Compare commits

...

3 commits

Author SHA1 Message Date
Leander dbaec0332b
Updated autocredits.py 2023-08-07 14:55:53 +02:00
Leander 9b8ab4eced
Updated settings.py 2023-08-07 14:55:39 +02:00
Leander 3f1db2dd3e
Updated main.py 2023-08-07 14:55:17 +02:00
3 changed files with 44 additions and 52 deletions

View file

@ -1,12 +1,15 @@
async def get_all_users(client):
users = client['nova-core']['users']
return users
async def update_credits(users, settings=None):
async def update_credits(pymongo_client, settings=None):
users = await get_all_users(pymongo_client)
if not settings:
users.update_many({}, {"$inc": {"credits": 250}})
users.update_many({}, {"$inc": {"credits": 2500}})
else:
for key, value in settings.items():
users.update_many({'role': key}, {"$inc": {"credits": int(value)}})
print(f'Updated {key} to {value}')
users.update_many(
{'level': key}, {"$inc": {"credits": int(value)}})

View file

@ -1,59 +1,48 @@
import os
import asyncio
import aiohttp
import pymongo
import autocredits
from dotenv import load_dotenv
from settings import roles
import autocredits
import aiohttp
from dotenv import load_dotenv
import os
import pymongo
load_dotenv()
pymongo_client = pymongo.MongoClient(os.getenv('MONGO_URI'))
CONNECTION_STRING = os.getenv("MONGO_URI")
async def main():
users = await autocredits.get_all_users(pymongo_client)
pymongo_client = pymongo.MongoClient(CONNECTION_STRING)
await update_roles(users)
await autocredits.update_credits(users, roles)
await update_roles(pymongo_client)
await autocredits.update_credits(pymongo_client, roles)
async def update_roles(users):
async def update_roles(pymongo_client):
async with aiohttp.ClientSession() as session:
try:
async with session.get('http://localhost:3224/get_roles') as response:
discord_users = await response.json()
async with session.get('http://0.0.0.0:3224/get_roles') as response:
data = await response.json()
except aiohttp.ClientError as e:
raise ValueError('Could not get roles.') from exc
lvlroles = [f'lvl{lvl}' for lvl in range(10, 110, 10)] + ['']
print(f"Error: {e}")
return
lvlroles = [f"lvl{lvl}" for lvl in range(10, 110, 10)]
discord_users = data
users = await autocredits.get_all_users(pymongo_client)
filtered_users = users.find({'role': {'$in': lvlroles}})
bulk_updates = []
for user in filtered_users:
for user in users.find():
discord = str(user['auth']['discord'])
for id_, roles in discord_users.items():
if id_ == discord:
for role in lvlroles:
print(2, id_)
if role in roles:
print(0, id_)
bulk_updates.append(pymongo.UpdateOne(
{'auth.discord': int(discord)},
{'$set': {'role': role}})
)
print(1, id_)
print(f'Updated {id_} to {role}')
break
users.update_one({'auth.discord': int(discord)}, {
'$set': {'level': role}})
print(f"Updated {discord} to {role}")
if bulk_updates:
with pymongo_client:
users.bulk_write(bulk_updates)
return users
if __name__ == "__main__":
asyncio.run(main())
asyncio.run(main())

View file

@ -1,13 +1,13 @@
roles = {
'': '250',
'lvl10': '280',
'lvl20': '310',
'lvl30': '340',
'lvl40': '370',
'lvl50': '400',
'lvl60': '430',
'lvl70': '460',
'lvl80': '490',
'lvl90': '520',
'lvl100': '550',
}
'': '2500',
'lvl10': '2800',
'lvl20': '3100',
'lvl30': '3400',
'lvl40': '3700',
'lvl50': '4000',
'lvl60': '4300',
'lvl70': '4600',
'lvl80': '4900',
'lvl90': '5200',
'lvl100': '5500',
}