@lifeready/core 7.0.4 → 7.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -4,7 +4,7 @@ import { Injectable } from '@angular/core';
4
4
  import graphlib, { Graph } from '@dagrejs/graphlib';
5
5
  import _ from 'lodash';
6
6
  import { asJwk, EncryptionService, isSymmetricKey, } from '../encryption/encryption.service';
7
- import { KcBadArgumentException, KcBadStateException, KcEncryptionException, KcNotFoundException, } from '../_common/exceptions';
7
+ import { KcBadArgumentException, KcBadLogicException, KcBadStateException, KcEncryptionException, KcNotFoundException, } from '../_common/exceptions';
8
8
  import { KeyFactoryService, KeyFactoryService as KFS, } from './key-factory.service';
9
9
  import { KeyService } from './key.service';
10
10
  import { KeyGraphEdgeType, KeyGraphNodeType, PayloadType, } from './key.types';
@@ -150,7 +150,13 @@ export class KeyGraphService {
150
150
  return __awaiter(this, void 0, void 0, function* () {
151
151
  let keyId = typeof keyOrId === 'string' ? keyOrId : keyOrId === null || keyOrId === void 0 ? void 0 : keyOrId.id;
152
152
  if (!this.hasKey(keyId) && getKeyIdCallback) {
153
- keyId = yield getKeyIdCallback();
153
+ const keyIdFromCallback = yield getKeyIdCallback();
154
+ if (keyId != null && keyId != keyIdFromCallback) {
155
+ throw new KcBadLogicException('Requested keyId is not in the key cache, so an API request was made to populate the key cache.' +
156
+ 'But the key returned by the API does NOT match the requested keyId.' +
157
+ 'This is a programming logic error.');
158
+ }
159
+ keyId = keyIdFromCallback;
154
160
  }
155
161
  // else, continue and let it fail.
156
162
  const key = this.key(keyId);
@@ -292,4 +298,4 @@ KeyGraphService.ctorParameters = () => [
292
298
  { type: KeyService },
293
299
  { type: KeyFactoryService }
294
300
  ];
295
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key-graph.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/key/key-graph.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Injectable } from '@angular/core';\nimport graphlib, { Graph } from '@dagrejs/graphlib';\nimport _ from 'lodash';\nimport { JWK } from 'node-jose';\nimport { JSONObject } from '../api/types';\nimport {\n  asJwk,\n  DecryptOptions,\n  EncryptionService,\n  isSymmetricKey,\n} from '../encryption/encryption.service';\nimport {\n  KcBadArgumentException,\n  KcBadStateException,\n  KcEncryptionException,\n  KcNotFoundException,\n} from '../_common/exceptions';\nimport {\n  KeyFactoryService,\n  KeyFactoryService as KFS,\n} from './key-factory.service';\nimport { KeyService, UserKeys } from './key.service';\nimport {\n  Key,\n  KeyGraphEdge,\n  KeyGraphEdgeType,\n  KeyGraphNode,\n  KeyGraphNodeType,\n  KeyGraphResponse,\n  PassKey,\n  PayloadType,\n} from './key.types';\n\nexport interface GraphKey extends Key {\n  task?: Promise<any>;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class KeyGraphService {\n  private graph: Graph;\n  // private keyCache: {\n  //   [id: string]: Key;\n  // };\n\n  constructor(\n    private encryptionService: EncryptionService,\n    private keyService: KeyService,\n    private keyFactory: KeyFactoryService\n  ) {\n    this.purgeKeys();\n  }\n\n  purgeKeys() {\n    this.graph = new Graph();\n    // this.keyCache = null;\n  }\n\n  async populateKeys(userKey: UserKeys) {\n    this.keyService.setKeys({\n      passKey: userKey.passKey,\n      masterKey: await this.keyService.loadMasterKey(userKey.masterKey.id),\n      rootKey: await this.unwrapKey(userKey.masterKey.id, userKey.rootKey.id),\n      pxk: await this.unwrapKey(userKey.masterKey.id, userKey.pxk.id),\n      sigPxk: await this.unwrapKey(userKey.masterKey.id, userKey.sigPxk.id),\n    });\n  }\n\n  hasKey(keyId: string) {\n    return !!this.graph.node(keyId);\n  }\n\n  private getNode(id, type): GraphKey | PassKey {\n    const node = this.graph.node(id);\n    if (!node) {\n      throw new KcNotFoundException(\n        `Key graphs does not contain key id: ${id}`\n      );\n    }\n    if (node.type !== type) {\n      throw new KcBadStateException(`Key with id ${id} is not of type ${type}`);\n    }\n    return node.data;\n  }\n\n  key(id): GraphKey {\n    return this.getNode(id, KeyGraphNodeType.Key);\n  }\n\n  passKey(id): PassKey {\n    return this.getNode(id, KeyGraphNodeType.PassKey);\n  }\n\n  addKeys(src: KeyGraphResponse) {\n    // Keys\n    if (src.keys) {\n      // What key graph returns can not be customized. So keys are essentially immutable.\n      // Therefore, if a key exists, there's no reason to update it.\n      for (const key of src.keys) {\n        // Note using Relay global id allows us to not worry about clashing node id\n        if (this.graph.hasNode(key.id)) {\n          continue;\n        }\n\n        const node: KeyGraphNode = {\n          type: KeyGraphNodeType.Key,\n          data: _.cloneDeep(key),\n        };\n\n        this.graph.setNode(key.id, node);\n      }\n    }\n\n    // KeyLinks\n    if (src.keyLinks) {\n      for (const keyLink of src.keyLinks) {\n        if (this.graph.hasEdge(keyLink.wrappingKeyId, keyLink.keyId)) {\n          continue;\n        }\n\n        const edge: KeyGraphEdge = {\n          type: KeyGraphEdgeType.KeyLink,\n          data: _.cloneDeep(keyLink),\n        };\n        // Edge goes from wrapping key to wrapped key.\n        this.graph.setEdge(keyLink.wrappingKeyId, keyLink.keyId, edge);\n      }\n    }\n\n    // PassKeyLinks\n    if (src.passKeyLinks) {\n      for (const passKeyLink of src.passKeyLinks) {\n        if (this.graph.hasEdge(passKeyLink.passKeyId, passKeyLink.keyId)) {\n          continue;\n        }\n\n        const edge: KeyGraphEdge = {\n          type: KeyGraphEdgeType.PassKeyLink,\n          data: _.cloneDeep(passKeyLink),\n        };\n        // Edge goes from wrapping key to wrapped key.\n        this.graph.setEdge(passKeyLink.passKeyId, passKeyLink.keyId, edge);\n      }\n    }\n\n    // The graph is the single source of truth. These are lazily calculated.\n    // this.keyCache = null;\n  }\n\n  tracePath(distances, keyId: string): KeyGraphEdge[] {\n    // The node label is the same as the id of the key nodes.\n    const ret: KeyGraphEdge[] = [];\n    let node = keyId;\n    if (!distances[node].predecessor) {\n      return null;\n    }\n\n    while (distances[node].predecessor) {\n      const child = distances[node].predecessor;\n      ret.push(this.graph.edge(child, node));\n      node = child;\n    }\n\n    // After reverse, the first element is the passkey\n    ret.reverse();\n\n    return ret;\n  }\n\n  getPath(knownKeyId: string, keyId: string): KeyGraphEdge[] {\n    if (!knownKeyId || typeof knownKeyId !== 'string') {\n      throw new KcEncryptionException(\n        `Param knownKeyId wrong format: ${knownKeyId}`\n      );\n    }\n    if (!keyId || typeof keyId !== 'string') {\n      throw new KcEncryptionException(`Param keyId wrong format: ${keyId}`);\n    }\n\n    // => { A: { distance: 0 },\n    //      B: { distance: 6, predecessor: 'C' },\n    //      C: { distance: 4, predecessor: 'A' },\n    //      D: { distance: 2, predecessor: 'A' },\n    //      E: { distance: 8, predecessor: 'F' },\n    //      F: { distance: 4, predecessor: 'D' } }\n    const distances = graphlib.alg.dijkstra(this.graph, knownKeyId);\n\n    // Trace path from keyId to knownKeyId\n    return this.tracePath(distances, keyId);\n  }\n\n  async getJwkKey(\n    keyOrId: string | Key,\n    getKeyIdCallback?: () => Promise<string> | string\n  ): Promise<JWK.Key> {\n    return (await this.getKey(keyOrId, getKeyIdCallback)).jwk;\n  }\n\n  // We assume that when a keyId is fetched, the key graph\n  // for the key is also returned and merged into the client-side\n  // key graph. By insisting a keyId is returned instead of the\n  // actual key we ensure key-graph is consistent.\n  async getKey(\n    keyOrId: string | Key,\n    getKeyIdCallback?: () => Promise<string> | string\n  ): Promise<Key> {\n    let keyId = typeof keyOrId === 'string' ? keyOrId : keyOrId?.id;\n\n    if (!this.hasKey(keyId) && getKeyIdCallback) {\n      keyId = await getKeyIdCallback();\n    }\n    // else, continue and let it fail.\n\n    const key = this.key(keyId);\n    if (key.jwk) {\n      return key;\n    } else {\n      return this.unwrapKey(this.keyService.currentMasterKey.id, keyId);\n    }\n  }\n\n  private async _unwrapLink(wrappingKey, link, dstKey) {\n    const wrappedKey = JSON.parse(link.data.wrappedKey);\n    // Signatures of keys contain the key itself. This way we only need\n    // to access the KeyLinks to decrypt/verify keys.\n    let nextRawKey;\n    if (wrappedKey.signatures) {\n      nextRawKey = await this.encryptionService.verify(wrappingKey, wrappedKey);\n    } else {\n      nextRawKey = await this.encryptionService.decrypt(\n        wrappingKey,\n        wrappedKey\n      );\n    }\n    dstKey.jwk = await KFS.asKey(nextRawKey);\n    dstKey.task = null;\n  }\n\n  private async _unwrap(key: JWK.Key, path: KeyGraphEdge[]): Promise<JWK.Key> {\n    for (const link of path) {\n      const dstKey = this.key(link.data.keyId);\n      if (dstKey.jwk) {\n        key = dstKey.jwk;\n        continue;\n      }\n\n      if (!dstKey.task) {\n        dstKey.task = this._unwrapLink(key, link, dstKey);\n      }\n\n      await dstKey.task;\n      key = dstKey.jwk;\n    }\n\n    return key;\n  }\n\n  public async unwrapWithPassKey(\n    passKeyId: string,\n    passKey: JWK.Key,\n    keyId: string\n  ): Promise<Key> {\n    // Get path of the directory key.\n    const path = this.getPath(passKeyId, keyId);\n\n    return {\n      id: keyId,\n      jwk: await this._unwrap(passKey, path),\n    };\n  }\n\n  async unwrapKey(masterKeyId: string, keyId: string): Promise<Key> {\n    // The first key should be a masterKey\n    const masterKey = await this.keyService.loadMasterKey(masterKeyId);\n\n    if (masterKeyId === keyId) {\n      return masterKey;\n    }\n\n    // Get path of the directory key.\n    const path = this.getPath(masterKey.id, keyId);\n\n    return {\n      id: keyId,\n      jwk: await this._unwrap(masterKey.jwk, path),\n    };\n  }\n\n  async decryptFromString<T>(\n    keyOrId: string | Key,\n    cipherData: string,\n    options?: DecryptOptions\n  ): Promise<T> {\n    if (cipherData) {\n      const key = await this.getJwkKey(keyOrId);\n      return (await this.encryptionService.decrypt(\n        key,\n        JSON.parse(cipherData),\n        options\n      )) as any;\n    }\n    return null;\n  }\n\n  async decryptFile(keyId: string, file: any): Promise<any> {\n    const key = await this.getJwkKey(keyId);\n    return (await this.encryptionService.decrypt(key, file, {\n      payloadType: PayloadType.UINT_8_ARRAY,\n    })) as any;\n  }\n\n  // TODO rename this to encrypt() and use as the most common usecase\n  async encryptToString(\n    key: string | Key | JWK.Key,\n    content: any\n  ): Promise<string> {\n    // Empty string should be encrypted since you want to clear the field.\n    // Null is not encrypted because it's not valid JSON in the old JSON spec. Use\n    // empty string instead. It'll function as a logic false as well.\n    // Note that passing in empty string means it'll be encrypted which verifies\n    // it's integrity. But we still want to have a way to set the DB field\n    // to NULL, so we explicitly return null when content == null. A null\n    // variable in graphql mutation on KC server clears the field to NULL.\n    if (content == null) {\n      return null;\n    }\n\n    const jwk = asJwk(key) || (await this.getJwkKey(key as string | Key));\n    return this.encryptionService.encryptToString(jwk, content);\n  }\n\n  // Wraps a symmetric encryption key.\n  // Throws exception if wrapping public keys.\n  async wrapKey(\n    wrappingKey: string | Key | JWK.Key,\n    key: JWK.Key\n  ): Promise<string> {\n    if (!isSymmetricKey(key)) {\n      throw new KcBadArgumentException(\n        'Only allowing wrapping of symmetric keys.'\n      );\n    }\n\n    return this.encryptToString(wrappingKey, key.toJSON(true));\n  }\n\n  // TODO\n  // async wrapPublicKey<T>();\n  // async wrapPrivateKey<T>();\n\n  async encryptWithNewKey(wrappingKeyId: string, cipherClearJson: JSONObject) {\n    const key = await this.keyFactory.createKey();\n    const wrappedKey = await this.encryptToString(\n      wrappingKeyId,\n      key.toJSON(true)\n    );\n    const cipher = await this.encryptToString(key, cipherClearJson);\n\n    return {\n      key,\n      wrappingKeyId,\n      wrappedKey,\n      cipher,\n    };\n  }\n}\n"]}
301
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key-graph.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/key/key-graph.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Injectable } from '@angular/core';\nimport graphlib, { Graph } from '@dagrejs/graphlib';\nimport _ from 'lodash';\nimport { JWK } from 'node-jose';\nimport { JSONObject } from '../api/types';\nimport {\n  asJwk,\n  DecryptOptions,\n  EncryptionService,\n  isSymmetricKey,\n} from '../encryption/encryption.service';\nimport {\n  KcBadArgumentException,\n  KcBadLogicException,\n  KcBadStateException,\n  KcEncryptionException,\n  KcNotFoundException,\n} from '../_common/exceptions';\nimport {\n  KeyFactoryService,\n  KeyFactoryService as KFS,\n} from './key-factory.service';\nimport { KeyService, UserKeys } from './key.service';\nimport {\n  Key,\n  KeyGraphEdge,\n  KeyGraphEdgeType,\n  KeyGraphNode,\n  KeyGraphNodeType,\n  KeyGraphResponse,\n  PassKey,\n  PayloadType,\n} from './key.types';\n\nexport interface GraphKey extends Key {\n  task?: Promise<any>;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class KeyGraphService {\n  private graph: Graph;\n  // private keyCache: {\n  //   [id: string]: Key;\n  // };\n\n  constructor(\n    private encryptionService: EncryptionService,\n    private keyService: KeyService,\n    private keyFactory: KeyFactoryService\n  ) {\n    this.purgeKeys();\n  }\n\n  purgeKeys() {\n    this.graph = new Graph();\n    // this.keyCache = null;\n  }\n\n  async populateKeys(userKey: UserKeys) {\n    this.keyService.setKeys({\n      passKey: userKey.passKey,\n      masterKey: await this.keyService.loadMasterKey(userKey.masterKey.id),\n      rootKey: await this.unwrapKey(userKey.masterKey.id, userKey.rootKey.id),\n      pxk: await this.unwrapKey(userKey.masterKey.id, userKey.pxk.id),\n      sigPxk: await this.unwrapKey(userKey.masterKey.id, userKey.sigPxk.id),\n    });\n  }\n\n  hasKey(keyId: string) {\n    return !!this.graph.node(keyId);\n  }\n\n  private getNode(id, type): GraphKey | PassKey {\n    const node = this.graph.node(id);\n    if (!node) {\n      throw new KcNotFoundException(\n        `Key graphs does not contain key id: ${id}`\n      );\n    }\n    if (node.type !== type) {\n      throw new KcBadStateException(`Key with id ${id} is not of type ${type}`);\n    }\n    return node.data;\n  }\n\n  key(id): GraphKey {\n    return this.getNode(id, KeyGraphNodeType.Key);\n  }\n\n  passKey(id): PassKey {\n    return this.getNode(id, KeyGraphNodeType.PassKey);\n  }\n\n  addKeys(src: KeyGraphResponse) {\n    // Keys\n    if (src.keys) {\n      // What key graph returns can not be customized. So keys are essentially immutable.\n      // Therefore, if a key exists, there's no reason to update it.\n      for (const key of src.keys) {\n        // Note using Relay global id allows us to not worry about clashing node id\n        if (this.graph.hasNode(key.id)) {\n          continue;\n        }\n\n        const node: KeyGraphNode = {\n          type: KeyGraphNodeType.Key,\n          data: _.cloneDeep(key),\n        };\n\n        this.graph.setNode(key.id, node);\n      }\n    }\n\n    // KeyLinks\n    if (src.keyLinks) {\n      for (const keyLink of src.keyLinks) {\n        if (this.graph.hasEdge(keyLink.wrappingKeyId, keyLink.keyId)) {\n          continue;\n        }\n\n        const edge: KeyGraphEdge = {\n          type: KeyGraphEdgeType.KeyLink,\n          data: _.cloneDeep(keyLink),\n        };\n        // Edge goes from wrapping key to wrapped key.\n        this.graph.setEdge(keyLink.wrappingKeyId, keyLink.keyId, edge);\n      }\n    }\n\n    // PassKeyLinks\n    if (src.passKeyLinks) {\n      for (const passKeyLink of src.passKeyLinks) {\n        if (this.graph.hasEdge(passKeyLink.passKeyId, passKeyLink.keyId)) {\n          continue;\n        }\n\n        const edge: KeyGraphEdge = {\n          type: KeyGraphEdgeType.PassKeyLink,\n          data: _.cloneDeep(passKeyLink),\n        };\n        // Edge goes from wrapping key to wrapped key.\n        this.graph.setEdge(passKeyLink.passKeyId, passKeyLink.keyId, edge);\n      }\n    }\n\n    // The graph is the single source of truth. These are lazily calculated.\n    // this.keyCache = null;\n  }\n\n  tracePath(distances, keyId: string): KeyGraphEdge[] {\n    // The node label is the same as the id of the key nodes.\n    const ret: KeyGraphEdge[] = [];\n    let node = keyId;\n    if (!distances[node].predecessor) {\n      return null;\n    }\n\n    while (distances[node].predecessor) {\n      const child = distances[node].predecessor;\n      ret.push(this.graph.edge(child, node));\n      node = child;\n    }\n\n    // After reverse, the first element is the passkey\n    ret.reverse();\n\n    return ret;\n  }\n\n  getPath(knownKeyId: string, keyId: string): KeyGraphEdge[] {\n    if (!knownKeyId || typeof knownKeyId !== 'string') {\n      throw new KcEncryptionException(\n        `Param knownKeyId wrong format: ${knownKeyId}`\n      );\n    }\n    if (!keyId || typeof keyId !== 'string') {\n      throw new KcEncryptionException(`Param keyId wrong format: ${keyId}`);\n    }\n\n    // => { A: { distance: 0 },\n    //      B: { distance: 6, predecessor: 'C' },\n    //      C: { distance: 4, predecessor: 'A' },\n    //      D: { distance: 2, predecessor: 'A' },\n    //      E: { distance: 8, predecessor: 'F' },\n    //      F: { distance: 4, predecessor: 'D' } }\n    const distances = graphlib.alg.dijkstra(this.graph, knownKeyId);\n\n    // Trace path from keyId to knownKeyId\n    return this.tracePath(distances, keyId);\n  }\n\n  async getJwkKey(\n    keyOrId: string | Key,\n    getKeyIdCallback?: () => Promise<string> | string\n  ): Promise<JWK.Key> {\n    return (await this.getKey(keyOrId, getKeyIdCallback)).jwk;\n  }\n\n  // We assume that when a keyId is fetched, the key graph\n  // for the key is also returned and merged into the client-side\n  // key graph. By insisting a keyId is returned instead of the\n  // actual key we ensure key-graph is consistent.\n  async getKey(\n    keyOrId: string | Key,\n    getKeyIdCallback?: () => Promise<string> | string\n  ): Promise<Key> {\n    let keyId = typeof keyOrId === 'string' ? keyOrId : keyOrId?.id;\n\n    if (!this.hasKey(keyId) && getKeyIdCallback) {\n      const keyIdFromCallback = await getKeyIdCallback();\n\n      if (keyId != null && keyId != keyIdFromCallback) {\n        throw new KcBadLogicException(\n          'Requested keyId is not in the key cache, so an API request was made to populate the key cache.' +\n            'But the key returned by the API does NOT match the requested keyId.' +\n            'This is a programming logic error.'\n        );\n      }\n\n      keyId = keyIdFromCallback;\n    }\n    // else, continue and let it fail.\n\n    const key = this.key(keyId);\n    if (key.jwk) {\n      return key;\n    } else {\n      return this.unwrapKey(this.keyService.currentMasterKey.id, keyId);\n    }\n  }\n\n  private async _unwrapLink(wrappingKey, link, dstKey) {\n    const wrappedKey = JSON.parse(link.data.wrappedKey);\n    // Signatures of keys contain the key itself. This way we only need\n    // to access the KeyLinks to decrypt/verify keys.\n    let nextRawKey;\n    if (wrappedKey.signatures) {\n      nextRawKey = await this.encryptionService.verify(wrappingKey, wrappedKey);\n    } else {\n      nextRawKey = await this.encryptionService.decrypt(\n        wrappingKey,\n        wrappedKey\n      );\n    }\n    dstKey.jwk = await KFS.asKey(nextRawKey);\n    dstKey.task = null;\n  }\n\n  private async _unwrap(key: JWK.Key, path: KeyGraphEdge[]): Promise<JWK.Key> {\n    for (const link of path) {\n      const dstKey = this.key(link.data.keyId);\n      if (dstKey.jwk) {\n        key = dstKey.jwk;\n        continue;\n      }\n\n      if (!dstKey.task) {\n        dstKey.task = this._unwrapLink(key, link, dstKey);\n      }\n\n      await dstKey.task;\n      key = dstKey.jwk;\n    }\n\n    return key;\n  }\n\n  public async unwrapWithPassKey(\n    passKeyId: string,\n    passKey: JWK.Key,\n    keyId: string\n  ): Promise<Key> {\n    // Get path of the directory key.\n    const path = this.getPath(passKeyId, keyId);\n\n    return {\n      id: keyId,\n      jwk: await this._unwrap(passKey, path),\n    };\n  }\n\n  async unwrapKey(masterKeyId: string, keyId: string): Promise<Key> {\n    // The first key should be a masterKey\n    const masterKey = await this.keyService.loadMasterKey(masterKeyId);\n\n    if (masterKeyId === keyId) {\n      return masterKey;\n    }\n\n    // Get path of the directory key.\n    const path = this.getPath(masterKey.id, keyId);\n\n    return {\n      id: keyId,\n      jwk: await this._unwrap(masterKey.jwk, path),\n    };\n  }\n\n  async decryptFromString<T>(\n    keyOrId: string | Key,\n    cipherData: string,\n    options?: DecryptOptions\n  ): Promise<T> {\n    if (cipherData) {\n      const key = await this.getJwkKey(keyOrId);\n      return (await this.encryptionService.decrypt(\n        key,\n        JSON.parse(cipherData),\n        options\n      )) as any;\n    }\n    return null;\n  }\n\n  async decryptFile(keyId: string, file: any): Promise<any> {\n    const key = await this.getJwkKey(keyId);\n    return (await this.encryptionService.decrypt(key, file, {\n      payloadType: PayloadType.UINT_8_ARRAY,\n    })) as any;\n  }\n\n  // TODO rename this to encrypt() and use as the most common usecase\n  async encryptToString(\n    key: string | Key | JWK.Key,\n    content: any\n  ): Promise<string> {\n    // Empty string should be encrypted since you want to clear the field.\n    // Null is not encrypted because it's not valid JSON in the old JSON spec. Use\n    // empty string instead. It'll function as a logic false as well.\n    // Note that passing in empty string means it'll be encrypted which verifies\n    // it's integrity. But we still want to have a way to set the DB field\n    // to NULL, so we explicitly return null when content == null. A null\n    // variable in graphql mutation on KC server clears the field to NULL.\n    if (content == null) {\n      return null;\n    }\n\n    const jwk = asJwk(key) || (await this.getJwkKey(key as string | Key));\n    return this.encryptionService.encryptToString(jwk, content);\n  }\n\n  // Wraps a symmetric encryption key.\n  // Throws exception if wrapping public keys.\n  async wrapKey(\n    wrappingKey: string | Key | JWK.Key,\n    key: JWK.Key\n  ): Promise<string> {\n    if (!isSymmetricKey(key)) {\n      throw new KcBadArgumentException(\n        'Only allowing wrapping of symmetric keys.'\n      );\n    }\n\n    return this.encryptToString(wrappingKey, key.toJSON(true));\n  }\n\n  // TODO\n  // async wrapPublicKey<T>();\n  // async wrapPrivateKey<T>();\n\n  async encryptWithNewKey(wrappingKeyId: string, cipherClearJson: JSONObject) {\n    const key = await this.keyFactory.createKey();\n    const wrappedKey = await this.encryptToString(\n      wrappingKeyId,\n      key.toJSON(true)\n    );\n    const cipher = await this.encryptToString(key, cipherClearJson);\n\n    return {\n      key,\n      wrappingKeyId,\n      wrappedKey,\n      cipher,\n    };\n  }\n}\n"]}
@@ -42,6 +42,74 @@ export const UnshareFileMutation = gqlTyped `
42
42
  }
43
43
  }
44
44
  `;
45
+ export const CreateSharedDirectoryMutation = gqlTyped `
46
+ mutation CreateSharedDirectoryMutation($input: CreateSharedDirectoryInput!) {
47
+ createSharedDirectory(input: $input) {
48
+ tpSharedDirectory {
49
+ id
50
+ }
51
+ }
52
+ }
53
+ `;
54
+ export const CreateSharedFileMutation = gqlTyped `
55
+ mutation CreateSharedFileMutation($input: CreateSharedFileInput!) {
56
+ createSharedFile(input: $input) {
57
+ tpSharedFile {
58
+ id
59
+ }
60
+ }
61
+ }
62
+ `;
63
+ export const UpdateSharedDirectoryMutation = gqlTyped `
64
+ mutation UpdateSharedDirectoryMutation($input: UpdateSharedDirectoryInput!) {
65
+ updateSharedDirectory(input: $input) {
66
+ tpSharedDirectory {
67
+ id
68
+ }
69
+ }
70
+ }
71
+ `;
72
+ export const UpdateSharedFileMutation = gqlTyped `
73
+ mutation UpdateSharedFileMutation($input: UpdateSharedFileInput!) {
74
+ updateSharedFile(input: $input) {
75
+ tpSharedFile {
76
+ id
77
+ }
78
+ }
79
+ }
80
+ `;
81
+ export const DeleteSharedDirectoryMutation = gqlTyped `
82
+ mutation DeleteSharedDirectoryMutation($input: DeleteSharedDirectoryInput!) {
83
+ deleteSharedDirectory(input: $input) {
84
+ id
85
+ }
86
+ }
87
+ `;
88
+ export const DeleteSharedFileMutation = gqlTyped `
89
+ mutation DeleteSharedFileMutation($input: DeleteSharedFileInput!) {
90
+ deleteSharedFile(input: $input) {
91
+ id
92
+ }
93
+ }
94
+ `;
95
+ export const CompleteDetachedSharedDirectoryMutation = gqlTyped `
96
+ mutation CompleteDetachedSharedDirectoryMutation($input: CompleteDetachedSharedDirectoryInput!) {
97
+ completeDetachedSharedDirectory(input: $input) {
98
+ tpSharedDirectory {
99
+ id
100
+ }
101
+ }
102
+ }
103
+ `;
104
+ export const CompleteDetachedSharedFileMutation = gqlTyped `
105
+ mutation CompleteDetachedSharedFileMutation($input: CompleteDetachedSharedFileInput!) {
106
+ completeDetachedSharedFile(input: $input) {
107
+ tpSharedFile {
108
+ id
109
+ }
110
+ }
111
+ }
112
+ `;
45
113
  export const RequestTpMkReshareMutation = gqlTyped `
46
114
  mutation RequestTpMkReshareMutation($input: RequestTpMkReshareInput!) {
47
115
  requestTpMkReshare(input: $input) {
@@ -61,4 +129,4 @@ mutation CompleteTpMkReshareMutation($input: CompleteTpMkReshareInput!) {
61
129
  id
62
130
  }
63
131
  }`;
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1c3RlZC1wYXJ0eS5ncWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3NyYy9saWIvdHJ1c3RlZC1wYXJ0eS90cnVzdGVkLXBhcnR5LmdxbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFPMUMsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsUUFBUSxDQUFrQjs7Ozs7O0NBTXpELENBQUM7QUFTRixNQUFNLENBQUMsTUFBTSxzQkFBc0IsR0FBRyxRQUFRLENBQXdCOzs7Ozs7OztDQVFyRSxDQUFDO0FBU0YsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQUcsUUFBUSxDQUEwQjs7Ozs7Ozs7Q0FRekUsQ0FBQztBQVNGLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLFFBQVEsQ0FBbUI7Ozs7Ozs7O0NBUTNELENBQUM7QUFTRixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxRQUFRLENBQXFCOzs7Ozs7OztDQVEvRCxDQUFDO0FBT0YsTUFBTSxDQUFDLE1BQU0sMEJBQTBCLEdBQUcsUUFBUSxDQUE0Qjs7Ozs7RUFLNUUsQ0FBQztBQU9ILE1BQU0sQ0FBQyxNQUFNLDBCQUEwQixHQUFHLFFBQVEsQ0FBNEI7Ozs7OztDQU03RSxDQUFDO0FBT0YsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQUcsUUFBUSxDQUE2Qjs7Ozs7RUFLOUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElEIH0gZnJvbSAnLi4vYXBpL3R5cGVzJztcbmltcG9ydCB7IGdxbFR5cGVkIH0gZnJvbSAnLi4vX2NvbW1vbi9hc3QnO1xuXG5leHBvcnQgaW50ZXJmYWNlIERlbGV0ZVRwTXV0YXRpb24ge1xuICBkZWxldGVUcDoge1xuICAgIGlkOiBJRDtcbiAgfTtcbn1cbmV4cG9ydCBjb25zdCBEZWxldGVUcE11dGF0aW9uID0gZ3FsVHlwZWQ8RGVsZXRlVHBNdXRhdGlvbj5gXG5tdXRhdGlvbiBEZWxldGVUcE11dGF0aW9uKCRpbnB1dDogRGVsZXRlVHBJbnB1dCEpIHtcbiAgZGVsZXRlVHAoaW5wdXQ6ICRpbnB1dCkge1xuICAgIGlkXG4gIH1cbn1cbmA7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2hhcmVEaXJlY3RvcnlNdXRhdGlvbiB7XG4gIHNoYXJlRGlyZWN0b3J5OiB7XG4gICAgdHBTaGFyZWREaXJlY3Rvcnk6IHtcbiAgICAgIGlkOiBJRDtcbiAgICB9O1xuICB9O1xufVxuZXhwb3J0IGNvbnN0IFNoYXJlRGlyZWN0b3J5TXV0YXRpb24gPSBncWxUeXBlZDxTaGFyZURpcmVjdG9yeU11dGF0aW9uPmBcbiAgbXV0YXRpb24gU2hhcmVEaXJlY3RvcnlNdXRhdGlvbigkaW5wdXQ6IFNoYXJlRGlyZWN0b3J5SW5wdXQhKSB7XG4gICAgc2hhcmVEaXJlY3RvcnkoaW5wdXQ6ICRpbnB1dCkge1xuICAgICAgdHBTaGFyZWREaXJlY3Rvcnkge1xuICAgICAgICBpZFxuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGludGVyZmFjZSBVbnNoYXJlRGlyZWN0b3J5TXV0YXRpb24ge1xuICB1bnNoYXJlRGlyZWN0b3J5OiB7XG4gICAgdHBTaGFyZWREaXJlY3Rvcnk6IHtcbiAgICAgIGlkOiBJRDtcbiAgICB9O1xuICB9O1xufVxuZXhwb3J0IGNvbnN0IFVuc2hhcmVEaXJlY3RvcnlNdXRhdGlvbiA9IGdxbFR5cGVkPFVuc2hhcmVEaXJlY3RvcnlNdXRhdGlvbj5gXG4gIG11dGF0aW9uIFVuc2hhcmVEaXJlY3RvcnlNdXRhdGlvbigkaW5wdXQ6IFVuc2hhcmVEaXJlY3RvcnlJbnB1dCEpIHtcbiAgICB1bnNoYXJlRGlyZWN0b3J5KGlucHV0OiAkaW5wdXQpIHtcbiAgICAgIHRwU2hhcmVkRGlyZWN0b3J5IHtcbiAgICAgICAgaWRcbiAgICAgIH1cbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2hhcmVGaWxlTXV0YXRpb24ge1xuICBzaGFyZUZpbGU6IHtcbiAgICB0cFNoYXJlZEZpbGU6IHtcbiAgICAgIGlkOiBJRDtcbiAgICB9O1xuICB9O1xufVxuZXhwb3J0IGNvbnN0IFNoYXJlRmlsZU11dGF0aW9uID0gZ3FsVHlwZWQ8U2hhcmVGaWxlTXV0YXRpb24+YFxuICBtdXRhdGlvbiBTaGFyZUZpbGVNdXRhdGlvbigkaW5wdXQ6IFNoYXJlRmlsZUlucHV0ISkge1xuICAgIHNoYXJlRmlsZShpbnB1dDogJGlucHV0KSB7XG4gICAgICB0cFNoYXJlZEZpbGUge1xuICAgICAgICBpZFxuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGludGVyZmFjZSBVbnNoYXJlRmlsZU11dGF0aW9uIHtcbiAgdW5zaGFyZUZpbGU6IHtcbiAgICB0cFNoYXJlZEZpbGU6IHtcbiAgICAgIGlkOiBJRDtcbiAgICB9O1xuICB9O1xufVxuZXhwb3J0IGNvbnN0IFVuc2hhcmVGaWxlTXV0YXRpb24gPSBncWxUeXBlZDxVbnNoYXJlRmlsZU11dGF0aW9uPmBcbiAgbXV0YXRpb24gVW5zaGFyZUZpbGVNdXRhdGlvbigkaW5wdXQ6IFVuc2hhcmVGaWxlSW5wdXQhKSB7XG4gICAgdW5zaGFyZUZpbGUoaW5wdXQ6ICRpbnB1dCkge1xuICAgICAgdHBTaGFyZWRGaWxlIHtcbiAgICAgICAgaWRcbiAgICAgIH1cbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVxdWVzdFRwTWtSZXNoYXJlTXV0YXRpb24ge1xuICByZXF1ZXN0VHBNa1Jlc2hhcmU6IHtcbiAgICBpZDogSUQ7XG4gIH07XG59XG5leHBvcnQgY29uc3QgUmVxdWVzdFRwTWtSZXNoYXJlTXV0YXRpb24gPSBncWxUeXBlZDxSZXF1ZXN0VHBNa1Jlc2hhcmVNdXRhdGlvbj5gXG5tdXRhdGlvbiBSZXF1ZXN0VHBNa1Jlc2hhcmVNdXRhdGlvbigkaW5wdXQ6IFJlcXVlc3RUcE1rUmVzaGFyZUlucHV0ISkge1xuICByZXF1ZXN0VHBNa1Jlc2hhcmUoaW5wdXQ6ICRpbnB1dCkge1xuICAgIGlkXG4gIH1cbn1gO1xuXG5leHBvcnQgaW50ZXJmYWNlIFJlc3BvbmRUcE1rUmVzaGFyZU11dGF0aW9uIHtcbiAgcmVzcG9uZFRwTWtSZXNoYXJlOiB7XG4gICAgaWQ6IElEO1xuICB9O1xufVxuZXhwb3J0IGNvbnN0IFJlc3BvbmRUcE1rUmVzaGFyZU11dGF0aW9uID0gZ3FsVHlwZWQ8UmVzcG9uZFRwTWtSZXNoYXJlTXV0YXRpb24+YFxuICBtdXRhdGlvbiBSZXNwb25kVHBNa1Jlc2hhcmVNdXRhdGlvbigkaW5wdXQ6IFJlc3BvbmRUcE1rUmVzaGFyZUlucHV0ISkge1xuICAgIHJlc3BvbmRUcE1rUmVzaGFyZShpbnB1dDogJGlucHV0KSB7XG4gICAgICBpZFxuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGludGVyZmFjZSBDb21wbGV0ZVRwTWtSZXNoYXJlTXV0YXRpb24ge1xuICBjb21wbGV0ZVRwTWtSZXNoYXJlOiB7XG4gICAgaWQ6IElEO1xuICB9O1xufVxuZXhwb3J0IGNvbnN0IENvbXBsZXRlVHBNa1Jlc2hhcmVNdXRhdGlvbiA9IGdxbFR5cGVkPENvbXBsZXRlVHBNa1Jlc2hhcmVNdXRhdGlvbj5gXG5tdXRhdGlvbiBDb21wbGV0ZVRwTWtSZXNoYXJlTXV0YXRpb24oJGlucHV0OiBDb21wbGV0ZVRwTWtSZXNoYXJlSW5wdXQhKSB7XG4gIGNvbXBsZXRlVHBNa1Jlc2hhcmUoaW5wdXQ6ICRpbnB1dCkge1xuICAgIGlkXG4gIH1cbn1gO1xuIl19
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trusted-party.gql.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/trusted-party/trusted-party.gql.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAO1C,MAAM,CAAC,MAAM,gBAAgB,GAAG,QAAQ,CAAkB;;;;;;CAMzD,CAAC;AASF,MAAM,CAAC,MAAM,sBAAsB,GAAG,QAAQ,CAAwB;;;;;;;;CAQrE,CAAC;AASF,MAAM,CAAC,MAAM,wBAAwB,GAAG,QAAQ,CAA0B;;;;;;;;CAQzE,CAAC;AASF,MAAM,CAAC,MAAM,iBAAiB,GAAG,QAAQ,CAAmB;;;;;;;;CAQ3D,CAAC;AASF,MAAM,CAAC,MAAM,mBAAmB,GAAG,QAAQ,CAAqB;;;;;;;;CAQ/D,CAAC;AASF,MAAM,CAAC,MAAM,6BAA6B,GAAG,QAAQ,CAAqC;;;;;;;;CAQzF,CAAC;AASF,MAAM,CAAC,MAAM,wBAAwB,GAAG,QAAQ,CAAgC;;;;;;;;CAQ/E,CAAC;AASF,MAAM,CAAC,MAAM,6BAA6B,GAAG,QAAQ,CAAqC;;;;;;;;CAQzF,CAAC;AASF,MAAM,CAAC,MAAM,wBAAwB,GAAG,QAAQ,CAAgC;;;;;;;;CAQ/E,CAAC;AAOF,MAAM,CAAC,MAAM,6BAA6B,GAAG,QAAQ,CAAqC;;;;;;CAMzF,CAAC;AAOF,MAAM,CAAC,MAAM,wBAAwB,GAAG,QAAQ,CAAgC;;;;;;CAM/E,CAAC;AASF,MAAM,CAAC,MAAM,uCAAuC,GAAG,QAAQ,CAA+C;;;;;;;;CAQ7G,CAAC;AASF,MAAM,CAAC,MAAM,kCAAkC,GAAG,QAAQ,CAA0C;;;;;;;;CAQnG,CAAC;AAOF,MAAM,CAAC,MAAM,0BAA0B,GAAG,QAAQ,CAA4B;;;;;EAK5E,CAAC;AAOH,MAAM,CAAC,MAAM,0BAA0B,GAAG,QAAQ,CAA4B;;;;;;CAM7E,CAAC;AAOF,MAAM,CAAC,MAAM,2BAA2B,GAAG,QAAQ,CAA6B;;;;;EAK9E,CAAC","sourcesContent":["import { ID } from '../api/types';\nimport { gqlTyped } from '../_common/ast';\n\nexport interface DeleteTpMutation {\n  deleteTp: {\n    id: ID;\n  };\n}\nexport const DeleteTpMutation = gqlTyped<DeleteTpMutation>`\nmutation DeleteTpMutation($input: DeleteTpInput!) {\n  deleteTp(input: $input) {\n    id\n  }\n}\n`;\n\nexport interface ShareDirectoryMutation {\n  shareDirectory: {\n    tpSharedDirectory: {\n      id: ID;\n    };\n  };\n}\nexport const ShareDirectoryMutation = gqlTyped<ShareDirectoryMutation>`\n  mutation ShareDirectoryMutation($input: ShareDirectoryInput!) {\n    shareDirectory(input: $input) {\n      tpSharedDirectory {\n        id\n      }\n    }\n  }\n`;\n\nexport interface UnshareDirectoryMutation {\n  unshareDirectory: {\n    tpSharedDirectory: {\n      id: ID;\n    };\n  };\n}\nexport const UnshareDirectoryMutation = gqlTyped<UnshareDirectoryMutation>`\n  mutation UnshareDirectoryMutation($input: UnshareDirectoryInput!) {\n    unshareDirectory(input: $input) {\n      tpSharedDirectory {\n        id\n      }\n    }\n  }\n`;\n\nexport interface ShareFileMutation {\n  shareFile: {\n    tpSharedFile: {\n      id: ID;\n    };\n  };\n}\nexport const ShareFileMutation = gqlTyped<ShareFileMutation>`\n  mutation ShareFileMutation($input: ShareFileInput!) {\n    shareFile(input: $input) {\n      tpSharedFile {\n        id\n      }\n    }\n  }\n`;\n\nexport interface UnshareFileMutation {\n  unshareFile: {\n    tpSharedFile: {\n      id: ID;\n    };\n  };\n}\nexport const UnshareFileMutation = gqlTyped<UnshareFileMutation>`\n  mutation UnshareFileMutation($input: UnshareFileInput!) {\n    unshareFile(input: $input) {\n      tpSharedFile {\n        id\n      }\n    }\n  }\n`;\n\nexport interface CreateSharedDirectoryMutationResult {\n  createSharedDirectory: {\n    tpSharedDirectory: {\n      id: ID;\n    };\n  };\n}\nexport const CreateSharedDirectoryMutation = gqlTyped<CreateSharedDirectoryMutationResult>`\nmutation CreateSharedDirectoryMutation($input: CreateSharedDirectoryInput!) {\n  createSharedDirectory(input: $input) {\n    tpSharedDirectory {\n      id\n    }\n  }\n}\n`;\n\nexport interface CreateSharedFileMutationResult {\n  createSharedFile: {\n    tpSharedFile: {\n      id: ID;\n    };\n  };\n}\nexport const CreateSharedFileMutation = gqlTyped<CreateSharedFileMutationResult>`\nmutation CreateSharedFileMutation($input: CreateSharedFileInput!) {\n  createSharedFile(input: $input) {\n    tpSharedFile {\n      id\n    }\n  }\n}\n`;\n\nexport interface UpdateSharedDirectoryMutationResult {\n  updateSharedDirectory: {\n    tpSharedDirectory: {\n      id: ID;\n    };\n  };\n}\nexport const UpdateSharedDirectoryMutation = gqlTyped<UpdateSharedDirectoryMutationResult>`\nmutation UpdateSharedDirectoryMutation($input: UpdateSharedDirectoryInput!) {\n  updateSharedDirectory(input: $input) {\n    tpSharedDirectory {\n      id\n    }\n  }\n}\n`;\n\nexport interface UpdateSharedFileMutationResult {\n  updateSharedFile: {\n    tpSharedFile: {\n      id: ID;\n    };\n  };\n}\nexport const UpdateSharedFileMutation = gqlTyped<UpdateSharedFileMutationResult>`\nmutation UpdateSharedFileMutation($input: UpdateSharedFileInput!) {\n  updateSharedFile(input: $input) {\n    tpSharedFile {\n      id\n    }\n  }\n}\n`;\n\nexport interface DeleteSharedDirectoryMutationResult {\n  deleteSharedDirectory: {\n    id: ID;\n  };\n}\nexport const DeleteSharedDirectoryMutation = gqlTyped<DeleteSharedDirectoryMutationResult>`\nmutation DeleteSharedDirectoryMutation($input: DeleteSharedDirectoryInput!) {\n  deleteSharedDirectory(input: $input) {\n    id\n  }\n}\n`;\n\nexport interface DeleteSharedFileMutationResult {\n  deleteSharedFile: {\n    id: ID;\n  };\n}\nexport const DeleteSharedFileMutation = gqlTyped<DeleteSharedFileMutationResult>`\nmutation DeleteSharedFileMutation($input: DeleteSharedFileInput!) {\n  deleteSharedFile(input: $input) {\n    id\n  }\n}\n`;\n\nexport interface CompleteDetachedSharedDirectoryMutationResult {\n  completeDetachedSharedDirectory: {\n    tpSharedDirectory: {\n      id: ID;\n    };\n  };\n}\nexport const CompleteDetachedSharedDirectoryMutation = gqlTyped<CompleteDetachedSharedDirectoryMutationResult>`\nmutation CompleteDetachedSharedDirectoryMutation($input: CompleteDetachedSharedDirectoryInput!) {\n  completeDetachedSharedDirectory(input: $input) {\n    tpSharedDirectory {\n      id\n    }\n  }\n}\n`;\n\nexport interface CompleteDetachedSharedFileMutationResult {\n  completeDetachedSharedDirectory: {\n    tpSharedDirectory: {\n      id: ID;\n    };\n  };\n}\nexport const CompleteDetachedSharedFileMutation = gqlTyped<CompleteDetachedSharedFileMutationResult>`\nmutation CompleteDetachedSharedFileMutation($input: CompleteDetachedSharedFileInput!) {\n  completeDetachedSharedFile(input: $input) {\n    tpSharedFile {\n      id\n    }\n  }\n}\n`;\n\nexport interface RequestTpMkReshareMutation {\n  requestTpMkReshare: {\n    id: ID;\n  };\n}\nexport const RequestTpMkReshareMutation = gqlTyped<RequestTpMkReshareMutation>`\nmutation RequestTpMkReshareMutation($input: RequestTpMkReshareInput!) {\n  requestTpMkReshare(input: $input) {\n    id\n  }\n}`;\n\nexport interface RespondTpMkReshareMutation {\n  respondTpMkReshare: {\n    id: ID;\n  };\n}\nexport const RespondTpMkReshareMutation = gqlTyped<RespondTpMkReshareMutation>`\n  mutation RespondTpMkReshareMutation($input: RespondTpMkReshareInput!) {\n    respondTpMkReshare(input: $input) {\n      id\n    }\n  }\n`;\n\nexport interface CompleteTpMkReshareMutation {\n  completeTpMkReshare: {\n    id: ID;\n  };\n}\nexport const CompleteTpMkReshareMutation = gqlTyped<CompleteTpMkReshareMutation>`\nmutation CompleteTpMkReshareMutation($input: CompleteTpMkReshareInput!) {\n  completeTpMkReshare(input: $input) {\n    id\n  }\n}`;\n"]}
@@ -9,7 +9,7 @@ import { KeyGraphService } from '../key/key-graph.service';
9
9
  import { KeyService } from '../key/key.service';
10
10
  import { KcBadStateException } from '../_common/exceptions';
11
11
  import { RunOutsideAngular } from '../_common/run-outside-angular';
12
- import { CompleteTpMkReshareMutation, DeleteTpMutation, RequestTpMkReshareMutation, RespondTpMkReshareMutation, ShareDirectoryMutation, ShareFileMutation, UnshareDirectoryMutation, UnshareFileMutation, } from './trusted-party.gql';
12
+ import { CompleteDetachedSharedDirectoryMutation, CompleteDetachedSharedFileMutation, CompleteTpMkReshareMutation, CreateSharedDirectoryMutation, CreateSharedFileMutation, DeleteSharedDirectoryMutation, DeleteTpMutation, RequestTpMkReshareMutation, RespondTpMkReshareMutation, ShareDirectoryMutation, ShareFileMutation, UnshareDirectoryMutation, UnshareFileMutation, UpdateSharedDirectoryMutation, UpdateSharedFileMutation, } from './trusted-party.gql';
13
13
  import { TpCurrentUserSharedKeyQuery } from './trusted-party.gql.private';
14
14
  import * as i0 from "@angular/core";
15
15
  import * as i1 from "../key/key-graph.service";
@@ -48,7 +48,10 @@ let TrustedPartyService = class TrustedPartyService extends LrService {
48
48
  }
49
49
  shareDirectoryMutation(options) {
50
50
  return __awaiter(this, void 0, void 0, function* () {
51
- return this.shareItemMutation(Object.assign(Object.assign({}, options), { isDirectory: true }));
51
+ return new LrMutation({
52
+ mutation: ShareDirectoryMutation,
53
+ variables: yield this.prepareShareItemMutation(Object.assign(Object.assign({}, options), { isDirectory: true })),
54
+ });
52
55
  });
53
56
  }
54
57
  shareFile(options) {
@@ -58,29 +61,30 @@ let TrustedPartyService = class TrustedPartyService extends LrService {
58
61
  }
59
62
  shareFileMutation(options) {
60
63
  return __awaiter(this, void 0, void 0, function* () {
61
- return this.shareItemMutation(Object.assign(Object.assign({}, options), { isDirectory: false }));
64
+ return new LrMutation({
65
+ mutation: ShareFileMutation,
66
+ variables: yield this.prepareShareItemMutation(Object.assign(Object.assign({}, options), { isDirectory: false })),
67
+ });
62
68
  });
63
69
  }
64
- shareItemMutation({ itemId, itemKeyId, tpId, tpSharedKeyId, accessRole, isDirectory, }) {
70
+ prepareShareItemMutation(options) {
65
71
  return __awaiter(this, void 0, void 0, function* () {
72
+ const { itemId, itemKeyId, tpId, tpSharedKeyId, accessRole, isDirectory } = options;
66
73
  const itemKey = yield this.keyGraph.getKey(itemKeyId, () => isDirectory
67
74
  ? this.itemService.getDirectoryKeyId(itemId)
68
75
  : this.itemService.getFileKeyId(itemId));
69
76
  const wrappingKey = yield this.keyGraph.getKey(tpSharedKeyId, () => this.getTpCurrentUserSharedKey(tpId).then((res) => res.sharedKey.id));
70
77
  const wrappedKey = yield this.keyGraph.wrapKey(wrappingKey, itemKey.jwk);
71
- return new LrMutation({
72
- mutation: isDirectory ? ShareDirectoryMutation : ShareFileMutation,
73
- variables: {
74
- input: {
75
- id: itemId,
76
- tpId,
77
- accessRole,
78
- keyId: itemKey.id,
79
- wrappingKeyId: wrappingKey.id,
80
- wrappedKey,
81
- },
78
+ return {
79
+ input: {
80
+ id: itemId,
81
+ tpId,
82
+ accessRole,
83
+ keyId: itemKey.id,
84
+ wrappingKeyId: wrappingKey.id,
85
+ wrappedKey,
82
86
  },
83
- });
87
+ };
84
88
  });
85
89
  }
86
90
  unshareDirectory(options) {
@@ -116,6 +120,151 @@ let TrustedPartyService = class TrustedPartyService extends LrService {
116
120
  });
117
121
  });
118
122
  }
123
+ createSharedDirectory(options) {
124
+ return __awaiter(this, void 0, void 0, function* () {
125
+ return this.mutate(this.createSharedDirectoryMutation(options));
126
+ });
127
+ }
128
+ createSharedDirectoryMutation(options) {
129
+ return __awaiter(this, void 0, void 0, function* () {
130
+ return new LrMutation({
131
+ mutation: CreateSharedDirectoryMutation,
132
+ variables: yield this.prepareCreateSharedItemMutation(Object.assign(Object.assign({}, options), { isDirectory: true })),
133
+ });
134
+ });
135
+ }
136
+ createSharedFile(options) {
137
+ return __awaiter(this, void 0, void 0, function* () {
138
+ return this.mutate(this.createSharedFileMutation(options));
139
+ });
140
+ }
141
+ createSharedFileMutation(options) {
142
+ return __awaiter(this, void 0, void 0, function* () {
143
+ return new LrMutation({
144
+ mutation: CreateSharedFileMutation,
145
+ variables: yield this.prepareCreateSharedItemMutation(Object.assign(Object.assign({}, options), { isDirectory: false })),
146
+ });
147
+ });
148
+ }
149
+ prepareCreateSharedItemMutation(options) {
150
+ return __awaiter(this, void 0, void 0, function* () {
151
+ const { itemId, itemKeyId, tpId, tpSharedKeyId, accessRole, isDirectory, shareType, } = options;
152
+ console.log('createSharedItemMutation()', itemKeyId);
153
+ const itemKey = yield this.keyGraph.getKey(itemKeyId, () => isDirectory
154
+ ? this.itemService.getDirectoryKeyId(itemId)
155
+ : this.itemService.getFileKeyId(itemId));
156
+ console.log('createSharedItemMutation()', itemKey.id);
157
+ const wrappingKey = yield this.keyGraph.getKey(tpSharedKeyId, () => this.getTpCurrentUserSharedKey(tpId).then((res) => res.sharedKey.id));
158
+ const wrappedKey = yield this.keyGraph.wrapKey(wrappingKey, itemKey.jwk);
159
+ return {
160
+ input: {
161
+ id: itemId,
162
+ tpId,
163
+ accessRole,
164
+ keyId: itemKey.id,
165
+ wrappingKeyId: wrappingKey.id,
166
+ wrappedKey,
167
+ shareType,
168
+ },
169
+ };
170
+ });
171
+ }
172
+ updateSharedDirectory(options) {
173
+ return __awaiter(this, void 0, void 0, function* () {
174
+ return this.mutate(this.updateSharedDirectoryMutation(options));
175
+ });
176
+ }
177
+ updateSharedDirectoryMutation(options) {
178
+ return __awaiter(this, void 0, void 0, function* () {
179
+ return new LrMutation({
180
+ mutation: UpdateSharedDirectoryMutation,
181
+ variables: this.prepareUpdateSharedItemMutation(options),
182
+ });
183
+ });
184
+ }
185
+ updateSharedFile(options) {
186
+ return __awaiter(this, void 0, void 0, function* () {
187
+ return this.mutate(this.updateSharedFileMutation(options));
188
+ });
189
+ }
190
+ updateSharedFileMutation(options) {
191
+ return __awaiter(this, void 0, void 0, function* () {
192
+ return new LrMutation({
193
+ mutation: UpdateSharedFileMutation,
194
+ variables: this.prepareUpdateSharedItemMutation(options),
195
+ });
196
+ });
197
+ }
198
+ prepareUpdateSharedItemMutation(options) {
199
+ const { sharedItemId, accessRole } = options;
200
+ return {
201
+ input: {
202
+ id: sharedItemId,
203
+ accessRole,
204
+ },
205
+ };
206
+ }
207
+ deleteSharedDirectory(id) {
208
+ return __awaiter(this, void 0, void 0, function* () {
209
+ return this.mutate(this.deleteSharedDirectoryMutation(id));
210
+ });
211
+ }
212
+ deleteSharedDirectoryMutation(id) {
213
+ return __awaiter(this, void 0, void 0, function* () {
214
+ return new LrMutation({
215
+ mutation: DeleteSharedDirectoryMutation,
216
+ variables: {
217
+ input: {
218
+ id,
219
+ },
220
+ },
221
+ });
222
+ });
223
+ }
224
+ completeDetachedSharedDirectory(options) {
225
+ return __awaiter(this, void 0, void 0, function* () {
226
+ return this.mutate(this.completeDetachedSharedDirectoryMutation(options));
227
+ });
228
+ }
229
+ completeDetachedSharedDirectoryMutation(options) {
230
+ return __awaiter(this, void 0, void 0, function* () {
231
+ return new LrMutation({
232
+ mutation: CompleteDetachedSharedDirectoryMutation,
233
+ variables: yield this.prepareCompleteDetachedSharedItemMutation(Object.assign(Object.assign({}, options), { isDirectory: true })),
234
+ });
235
+ });
236
+ }
237
+ completeDetachedSharedFile(options) {
238
+ return __awaiter(this, void 0, void 0, function* () {
239
+ return this.mutate(this.completeDetachedSharedFileMutation(options));
240
+ });
241
+ }
242
+ completeDetachedSharedFileMutation(options) {
243
+ return __awaiter(this, void 0, void 0, function* () {
244
+ return new LrMutation({
245
+ mutation: CompleteDetachedSharedFileMutation,
246
+ variables: yield this.prepareCompleteDetachedSharedItemMutation(Object.assign(Object.assign({}, options), { isDirectory: false })),
247
+ });
248
+ });
249
+ }
250
+ prepareCompleteDetachedSharedItemMutation(options) {
251
+ return __awaiter(this, void 0, void 0, function* () {
252
+ const { sharedItemId, itemKeyId, isDirectory } = options;
253
+ const itemKey = yield this.keyGraph.getKey(itemKeyId, () => isDirectory
254
+ ? this.itemService.getDirectoryKeyIdFromSharedDirectory(sharedItemId)
255
+ : this.itemService.getFileKeyIdFromSharedFile(sharedItemId));
256
+ const rootKey = this.keyService.currentRootKey;
257
+ const wrappedKey = yield this.keyGraph.wrapKey(rootKey, itemKey.jwk);
258
+ return {
259
+ input: {
260
+ id: sharedItemId,
261
+ keyId: itemKey.id,
262
+ wrappingKeyId: rootKey.id,
263
+ wrappedKey,
264
+ },
265
+ };
266
+ });
267
+ }
119
268
  requestMkReshareMutation(tpId) {
120
269
  return __awaiter(this, void 0, void 0, function* () {
121
270
  const userSharedKey = yield this.getTpCurrentUserSharedKey(tpId);
@@ -237,4 +386,4 @@ TrustedPartyService = __decorate([
237
386
  })
238
387
  ], TrustedPartyService);
239
388
  export { TrustedPartyService };
240
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trusted-party.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/trusted-party/trusted-party.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector, NgZone } from '@angular/core';\nimport { JWK } from 'node-jose';\nimport { LrMutation, LrService } from '../api/lr-graphql';\nimport { LrRelayIdInput } from '../api/types';\nimport { EncryptionService } from '../encryption/encryption.service';\nimport { ItemService } from '../item/item.service';\nimport { KeyFactoryService } from '../key/key-factory.service';\nimport { KeyGraphService } from '../key/key-graph.service';\nimport { KeyService } from '../key/key.service';\nimport { Key } from '../key/key.types';\nimport { KcBadStateException } from '../_common/exceptions';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport {\n  CompleteTpMkReshareMutation,\n  DeleteTpMutation,\n  RequestTpMkReshareMutation,\n  RespondTpMkReshareMutation,\n  ShareDirectoryMutation,\n  ShareFileMutation,\n  UnshareDirectoryMutation,\n  UnshareFileMutation,\n} from './trusted-party.gql';\nimport { TpCurrentUserSharedKeyQuery } from './trusted-party.gql.private';\nimport { ShareItemOptions, UnshareItemOptions } from './trusted-party.types';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TrustedPartyService extends LrService {\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    private keyGraph: KeyGraphService,\n    private itemService: ItemService,\n    private keyService: KeyService,\n    private keyFactory: KeyFactoryService,\n    private encryptionService: EncryptionService\n  ) {\n    super(injector);\n  }\n\n  deleteTp(tpId: LrRelayIdInput) {\n    return this.mutate(this.deleteTpMutation(tpId));\n  }\n\n  deleteTpMutation(tpId: LrRelayIdInput) {\n    return new LrMutation({\n      mutation: DeleteTpMutation,\n      variables: {\n        input: {\n          id: tpId,\n        },\n      },\n    });\n  }\n\n  async shareDirectory(options: ShareItemOptions) {\n    return this.mutate(this.shareDirectoryMutation(options));\n  }\n\n  async shareDirectoryMutation(options: ShareItemOptions) {\n    return this.shareItemMutation({ ...options, isDirectory: true });\n  }\n\n  async shareFile(options: ShareItemOptions) {\n    return this.mutate(this.shareFileMutation(options));\n  }\n\n  async shareFileMutation(options: ShareItemOptions) {\n    return this.shareItemMutation({ ...options, isDirectory: false });\n  }\n\n  private async shareItemMutation({\n    itemId,\n    itemKeyId,\n    tpId,\n    tpSharedKeyId,\n    accessRole,\n    isDirectory,\n  }: ShareItemOptions & {\n    isDirectory: boolean;\n  }) {\n    const itemKey = await this.keyGraph.getKey(itemKeyId, () =>\n      isDirectory\n        ? this.itemService.getDirectoryKeyId(itemId)\n        : this.itemService.getFileKeyId(itemId)\n    );\n    const wrappingKey = await this.keyGraph.getKey(tpSharedKeyId, () =>\n      this.getTpCurrentUserSharedKey(tpId).then((res) => res.sharedKey.id)\n    );\n    const wrappedKey = await this.keyGraph.wrapKey(wrappingKey, itemKey.jwk);\n\n    return new LrMutation({\n      mutation: isDirectory ? ShareDirectoryMutation : ShareFileMutation,\n      variables: {\n        input: {\n          id: itemId,\n          tpId,\n          accessRole,\n          keyId: itemKey.id,\n          wrappingKeyId: wrappingKey.id,\n          wrappedKey,\n        },\n      },\n    });\n  }\n\n  async unshareDirectory(options: UnshareItemOptions) {\n    return this.mutate(this.unshareDirectoryMutation(options));\n  }\n\n  async unshareDirectoryMutation(options: UnshareItemOptions) {\n    return this.unshareItemMutation({ ...options, isDirectory: true });\n  }\n\n  async unshareFile(options: UnshareItemOptions) {\n    return this.mutate(this.unshareFileMutation(options));\n  }\n\n  async unshareFileMutation(options: UnshareItemOptions) {\n    return this.unshareItemMutation({ ...options, isDirectory: false });\n  }\n\n  private async unshareItemMutation({\n    itemId,\n    tpId,\n    isDirectory,\n  }: UnshareItemOptions & { isDirectory: boolean }) {\n    return new LrMutation({\n      mutation: isDirectory ? UnshareDirectoryMutation : UnshareFileMutation,\n      variables: {\n        input: {\n          id: itemId,\n          tpId,\n        },\n      },\n    });\n  }\n\n  async requestMkReshareMutation(tpId: LrRelayIdInput) {\n    const userSharedKey = await this.getTpCurrentUserSharedKey(tpId);\n\n    if (userSharedKey.mkSharedKey) {\n      throw new KcBadStateException('TP already has mkSharedKey');\n    }\n\n    const masterKey = this.keyService.currentMasterKey;\n    const prk = await this.keyFactory.createPkcKey();\n    const mkWrappedMkPrk = await this.encryptionService.encryptToString(\n      masterKey.jwk,\n      prk.toJSON(true)\n    );\n\n    const sharedKey = await this.keyGraph.getKey(userSharedKey.sharedKey.id);\n    const mkReshareRequestCipher = await this.encryptionService.encryptToString(\n      sharedKey.jwk,\n      {\n        pbk: prk.toJSON(),\n      }\n    );\n\n    return await new LrMutation({\n      mutation: RequestTpMkReshareMutation,\n      variables: {\n        input: {\n          tpId,\n          masterKeyId: masterKey.id,\n          mkPbk: JSON.stringify(prk.toJSON()),\n          mkWrappedMkPrk,\n          sharedKeyId: sharedKey.id,\n          mkReshareRequestCipher,\n        },\n      },\n    });\n  }\n\n  async respondMkReshare(tpId: LrRelayIdInput) {\n    const userSharedKey = await this.getTpCurrentUserSharedKey(tpId);\n\n    if (!userSharedKey.mkSharedKey) {\n      throw new KcBadStateException(\n        'No access to the mkSharedKey so cannot reshare it with TP'\n      );\n    }\n\n    const sharedKey = await this.keyGraph.getKey(userSharedKey.sharedKey.id);\n    const plainMkReshareRequestCipher = await this.encryptionService.decrypt(\n      sharedKey,\n      userSharedKey.mkReshareRequestCipher\n    );\n    const pbk = await JWK.asKey(plainMkReshareRequestCipher.pbk);\n    const mkSharedKey = await this.keyGraph.getKey(\n      userSharedKey.mkSharedKey.id\n    );\n\n    const plainMkReshareResponseCipher = {\n      mkSharedKey: {\n        id: mkSharedKey.id,\n        jwk: mkSharedKey.jwk.toJSON(true),\n      },\n    };\n\n    // Wrap with sharedKey then again with Pbk\n    const mkReshareResponseCipher =\n      await this.encryptionService.encryptToString(\n        pbk,\n        await this.encryptionService.encryptToString(\n          sharedKey.jwk,\n          plainMkReshareResponseCipher\n        )\n      );\n\n    return new LrMutation({\n      mutation: RespondTpMkReshareMutation,\n      variables: {\n        input: {\n          tpId,\n          mkSharedKeyId: mkSharedKey.id,\n          mkReshareResponseCipher,\n        },\n      },\n    });\n  }\n\n  async completeMkReshare(tpId: LrRelayIdInput) {\n    const userSharedKey = await this.getTpCurrentUserSharedKey(tpId);\n\n    const sharedKey = await this.keyGraph.getKey(userSharedKey.sharedKey.id);\n    const prk = await this.keyGraph.getKey(userSharedKey.mkPxk.id);\n    const plainMkReshareResponseCipher = await this.encryptionService.decrypt(\n      sharedKey,\n      await this.encryptionService.decrypt(\n        prk,\n        userSharedKey.mkReshareResponseCipher\n      )\n    );\n\n    // Double check it's a valid key.\n    const mkSharedKey: Key = {\n      id: plainMkReshareResponseCipher.mkSharedKey.id,\n      jwk: await JWK.asKey(plainMkReshareResponseCipher.mkSharedKey.jwk),\n    };\n\n    const masterKey = this.keyService.currentMasterKey;\n    const mkWrappedMkSharedKey = await this.encryptionService.encryptToString(\n      masterKey.jwk,\n      mkSharedKey.jwk.toJSON(true)\n    );\n\n    return new LrMutation({\n      mutation: CompleteTpMkReshareMutation,\n      variables: {\n        input: {\n          tpId,\n          masterKeyId: masterKey.id,\n          mkSharedKeyId: mkSharedKey.id,\n          mkWrappedMkSharedKey,\n        },\n      },\n    });\n  }\n\n  // ------------------------------------------------------------------------------------\n  // ------------------------------------------------------------------------------------\n  // Helpers\n  // ------------------------------------------------------------------------------------\n  // ------------------------------------------------------------------------------------\n  private async getTpCurrentUserSharedKey(tpId: LrRelayIdInput) {\n    return (\n      await this.lrGraphQL.query({\n        query: TpCurrentUserSharedKeyQuery,\n        variables: {\n          id: tpId,\n        },\n      })\n    ).tp.currentUserSharedKey.userSharedKey;\n  }\n}\n"]}
389
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trusted-party.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/trusted-party/trusted-party.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector, NgZone } from '@angular/core';\nimport { JWK } from 'node-jose';\nimport { LrMutation, LrService } from '../api/lr-graphql';\nimport { LrRelayIdInput } from '../api/types';\nimport { EncryptionService } from '../encryption/encryption.service';\nimport { ItemService } from '../item/item.service';\nimport { KeyFactoryService } from '../key/key-factory.service';\nimport { KeyGraphService } from '../key/key-graph.service';\nimport { KeyService } from '../key/key.service';\nimport { Key } from '../key/key.types';\nimport { KcBadStateException } from '../_common/exceptions';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport {\n  CompleteDetachedSharedDirectoryMutation,\n  CompleteDetachedSharedFileMutation,\n  CompleteTpMkReshareMutation,\n  CreateSharedDirectoryMutation,\n  CreateSharedFileMutation,\n  DeleteSharedDirectoryMutation,\n  DeleteTpMutation,\n  RequestTpMkReshareMutation,\n  RespondTpMkReshareMutation,\n  ShareDirectoryMutation,\n  ShareFileMutation,\n  UnshareDirectoryMutation,\n  UnshareFileMutation,\n  UpdateSharedDirectoryMutation,\n  UpdateSharedFileMutation,\n} from './trusted-party.gql';\nimport { TpCurrentUserSharedKeyQuery } from './trusted-party.gql.private';\nimport {\n  CompleteDetachedSharedItemOptions,\n  CreateSharedItemOptions,\n  ShareItemOptions,\n  UnshareItemOptions,\n  UpdateSharedItemOptions,\n} from './trusted-party.types';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class TrustedPartyService extends LrService {\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    private keyGraph: KeyGraphService,\n    private itemService: ItemService,\n    private keyService: KeyService,\n    private keyFactory: KeyFactoryService,\n    private encryptionService: EncryptionService\n  ) {\n    super(injector);\n  }\n\n  deleteTp(tpId: LrRelayIdInput) {\n    return this.mutate(this.deleteTpMutation(tpId));\n  }\n\n  deleteTpMutation(tpId: LrRelayIdInput) {\n    return new LrMutation({\n      mutation: DeleteTpMutation,\n      variables: {\n        input: {\n          id: tpId,\n        },\n      },\n    });\n  }\n\n  async shareDirectory(options: ShareItemOptions) {\n    return this.mutate(this.shareDirectoryMutation(options));\n  }\n\n  async shareDirectoryMutation(options: ShareItemOptions) {\n    return new LrMutation({\n      mutation: ShareDirectoryMutation,\n      variables: await this.prepareShareItemMutation({\n        ...options,\n        isDirectory: true,\n      }),\n    });\n  }\n\n  async shareFile(options: ShareItemOptions) {\n    return this.mutate(this.shareFileMutation(options));\n  }\n\n  async shareFileMutation(options: ShareItemOptions) {\n    return new LrMutation({\n      mutation: ShareFileMutation,\n      variables: await this.prepareShareItemMutation({\n        ...options,\n        isDirectory: false,\n      }),\n    });\n  }\n\n  private async prepareShareItemMutation(\n    options: ShareItemOptions & {\n      isDirectory: boolean;\n    }\n  ) {\n    const { itemId, itemKeyId, tpId, tpSharedKeyId, accessRole, isDirectory } =\n      options;\n\n    const itemKey = await this.keyGraph.getKey(itemKeyId, () =>\n      isDirectory\n        ? this.itemService.getDirectoryKeyId(itemId)\n        : this.itemService.getFileKeyId(itemId)\n    );\n    const wrappingKey = await this.keyGraph.getKey(tpSharedKeyId, () =>\n      this.getTpCurrentUserSharedKey(tpId).then((res) => res.sharedKey.id)\n    );\n    const wrappedKey = await this.keyGraph.wrapKey(wrappingKey, itemKey.jwk);\n\n    return {\n      input: {\n        id: itemId,\n        tpId,\n        accessRole,\n        keyId: itemKey.id,\n        wrappingKeyId: wrappingKey.id,\n        wrappedKey,\n      },\n    };\n  }\n\n  async unshareDirectory(options: UnshareItemOptions) {\n    return this.mutate(this.unshareDirectoryMutation(options));\n  }\n\n  async unshareDirectoryMutation(options: UnshareItemOptions) {\n    return this.unshareItemMutation({ ...options, isDirectory: true });\n  }\n\n  async unshareFile(options: UnshareItemOptions) {\n    return this.mutate(this.unshareFileMutation(options));\n  }\n\n  async unshareFileMutation(options: UnshareItemOptions) {\n    return this.unshareItemMutation({ ...options, isDirectory: false });\n  }\n\n  private async unshareItemMutation({\n    itemId,\n    tpId,\n    isDirectory,\n  }: UnshareItemOptions & { isDirectory: boolean }) {\n    return new LrMutation({\n      mutation: isDirectory ? UnshareDirectoryMutation : UnshareFileMutation,\n      variables: {\n        input: {\n          id: itemId,\n          tpId,\n        },\n      },\n    });\n  }\n\n  async createSharedDirectory(options: CreateSharedItemOptions) {\n    return this.mutate(this.createSharedDirectoryMutation(options));\n  }\n\n  async createSharedDirectoryMutation(options: CreateSharedItemOptions) {\n    return new LrMutation({\n      mutation: CreateSharedDirectoryMutation,\n      variables: await this.prepareCreateSharedItemMutation({\n        ...options,\n        isDirectory: true,\n      }),\n    });\n  }\n\n  async createSharedFile(options: CreateSharedItemOptions) {\n    return this.mutate(this.createSharedFileMutation(options));\n  }\n\n  async createSharedFileMutation(options: CreateSharedItemOptions) {\n    return new LrMutation({\n      mutation: CreateSharedFileMutation,\n      variables: await this.prepareCreateSharedItemMutation({\n        ...options,\n        isDirectory: false,\n      }),\n    });\n  }\n\n  private async prepareCreateSharedItemMutation(\n    options: CreateSharedItemOptions & { isDirectory: boolean }\n  ) {\n    const {\n      itemId,\n      itemKeyId,\n      tpId,\n      tpSharedKeyId,\n      accessRole,\n      isDirectory,\n      shareType,\n    } = options;\n\n    console.log('createSharedItemMutation()', itemKeyId);\n    const itemKey = await this.keyGraph.getKey(itemKeyId, () =>\n      isDirectory\n        ? this.itemService.getDirectoryKeyId(itemId)\n        : this.itemService.getFileKeyId(itemId)\n    );\n    console.log('createSharedItemMutation()', itemKey.id);\n\n    const wrappingKey = await this.keyGraph.getKey(tpSharedKeyId, () =>\n      this.getTpCurrentUserSharedKey(tpId).then((res) => res.sharedKey.id)\n    );\n    const wrappedKey = await this.keyGraph.wrapKey(wrappingKey, itemKey.jwk);\n\n    return {\n      input: {\n        id: itemId,\n        tpId,\n        accessRole,\n        keyId: itemKey.id,\n        wrappingKeyId: wrappingKey.id,\n        wrappedKey,\n        shareType,\n      },\n    };\n  }\n\n  async updateSharedDirectory(options: UpdateSharedItemOptions) {\n    return this.mutate(this.updateSharedDirectoryMutation(options));\n  }\n\n  async updateSharedDirectoryMutation(options: UpdateSharedItemOptions) {\n    return new LrMutation({\n      mutation: UpdateSharedDirectoryMutation,\n      variables: this.prepareUpdateSharedItemMutation(options),\n    });\n  }\n\n  async updateSharedFile(options: UpdateSharedItemOptions) {\n    return this.mutate(this.updateSharedFileMutation(options));\n  }\n\n  async updateSharedFileMutation(options: UpdateSharedItemOptions) {\n    return new LrMutation({\n      mutation: UpdateSharedFileMutation,\n      variables: this.prepareUpdateSharedItemMutation(options),\n    });\n  }\n\n  private prepareUpdateSharedItemMutation(options: UpdateSharedItemOptions) {\n    const { sharedItemId, accessRole } = options;\n\n    return {\n      input: {\n        id: sharedItemId,\n        accessRole,\n      },\n    };\n  }\n\n  async deleteSharedDirectory(id: string) {\n    return this.mutate(this.deleteSharedDirectoryMutation(id));\n  }\n\n  async deleteSharedDirectoryMutation(id: string) {\n    return new LrMutation({\n      mutation: DeleteSharedDirectoryMutation,\n      variables: {\n        input: {\n          id,\n        },\n      },\n    });\n  }\n\n  async completeDetachedSharedDirectory(\n    options: CompleteDetachedSharedItemOptions\n  ) {\n    return this.mutate(this.completeDetachedSharedDirectoryMutation(options));\n  }\n\n  async completeDetachedSharedDirectoryMutation(\n    options: CompleteDetachedSharedItemOptions\n  ) {\n    return new LrMutation({\n      mutation: CompleteDetachedSharedDirectoryMutation,\n      variables: await this.prepareCompleteDetachedSharedItemMutation({\n        ...options,\n        isDirectory: true,\n      }),\n    });\n  }\n\n  async completeDetachedSharedFile(options: CompleteDetachedSharedItemOptions) {\n    return this.mutate(this.completeDetachedSharedFileMutation(options));\n  }\n\n  async completeDetachedSharedFileMutation(\n    options: CompleteDetachedSharedItemOptions\n  ) {\n    return new LrMutation({\n      mutation: CompleteDetachedSharedFileMutation,\n      variables: await this.prepareCompleteDetachedSharedItemMutation({\n        ...options,\n        isDirectory: false,\n      }),\n    });\n  }\n\n  private async prepareCompleteDetachedSharedItemMutation(\n    options: CompleteDetachedSharedItemOptions & { isDirectory: boolean }\n  ) {\n    const { sharedItemId, itemKeyId, isDirectory } = options;\n\n    const itemKey = await this.keyGraph.getKey(itemKeyId, () =>\n      isDirectory\n        ? this.itemService.getDirectoryKeyIdFromSharedDirectory(sharedItemId)\n        : this.itemService.getFileKeyIdFromSharedFile(sharedItemId)\n    );\n\n    const rootKey = this.keyService.currentRootKey;\n\n    const wrappedKey = await this.keyGraph.wrapKey(rootKey, itemKey.jwk);\n\n    return {\n      input: {\n        id: sharedItemId,\n        keyId: itemKey.id,\n        wrappingKeyId: rootKey.id,\n        wrappedKey,\n      },\n    };\n  }\n\n  async requestMkReshareMutation(tpId: LrRelayIdInput) {\n    const userSharedKey = await this.getTpCurrentUserSharedKey(tpId);\n\n    if (userSharedKey.mkSharedKey) {\n      throw new KcBadStateException('TP already has mkSharedKey');\n    }\n\n    const masterKey = this.keyService.currentMasterKey;\n    const prk = await this.keyFactory.createPkcKey();\n    const mkWrappedMkPrk = await this.encryptionService.encryptToString(\n      masterKey.jwk,\n      prk.toJSON(true)\n    );\n\n    const sharedKey = await this.keyGraph.getKey(userSharedKey.sharedKey.id);\n    const mkReshareRequestCipher = await this.encryptionService.encryptToString(\n      sharedKey.jwk,\n      {\n        pbk: prk.toJSON(),\n      }\n    );\n\n    return await new LrMutation({\n      mutation: RequestTpMkReshareMutation,\n      variables: {\n        input: {\n          tpId,\n          masterKeyId: masterKey.id,\n          mkPbk: JSON.stringify(prk.toJSON()),\n          mkWrappedMkPrk,\n          sharedKeyId: sharedKey.id,\n          mkReshareRequestCipher,\n        },\n      },\n    });\n  }\n\n  async respondMkReshare(tpId: LrRelayIdInput) {\n    const userSharedKey = await this.getTpCurrentUserSharedKey(tpId);\n\n    if (!userSharedKey.mkSharedKey) {\n      throw new KcBadStateException(\n        'No access to the mkSharedKey so cannot reshare it with TP'\n      );\n    }\n\n    const sharedKey = await this.keyGraph.getKey(userSharedKey.sharedKey.id);\n    const plainMkReshareRequestCipher = await this.encryptionService.decrypt(\n      sharedKey,\n      userSharedKey.mkReshareRequestCipher\n    );\n    const pbk = await JWK.asKey(plainMkReshareRequestCipher.pbk);\n    const mkSharedKey = await this.keyGraph.getKey(\n      userSharedKey.mkSharedKey.id\n    );\n\n    const plainMkReshareResponseCipher = {\n      mkSharedKey: {\n        id: mkSharedKey.id,\n        jwk: mkSharedKey.jwk.toJSON(true),\n      },\n    };\n\n    // Wrap with sharedKey then again with Pbk\n    const mkReshareResponseCipher =\n      await this.encryptionService.encryptToString(\n        pbk,\n        await this.encryptionService.encryptToString(\n          sharedKey.jwk,\n          plainMkReshareResponseCipher\n        )\n      );\n\n    return new LrMutation({\n      mutation: RespondTpMkReshareMutation,\n      variables: {\n        input: {\n          tpId,\n          mkSharedKeyId: mkSharedKey.id,\n          mkReshareResponseCipher,\n        },\n      },\n    });\n  }\n\n  async completeMkReshare(tpId: LrRelayIdInput) {\n    const userSharedKey = await this.getTpCurrentUserSharedKey(tpId);\n\n    const sharedKey = await this.keyGraph.getKey(userSharedKey.sharedKey.id);\n    const prk = await this.keyGraph.getKey(userSharedKey.mkPxk.id);\n    const plainMkReshareResponseCipher = await this.encryptionService.decrypt(\n      sharedKey,\n      await this.encryptionService.decrypt(\n        prk,\n        userSharedKey.mkReshareResponseCipher\n      )\n    );\n\n    // Double check it's a valid key.\n    const mkSharedKey: Key = {\n      id: plainMkReshareResponseCipher.mkSharedKey.id,\n      jwk: await JWK.asKey(plainMkReshareResponseCipher.mkSharedKey.jwk),\n    };\n\n    const masterKey = this.keyService.currentMasterKey;\n    const mkWrappedMkSharedKey = await this.encryptionService.encryptToString(\n      masterKey.jwk,\n      mkSharedKey.jwk.toJSON(true)\n    );\n\n    return new LrMutation({\n      mutation: CompleteTpMkReshareMutation,\n      variables: {\n        input: {\n          tpId,\n          masterKeyId: masterKey.id,\n          mkSharedKeyId: mkSharedKey.id,\n          mkWrappedMkSharedKey,\n        },\n      },\n    });\n  }\n\n  // ------------------------------------------------------------------------------------\n  // ------------------------------------------------------------------------------------\n  // Helpers\n  // ------------------------------------------------------------------------------------\n  // ------------------------------------------------------------------------------------\n  private async getTpCurrentUserSharedKey(tpId: LrRelayIdInput) {\n    return (\n      await this.lrGraphQL.query({\n        query: TpCurrentUserSharedKeyQuery,\n        variables: {\n          id: tpId,\n        },\n      })\n    ).tp.currentUserSharedKey.userSharedKey;\n  }\n}\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1c3RlZC1wYXJ0eS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi90cnVzdGVkLXBhcnR5L3RydXN0ZWQtcGFydHkudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFjY2Vzc1JvbGVDaG9pY2UsIExyUmVsYXlJZElucHV0IH0gZnJvbSAnLi4vYXBpL3R5cGVzJztcblxuLy8gSWYgeHh4S2V5SWQgbm90IGdpdmVuLCB0aGVuIGZldGNoIHRoZW0gd2l0aCBBUEkgY2FsbHNcbmV4cG9ydCBpbnRlcmZhY2UgU2hhcmVJdGVtT3B0aW9ucyB7XG4gIGl0ZW1JZDogTHJSZWxheUlkSW5wdXQ7XG4gIGl0ZW1LZXlJZD86IExyUmVsYXlJZElucHV0O1xuICB0cElkOiBMclJlbGF5SWRJbnB1dDtcbiAgdHBTaGFyZWRLZXlJZD86IExyUmVsYXlJZElucHV0O1xuICBhY2Nlc3NSb2xlOiBBY2Nlc3NSb2xlQ2hvaWNlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFVuc2hhcmVJdGVtT3B0aW9ucyB7XG4gIGl0ZW1JZDogc3RyaW5nO1xuICB0cElkOiBzdHJpbmc7XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1c3RlZC1wYXJ0eS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi90cnVzdGVkLXBhcnR5L3RydXN0ZWQtcGFydHkudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFjY2Vzc1JvbGVDaG9pY2UsXG4gIExyUmVsYXlJZElucHV0LFxuICBUcFNoYXJlVHlwZUNob2ljZSxcbn0gZnJvbSAnLi4vYXBpL3R5cGVzJztcblxuLy8gSWYgeHh4S2V5SWQgbm90IGdpdmVuLCB0aGVuIGZldGNoIHRoZW0gd2l0aCBBUEkgY2FsbHNcbmV4cG9ydCBpbnRlcmZhY2UgU2hhcmVJdGVtT3B0aW9ucyB7XG4gIGl0ZW1JZDogTHJSZWxheUlkSW5wdXQ7XG4gIGl0ZW1LZXlJZD86IExyUmVsYXlJZElucHV0O1xuICB0cElkOiBMclJlbGF5SWRJbnB1dDtcbiAgdHBTaGFyZWRLZXlJZD86IExyUmVsYXlJZElucHV0O1xuICBhY2Nlc3NSb2xlOiBBY2Nlc3NSb2xlQ2hvaWNlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFVuc2hhcmVJdGVtT3B0aW9ucyB7XG4gIGl0ZW1JZDogc3RyaW5nO1xuICB0cElkOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ3JlYXRlU2hhcmVkSXRlbU9wdGlvbnMge1xuICBpdGVtSWQ6IExyUmVsYXlJZElucHV0O1xuICBpdGVtS2V5SWQ/OiBMclJlbGF5SWRJbnB1dDtcbiAgdHBJZDogTHJSZWxheUlkSW5wdXQ7XG4gIHRwU2hhcmVkS2V5SWQ/OiBMclJlbGF5SWRJbnB1dDtcbiAgYWNjZXNzUm9sZTogQWNjZXNzUm9sZUNob2ljZTtcbiAgc2hhcmVUeXBlOiBUcFNoYXJlVHlwZUNob2ljZTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVcGRhdGVTaGFyZWRJdGVtT3B0aW9ucyB7XG4gIHNoYXJlZEl0ZW1JZDogTHJSZWxheUlkSW5wdXQ7XG4gIGFjY2Vzc1JvbGU6IEFjY2Vzc1JvbGVDaG9pY2U7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29tcGxldGVEZXRhY2hlZFNoYXJlZEl0ZW1PcHRpb25zIHtcbiAgc2hhcmVkSXRlbUlkOiBMclJlbGF5SWRJbnB1dDtcbiAgaXRlbUtleUlkPzogTHJSZWxheUlkSW5wdXQ7XG59XG4iXX0=