-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathupdate.py
100 lines (77 loc) · 2.61 KB
/
update.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
# This file didn't used in the userbot because it has error
import threading
import asyncio
import contextlib
import os
import sys
from asyncio import CancelledError
import heroku3
import urllib3
from git import Repo
from git.exc import GitCommandError, InvalidGitRepositoryError, NoSuchPathError
from telethon import events
from sqlalchemy import distinct, func
from sqlalchemy.ext.declarative import declarative_base
import logging
from asyncio import CancelledError
from config import *
from sqlalchemy import create_engine
from sqlalchemy.orm import declarative_base
from sqlalchemy import Column, PickleType, UnicodeText
import urllib3
import heroku3
BASE = declarative_base()
engine = create_engine("sqlite:///fifthon.db", echo=False)
class Cat_GlobalCollection(BASE):
__tablename__ = "sed_connection"
keywoard = Column(UnicodeText, primary_key=True)
contents = Column(PickleType, primary_key=True, nullable=False)
def __init__(self, keywoard, contents):
self.keywoard = keywoard
self.contents = tuple(contents)
def __repr__(self):
return "<Cat Global Collection lists '%s' for %s>" % (
self.contents,
self.keywoard,
)
def __eq__(self, other):
return (
isinstance(other, Cat_GlobalCollection)
and self.keywoard == other.keywoard
and self.contents == other.contents
)
BASE.metadata.create_all(engine)
# Cat_GlobalCollection.__table__.create(checkfirst=True)
CAT_GLOBALCOLLECTION = threading.RLock()
class COLLECTION_SQL:
def __init__(self):
self.CONTENTS_LIST = {}
COLLECTION_SQL_ = COLLECTION_SQL()
def add_to_collectionlist(keywoard, contents):
with CAT_GLOBALCOLLECTION:
keyword_items = Cat_GlobalCollection(keywoard, tuple(contents))
SESSION.merge(keyword_items)
SESSION.commit()
COLLECTION_SQL_.CONTENTS_LIST.setdefault(
keywoard, set()).add(tuple(contents))
def get_collectionlist_items():
try:
chats = SESSION.query(Cat_GlobalCollection.keywoard).distinct().all()
return [i[0] for i in chats]
finally:
SESSION.close()
def del_keyword_collectionlist(keywoard):
with CAT_GLOBALCOLLECTION:
keyword_items = (
SESSION.query(Cat_GlobalCollection.keywoard)
.filter(Cat_GlobalCollection.keywoard == keywoard)
.delete()
)
COLLECTION_SQL_.CONTENTS_LIST.pop(keywoard)
SESSION.commit()
logging.basicConfig(
format="[%(levelname)s- %(asctime)s]- %(name)s- %(message)s",
level=logging.INFO,
datefmt="%H:%M:%S",
)
LOGS = logging.getLogger(__name__)