This repository has been archived by the owner on Dec 4, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathmain.py
102 lines (79 loc) · 3.1 KB
/
main.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
import asyncio
import os
import dataset
import dotenv
import hikari
import lightbulb
from loguru import logger as log
from scraper import generate_embed, scrape
dotenv.load_dotenv()
bot = lightbulb.BotApp(token=os.getenv("TOKEN"))
db = dataset.connect("sqlite:///data.db")
table = db["subscriptions"]
async def run_background() -> None:
log.info("Scraper started.")
while True:
log.info("Executing scraping loop")
for sub in db["subscriptions"]:
print(sub)
items = scrape(db, sub)
log.debug("{items} found for {id}", items=len(items), id=str(sub["id"]))
for item in items:
embed = generate_embed(item, sub["id"])
await bot.rest.create_message(sub["channel_id"], embed=embed)
if len(items) > 0:
# Update table by using last in date item timestamp
table.update(
{
"id": sub["id"],
"last_sync": int(
items[0]["photo"]["high_resolution"]["timestamp"]
),
},
["id"],
)
log.info("Sleeping for {interval} seconds", interval=os.getenv("INTERVAL", 60))
await asyncio.sleep(int(os.getenv("INTERVAL", 60)))
@bot.listen(hikari.ShardReadyEvent)
async def ready_listener(_):
log.info("Bot is ready")
log.info("{count} subscriptions registered", count=table.count())
asyncio.create_task(run_background())
@bot.command()
@lightbulb.option("url", "URL to vinted search", type=str, required=True)
@lightbulb.option(
"channel", "Channel to receive alerts", type=hikari.TextableChannel, required=True
)
@lightbulb.command("subscribe", "Subscribe to a Vinted search")
@lightbulb.implements(lightbulb.SlashCommand)
async def subscribe(ctx: lightbulb.Context) -> None:
table.insert(
{"url": ctx.options.url, "channel_id": ctx.options.channel.id, "last_sync": -1}
)
log.info("Subscription created for {url}", url=ctx.options.url)
await ctx.respond("✅ Created subscription")
@bot.command()
@lightbulb.command("subscriptions", "Get a list of subscription")
@lightbulb.implements(lightbulb.SlashCommand)
async def subscriptions(ctx: lightbulb.Context) -> None:
embed = hikari.Embed(title="Subscriptions")
for sub in table:
embed.add_field(name="#" + str(sub["id"]), value=sub["url"])
await ctx.respond(embed)
@bot.command()
@lightbulb.option("id", "ID of the subscription", type=int, required=True)
@lightbulb.command("unsubscribe", "Stop following a subscription")
@lightbulb.implements(lightbulb.SlashCommand)
async def unsubscribe(ctx: lightbulb.Context) -> None:
table.delete(id=ctx.options.id)
log.info("Deleted subscription #{id}", id=str(ctx.options.id))
await ctx.respond(f"🗑 Deleted subscription #{str(ctx.options.id)}.")
if __name__ == "__main__":
if os.name != "nt":
import uvloop
uvloop.install()
bot.run(
activity=hikari.Activity(
name="Vinted articles!", type=hikari.ActivityType.WATCHING
)
)