2018-04-27 17:16:43 +00:00
|
|
|
from click import argument, option
|
2018-05-30 10:49:40 +00:00
|
|
|
from flask import current_app as app
|
2018-04-27 17:16:43 +00:00
|
|
|
|
|
|
|
from ereuse_devicehub import devicehub
|
|
|
|
from ereuse_devicehub.db import db
|
2018-05-30 10:49:40 +00:00
|
|
|
from ereuse_devicehub.resources.user.models import Organization, User
|
2018-04-27 17:16:43 +00:00
|
|
|
from ereuse_devicehub.resources.user.schemas import User as UserS
|
|
|
|
from ereuse_devicehub.resources.user.views import UserView, login
|
2018-05-30 10:49:40 +00:00
|
|
|
from teal.db import SQLAlchemy
|
2018-04-27 17:16:43 +00:00
|
|
|
from teal.resource import Converters, Resource
|
|
|
|
|
|
|
|
|
|
|
|
class UserDef(Resource):
|
|
|
|
SCHEMA = UserS
|
|
|
|
VIEW = UserView
|
2018-06-15 13:31:03 +00:00
|
|
|
ID_CONVERTER = Converters.uuid
|
2018-04-27 17:16:43 +00:00
|
|
|
AUTH = True
|
|
|
|
|
|
|
|
def __init__(self, app: 'devicehub.Devicehub', import_name=__package__, static_folder=None,
|
|
|
|
static_url_path=None, template_folder=None, url_prefix=None, subdomain=None,
|
|
|
|
url_defaults=None, root_path=None):
|
2018-05-30 10:49:40 +00:00
|
|
|
cli_commands = ((self.create_user, 'create-user'),)
|
2018-04-27 17:16:43 +00:00
|
|
|
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
|
|
|
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
|
|
|
self.add_url_rule('/login', view_func=login, methods={'POST'})
|
|
|
|
|
|
|
|
@argument('email')
|
|
|
|
@option('--password', prompt=True, hide_input=True, confirmation_prompt=True)
|
|
|
|
def create_user(self, email: str, password: str) -> dict:
|
|
|
|
"""
|
|
|
|
Creates an user.
|
|
|
|
"""
|
2018-05-30 10:49:40 +00:00
|
|
|
u = self.SCHEMA(only={'email', 'password'}, exclude=('token',)) \
|
|
|
|
.load({'email': email, 'password': password})
|
|
|
|
user = User(**u)
|
|
|
|
db.session.add(user)
|
|
|
|
db.session.commit()
|
|
|
|
return self.schema.dump(user)
|
|
|
|
|
|
|
|
|
|
|
|
class OrganizationDef(Resource):
|
|
|
|
__type__ = 'Organization'
|
2018-06-15 13:31:03 +00:00
|
|
|
ID_CONVERTER = Converters.uuid
|
2018-05-30 10:49:40 +00:00
|
|
|
AUTH = True
|
|
|
|
|
|
|
|
def __init__(self, app, import_name=__package__, static_folder=None, static_url_path=None,
|
|
|
|
template_folder=None, url_prefix=None, subdomain=None, url_defaults=None,
|
|
|
|
root_path=None):
|
|
|
|
cli_commands = ((self.create_org, 'create-org'),)
|
|
|
|
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
|
|
|
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
|
|
|
|
|
|
|
@argument('name')
|
|
|
|
@argument('tax_id')
|
|
|
|
@argument('country')
|
|
|
|
def create_org(self, **kw: dict) -> dict:
|
|
|
|
"""
|
|
|
|
Creates an organization.
|
|
|
|
COUNTRY has to be 2 characters as defined by
|
|
|
|
"""
|
|
|
|
org = Organization(**self.schema.load(kw))
|
|
|
|
db.session.add(org)
|
|
|
|
db.session.commit()
|
|
|
|
return self.schema.dump(org)
|
|
|
|
|
|
|
|
def init_db(self, db: SQLAlchemy):
|
|
|
|
"""Creates the default organization."""
|
|
|
|
org = Organization(**app.config.get_namespace('ORGANIZATION_'))
|
|
|
|
db.session.add(org)
|