Merge branch 'dpp' into dpp_upc

This commit is contained in:
Cayo Puigdefabregas 2023-06-15 19:19:02 +02:00
commit 2a6cc105e3
5 changed files with 106 additions and 13 deletions

View file

@ -0,0 +1,24 @@
import click
from ereuse_devicehub.db import db
from ereuse_devicehub.resources.agent.models import Person
from ereuse_devicehub.resources.user.models import User
class AddUser:
def __init__(self, app) -> None:
super().__init__()
self.app = app
self.schema = app.config.get('DB_SCHEMA')
self.app.cli.command('adduser', short_help='add a user.')(self.run)
@click.argument('email')
@click.argument('password')
def run(self, email, password):
name = email.split('@')[0]
user = User(email=email, password=password)
user.individuals.add(Person(name=name))
db.session.add(user)
db.session.commit()

View file

@ -0,0 +1,40 @@
from uuid import uuid4
from boltons.urlutils import URL
from ereuse_devicehub.db import db
from ereuse_devicehub.resources.agent.models import Person
from ereuse_devicehub.resources.inventory.model import Inventory
from ereuse_devicehub.resources.user.models import User
class InitDatas:
def __init__(self, app) -> None:
super().__init__()
self.app = app
self.schema = app.config.get('DB_SCHEMA')
self.app.cli.command(
'initdata', short_help='Save a minimum structure of datas.'
)(self.run)
def run(self):
inv = Inventory(
id=self.schema,
name="usody",
tag_provider=URL('http://localhost:8081'),
tag_token=uuid4(),
org_id=uuid4(),
)
db.session.add(inv)
db.session.commit()
email = 'user@dhub.com'
password = '1234'
name = 'user'
user = User(email=email, password=password)
user.individuals.add(Person(name=name))
db.session.add(user)
db.session.commit()

View file

@ -12,6 +12,8 @@ from flask_sqlalchemy import SQLAlchemy
import ereuse_devicehub.ereuse_utils.cli import ereuse_devicehub.ereuse_utils.cli
from ereuse_devicehub.auth import Auth from ereuse_devicehub.auth import Auth
from ereuse_devicehub.client import Client, UserClient from ereuse_devicehub.client import Client, UserClient
from ereuse_devicehub.commands.adduser import AddUser
from ereuse_devicehub.commands.initdatas import InitDatas
# from ereuse_devicehub.commands.reports import Report # from ereuse_devicehub.commands.reports import Report
from ereuse_devicehub.commands.users import GetToken from ereuse_devicehub.commands.users import GetToken
@ -31,6 +33,21 @@ try:
except Exception: except Exception:
GetMembers = None GetMembers = None
try:
from ereuse_devicehub.modules.dpp.commands.register_user_dlt import RegisterUserDlt
except Exception:
RegisterUserDlt = None
try:
from ereuse_devicehub.modules.oidc.commands.add_member import AddMember
except Exception:
AddMember = None
try:
from ereuse_devicehub.modules.oidc.commands.add_member import AddClientOidc
except Exception:
AddClientOidc = None
class Devicehub(Teal): class Devicehub(Teal):
test_client_class = Client test_client_class = Client
@ -78,8 +95,17 @@ class Devicehub(Teal):
self.dummy = Dummy(self) self.dummy = Dummy(self)
# self.report = Report(self) # self.report = Report(self)
self.get_token = GetToken(self) self.get_token = GetToken(self)
self.initdata = InitDatas(self)
self.adduser = AddUser(self)
if GetMembers: if GetMembers:
self.get_members = GetMembers(self) self.get_members = GetMembers(self)
if RegisterUserDlt:
self.register_user_dlt = RegisterUserDlt(self)
if AddMember:
self.register_user_dlt = AddMember(self)
if AddClientOidc:
self.register_user_dlt = AddClientOidc(self)
@self.cli.group( @self.cli.group(
short_help='Inventory management.', short_help='Inventory management.',

View file

@ -8,12 +8,11 @@ Create Date: 2020-05-07 10:04:40.269511
import citext import citext
import sqlalchemy as sa import sqlalchemy as sa
import sqlalchemy_utils import sqlalchemy_utils
from ereuse_devicehub import teal from alembic import context, op
from alembic import context
from alembic import op
from sqlalchemy.dialects import postgresql from sqlalchemy.dialects import postgresql
from ereuse_devicehub.resources.enums import TransferState, Severity from ereuse_devicehub import teal
from ereuse_devicehub.resources.enums import Severity, TransferState
# revision identifiers, used by Alembic. # revision identifiers, used by Alembic.
revision = 'fbb7e2a0cde0' revision = 'fbb7e2a0cde0'
@ -348,6 +347,7 @@ def upgrade():
postgresql_using='hash', postgresql_using='hash',
schema=f'{get_inv()}', schema=f'{get_inv()}',
) )
op.execute(f"CREATE SEQUENCE {get_inv()}.device_seq START 1;")
op.create_table( op.create_table(
'agent', 'agent',
sa.Column( sa.Column(

View file

@ -138,7 +138,7 @@ class User(UserMixin, Thing):
data = json.dumps(data) data = json.dumps(data)
self.api_keys_dlt = encrypt(password, data) self.api_keys_dlt = encrypt(password, data)
def allow_permitions(self, api_token=None): def allow_permitions(self, api_token=None, rols="Operator"):
if 'dpp' not in app.blueprints.keys(): if 'dpp' not in app.blueprints.keys():
return return
@ -152,22 +152,25 @@ class User(UserMixin, Thing):
apiUser1 = API(api_dlt, keyUser1, "ethereum") apiUser1 = API(api_dlt, keyUser1, "ethereum")
result = apiUser1.issue_credential("Operator", target_user) for rol in rols.split(","):
result = apiUser1.issue_credential(rol.strip(), target_user)
return result return result
def get_rols(self): def get_rols_dlt(self):
if session.get('rols'): return json.loads(self.rols_dlt)
return session.get('rols')
def get_rols(self, token_dlt=None):
if 'dpp' not in app.blueprints.keys(): if 'dpp' not in app.blueprints.keys():
return [] return []
if not session.get('token_dlt'): if not token_dlt:
return [] token_dlt = session.get('token_dlt')
if not token_dlt:
return []
token_dlt = session.get('token_dlt')
api_dlt = app.config.get('API_DLT') api_dlt = app.config.get('API_DLT')
if not token_dlt or not api_dlt: if not api_dlt:
return [] return []
api = API(api_dlt, token_dlt, "ethereum") api = API(api_dlt, token_dlt, "ethereum")