thenetcircle/dino

View on GitHub
dino/rest/resources/joins.py

Summary

Maintainability
A
55 mins
Test Coverage
import logging
from datetime import datetime

from flask import request

from dino import environ
from dino.exceptions import NoSuchRoomException
from dino.rest.resources.base import BaseResource
from dino.utils import b64d
from dino.utils.decorators import timeit

logger = logging.getLogger(__name__)


class JoinsInRoomResource(BaseResource):
    def __init__(self):
        super(JoinsInRoomResource, self).__init__()
        self.last_cleared = datetime.utcnow()
        self.request = request

    def _do_get(self, room_id: str = None, room_name: str = None):
        try:
            if room_id is not None:
                return environ.env.db.get_joins_in_room(room_id) or 0
            else:
                return environ.env.db.get_joins_in_room_by_name(room_name) or 0
        except Exception as e:
            e_msg = "no such room: {}".format(room_id)
            logger.error(e_msg)
            logger.exception(e)
            raise RuntimeError(str(e))

    def do_get_with_params(self, room_id: str = None, room_name: str = None):
        return self._do_get(room_id, room_name)

    @timeit(logger, 'on_rest_count_joins')
    def do_get(self):
        is_valid, msg, json = self.validate_json(self.request, silent=False)
        if not is_valid:
            logger.error('invalid json: %s' % msg)
            return dict()

        logger.debug('GET request: %s' % str(json))
        if 'room_ids' not in json and 'room_names' not in json:
            return dict()

        output = dict()

        if 'room_ids' in json:
            for room_id in json['room_ids']:
                output[room_id] = self.do_get_with_params(room_id=room_id)

        if 'room_names' in json:
            for room_name in json['room_names']:
                output[room_name] = self.do_get_with_params(room_name=b64d(room_name))

        return output

    def _get_lru_method(self):
        return self.do_get_with_params

    def _get_last_cleared(self):
        return self.last_cleared

    def _set_last_cleared(self, last_cleared):
        self.last_cleared = last_cleared