Exemple #1
0
async def disconnect(event):
    user_id = event.from_id
    old = mongodb.connections.find_one({'user_id': user_id})
    if not old:
        await event.reply(get_string("connections", "u_wasnt_connected", event.chat_id))
        return
    chat_title = await get_conn_chat(user_id, event.chat_id)
    mongodb.connections.delete_one({'_id': old['_id']})
    redis.delete('connection_cache_{}'.format(user_id))
    await event.reply(get_string("connections", "disconnected", event.chat_id).format(chat_title))
Exemple #2
0
def update_locks_cache(chat_id):
    key = 'locks_cache_{}'.format(chat_id)
    redis.delete(key)
    data = mongodb.locks.find_one({'chat_id': chat_id})
    if not data:
        return False
    for lock in data:
        if lock == 'chat_id' or lock == '_id':
            continue
        if data[lock] is True:
            redis.lpush(key, lock)
    redis.expire(key, 3600)
    return True
Exemple #3
0
def update_handlers_cache(chat_id):
    filters = mongodb.filters.find({'chat_id': chat_id})
    redis.delete('filters_cache_{}'.format(chat_id))
    for filter in filters:
        redis.lpush('filters_cache_{}'.format(chat_id), filter['handler'])