async def remove_user_vault_key(self, identity: Identity, user_id: str, user_identity: Identity) -> Revision: vault = self.vault if vault is None: raise ValueError("Invalid argument") self.logger.debug('Removing user vault key') revision = Revision(operation=RevisionOp.RemoveUserKey) revision.vault_id = vault.config.id revision.parent_id = vault.revision revision.user_id = user_id revision.user_public_key = user_identity.public_key.exportKey("DER") revision.sign(identity=identity) # upload metadata await self.write_term('remove_user_vault_key', user_id, revision.user_public_key, user_identity.get_fingerprint(), revision.user_fingerprint, revision.parent_id, revision.signature ) # assert :ok response = await self.read_response() ret_revision = self.server_info_to_revision(rewrite_atoms_dict(response), vault) revision.revision_id = ret_revision.revision_id revision.created_at = ret_revision.created_at return revision
async def remove_user_vault_key(self, identity: Identity, user_id: str, user_identity: Identity) -> Revision: vault = self.vault if vault is None: raise ValueError("Invalid argument") self.logger.debug('Removing user vault key') revision = Revision(operation=RevisionOp.RemoveUserKey) revision.vault_id = vault.config.id revision.parent_id = vault.revision revision.user_id = user_id revision.user_public_key = user_identity.public_key.exportKey("DER") revision.sign(identity=identity) # upload metadata await self.write_term('remove_user_vault_key', user_id, revision.user_public_key, user_identity.get_fingerprint(), revision.user_fingerprint, revision.parent_id, revision.signature) # assert :ok response = await self.read_response() ret_revision = self.server_info_to_revision( rewrite_atoms_dict(response), vault) revision.revision_id = ret_revision.revision_id revision.created_at = ret_revision.created_at return revision
async def remove_user_vault_key(self, identity: Identity, user_id: str, user_identity: Identity): vault = cast(Vault, self.vault) # We can savely cast because of @require_vault logger.info("Removing user vault key %s", user_id) revision = Revision(operation=RevisionOp.RemoveUserKey) revision.vault_id = vault.config.id revision.parent_id = vault.revision revision.user_public_key = user_identity.public_key.exportKey('DER') revision.user_id = user_id revision.sign(identity=identity) return self.add_revision(revision)
async def remove_user_vault_key(self, identity: Identity, user_id: str, user_identity: Identity): vault = cast( Vault, self.vault) # We can savely cast because of @require_vault logger.info("Removing user vault key %s", user_id) revision = Revision(operation=RevisionOp.RemoveUserKey) revision.vault_id = vault.config.id revision.parent_id = vault.revision revision.user_public_key = user_identity.public_key.exportKey('DER') revision.user_id = user_id revision.sign(identity=identity) return self.add_revision(revision)
async def create_vault(self, identity: Identity) -> Revision: vault = self.vault if vault is None: raise ValueError("Invalid argument") revision = Revision(operation=RevisionOp.CreateVault) revision.vault_public_key = vault.identity.public_key.exportKey("DER") revision.user_public_key = identity.public_key.exportKey("DER") revision.user_id = '*****@*****.**' # TBD revision.sign(identity=identity) await self.write_term('create_vault', revision.vault_public_key, revision.user_public_key, revision.user_fingerprint, revision.signature) response = await self.read_term() vault_id = response[1].decode(vault.config.encoding) auth = response[2].decode(vault.config.encoding) server_info = rewrite_atoms_dict(response[3]) if not vault_id: raise ServerError("Invalid vault ID: {0}".format(vault_id)) if not auth: raise ServerError("Invalid auth token: {0}".format(auth)) revision.vault_id = vault_id # assert :ok ret_revision = self.server_info_to_revision(server_info, vault) revision.revision_id = ret_revision.revision_id revision.created_at = ret_revision.created_at self.logger.info('Successfully created vault %s', vault_id) with vault.config.update_context(): vault.config.update('remote', { 'auth': auth }) vault.config.update('vault', { 'id': response[1].decode(vault.config.encoding) }) return revision
async def create_vault(self, identity: Identity) -> Revision: vault = self.vault if vault is None: raise ValueError("Invalid argument") revision = Revision(operation=RevisionOp.CreateVault) revision.vault_public_key = vault.identity.public_key.exportKey("DER") revision.user_public_key = identity.public_key.exportKey("DER") user_info = await self.user_info() revision.user_id = user_info['email'] revision.sign(identity=identity) await self.write_term('create_vault', revision.vault_public_key, revision.user_public_key, revision.user_fingerprint, revision.signature) response = await self.read_term() vault_id = response[1].decode(vault.config.encoding) auth = response[2].decode(vault.config.encoding) server_info = rewrite_atoms_dict(response[3]) if not vault_id: raise ServerError("Invalid vault ID: {0}".format(vault_id)) if not auth: raise ServerError("Invalid auth token: {0}".format(auth)) revision.vault_id = vault_id # assert :ok ret_revision = self.server_info_to_revision(server_info, vault) revision.revision_id = ret_revision.revision_id revision.created_at = ret_revision.created_at self.logger.info('Successfully created vault %s', vault_id) with vault.config.update_context(): vault.config.update('remote', {'auth': auth}) vault.config.update( 'vault', {'id': response[1].decode(vault.config.encoding)}) return revision
async def init(self, identity: Identity) -> Revision: vault = cast(Vault, self.vault) # We can savely cast because of @require_vault new_vault_id = str(uuid4()) if not vault.config.get("vault.id"): with vault.config.update_context(): vault.config.update("vault", {"id": new_vault_id}) await self.open() # create directory # create txchain store with open(os.path.join(self.path, "txchain"), "wb"): pass revision = Revision(operation=RevisionOp.CreateVault) revision.vault_id = new_vault_id revision.user_id = "user@localhost" revision.vault_public_key = vault.identity.public_key.exportKey("DER") revision.user_public_key = identity.public_key.exportKey("DER") revision.sign(identity=identity) return self.add_revision(revision)
async def init(self, identity: Identity) -> Revision: vault = cast( Vault, self.vault) # We can savely cast because of @require_vault new_vault_id = str(uuid4()) if not vault.config.get("vault.id"): with vault.config.update_context(): vault.config.update("vault", {"id": new_vault_id}) await self.open() # create directory # create txchain store with open(os.path.join(self.path, "txchain"), "wb"): pass revision = Revision(operation=RevisionOp.CreateVault) revision.vault_id = new_vault_id revision.user_id = "user@localhost" revision.vault_public_key = vault.identity.public_key.exportKey("DER") revision.user_public_key = identity.public_key.exportKey("DER") revision.sign(identity=identity) return self.add_revision(revision)