File size: 4,626 Bytes
434f798
30462e3
c87648d
8dd1108
1f188d9
f6602f2
1f188d9
 
ad9d692
960e451
1f188d9
c6565e2
960e451
773ec73
d522acf
960e451
cbfe4d5
78dea1a
b7eca85
cbfe4d5
d522acf
09d6ac2
06157f0
 
 
 
37baec4
d522acf
 
 
b80bf81
960e451
 
cbfe4d5
960e451
 
 
 
 
 
 
 
 
 
 
 
cbfe4d5
960e451
 
 
 
 
 
 
 
 
 
 
 
a56363d
ae4f533
960e451
 
 
ae4f533
 
5e34c0f
 
 
 
 
 
 
 
2cf1870
5e34c0f
 
30462e3
5e34c0f
 
2cf1870
5e34c0f
 
 
2cf1870
5e34c0f
d522acf
ae4f533
960e451
 
 
 
ae4f533
960e451
 
 
 
c87648d
cbfe4d5
139364e
960e451
 
139364e
960e451
cbfe4d5
139364e
960e451
 
 
 
 
 
139364e
 
 
960e451
 
139364e
960e451
 
cbfe4d5
 
 
 
 
 
 
960e451
 
 
 
 
 
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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
import os
import io
import sys
import asyncio
import discord
import aiohttp
import pandas as pd
import gradio as gr
from datetime import datetime, timedelta
from discord.ext import commands
from apscheduler.schedulers.asyncio import AsyncIOScheduler

# Environment variable for Discord token
DISCORD_TOKEN = os.environ.get("DISCORD_TOKEN", None)

# Create Discord bot with all intents
intents = discord.Intents.all()
bot = commands.Bot(command_prefix='!', intents=intents)

# Set up an async scheduler for periodic tasks (like a bot restart)
scheduler = AsyncIOScheduler()

def restart_bot():
    print("Restarting bot...")
    os.execv(sys.executable, ['python'] + sys.argv)

@scheduler.scheduled_job('interval', minutes=60)
def periodic_restart():
    print("Scheduled restart triggered...")
    restart_bot()

async def process_row(row, guild, role):
    """
    Process a single CSV row: if the Discord member associated with the row hasn't received the role, add it.
    """
    hf_user_name = row['hf_user_name']
    if pd.notna(hf_user_name) and hf_user_name.lower() != 'n/a':
        discord_id = row['discord_user_id'].strip('L')
        try:
            member = guild.get_member(int(discord_id))
        except Exception as e:
            print(f"Error converting Discord ID {discord_id}: {e}")
            return

        if not member:
            return

        if role not in member.roles:
            try:
                await member.add_roles(role)
                print(f"Role added to member: {member}")
                lunar = bot.get_user(811235357663297546)
                if lunar:
                    await lunar.send(f"Verified role given to {member}!")
                await member.send(
                    f"Verification successful! [{member} <---> {row['discord_user_name']}]"
                )
            except Exception as e:
                print(f"Error processing member {member}: {e}")

async def give_verified_roles():
    """
    Periodically fetch CSV data from Google Sheets and verify roles for members.
    """
    while True:
        try:
            async with aiohttp.ClientSession() as session:
                try:
                    async with session.get(
                        "https://docs.google.com/spreadsheets/d/1C8aLqgCqLYcMiIFf-P_Aosaa03C_WLIB_UyqvjSdWg8/export?format=csv&gid=0",
                        timeout=10
                    ) as response:
                        if response.status != 200:
                            print(f"Failed to fetch CSV: HTTP {response.status}")
                            await asyncio.sleep(30)
                            continue
                        csv_data = await response.text()
                        global_df = pd.read_csv(io.StringIO(csv_data))
                except asyncio.TimeoutError:
                    print("CSV fetch timed out.")
                    await asyncio.sleep(30)
                    continue
                except Exception as e:
                    print(f"Error fetching CSV: {e}")
                    await asyncio.sleep(30)
                    continue

            guild = bot.get_guild(879548962464493619)
            if not guild:
                print("Guild not found.")
                await asyncio.sleep(30)
                continue
            role = guild.get_role(900063512829755413)
            if not role:
                print("Role not found.")
                await asyncio.sleep(30)
                continue

            await guild.chunk()  # Cache all guild members

            tasks = [process_row(row, guild, role) for _, row in global_df.iterrows()]
            await asyncio.gather(*tasks)
        except Exception as e:
            print(f"Error in give_verified_roles loop: {e}")
        await asyncio.sleep(30)  # Adjust the sleep interval as needed

@bot.event
async def on_ready():
    print(f"We have logged in as {bot.user}")
    scheduler.start()
    # Start the background role verification loop
    bot.loop.create_task(give_verified_roles())

def greet(name):
    return "Hello " + name + "!"

# Create the Gradio interface
demo = gr.Interface(fn=greet, inputs="text", outputs="text")

async def main():
    # Launch Gradio in a separate thread (non-blocking) without using the unsupported 'block' parameter
    gradio_thread = asyncio.to_thread(demo.launch, share=False)
    # Run both the Discord bot and Gradio concurrently
    await asyncio.gather(
        bot.start(DISCORD_TOKEN),
        gradio_thread
    )

if __name__ == "__main__":
    try:
        asyncio.run(main())
    except KeyboardInterrupt:
        print("Shutting down...")