1
0
Fork 0
mirror of https://github.com/myned/modufur.git synced 2024-12-26 15:07:27 +00:00
modufur/src/main/utils/utils.py

100 lines
2.7 KiB
Python
Raw Normal View History

2017-10-13 02:30:07 +00:00
import asyncio
import json
2017-10-14 03:59:14 +00:00
import os
2017-10-13 02:30:07 +00:00
import pickle as pkl
import subprocess
from contextlib import suppress
2017-10-13 02:30:07 +00:00
import aiohttp
from pync import Notifier
print('\nPID : {}\n'.format(os.getpid()))
# def notify(message):
# subprocess.run(['terminal-notifier', '-message', message, '-title',
# 'Modumind', '-activate', 'com.apple.Terminal', '-appIcon', 'icon.png', '-sound', 'Ping'], stdout=subprocess.PIPE, stderr=subprocess.PIPE)
2017-10-13 02:30:07 +00:00
2017-10-14 03:59:14 +00:00
try:
with open('config.json') as infile:
config = json.load(infile)
print('config.json loaded.')
2017-10-14 03:59:14 +00:00
except FileNotFoundError:
with open('config.json', 'w') as outfile:
json.dump({'client_id': 0, 'listed_ids': [0], 'owner_id': 0, 'permissions': 126016, 'prefix': ',',
'shutdown_channel': 0, 'startup_channel': 0, 'token': 'str'}, outfile, indent=4, sort_keys=True)
raise FileNotFoundError(
'Config file not found: config.json created with abstract values. Restart run.py with correct values.')
2017-10-14 03:59:14 +00:00
2017-10-13 02:30:07 +00:00
def setdefault(filename, default=None):
try:
with open(filename, 'rb') as infile:
print('{} loaded.'.format(filename))
2017-10-13 02:30:07 +00:00
return pkl.load(infile)
except FileNotFoundError:
with open(filename, 'wb+') as iofile:
print('File not found: {} created and loaded with default values.'.format(filename))
2017-10-13 02:30:07 +00:00
pkl.dump(default, iofile)
iofile.seek(0)
return pkl.load(iofile)
def load(filename):
with open(filename, 'rb') as infile:
return pkl.load(infile)
def dump(obj, filename):
with open(filename, 'wb') as outfile:
pkl.dump(obj, outfile)
2017-10-13 02:30:07 +00:00
2017-10-15 03:40:56 +00:00
settings = setdefault('settings.pkl', {'del_ctx': []})
tasks = setdefault('cogs/tasks.pkl', {'auto_del': []})
2017-10-13 02:30:07 +00:00
async def clear(obj, interval=10 * 60, replace=None):
if replace is None:
if type(obj) is list:
replace = []
elif type(obj) is dict:
replace = {}
elif type(obj) is int:
replace = 0
elif type(obj) is str:
replace = ''
while True:
obj = replace
asyncio.sleep(interval)
2017-10-13 02:30:07 +00:00
session = aiohttp.ClientSession()
def close(loop):
global session
if session:
session.close()
loop.stop()
pending = asyncio.Task.all_tasks()
for task in pending:
task.cancel()
# with suppress(asyncio.CancelledError):
# loop.run_until_complete(task)
# loop.close()
print('Finished cancelling tasks.')
2017-10-13 02:30:07 +00:00
async def fetch(url, *, params={}, json=False):
global session
async with session.get(url, params=params, headers={'user-agent': 'Modumind/0.0.1 (Myned)'}) as r:
if json is True:
return await r.json()
return await r.read()