@lifeready/core 6.1.1 → 6.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.
@@ -33,21 +33,6 @@ export class KeyMetaService {
33
33
  this.keyService = keyService;
34
34
  this.keyFactory = keyFactory;
35
35
  }
36
- // async decryptFromString<T>(
37
- // keyOrId: string | Key,
38
- // cipherData: string,
39
- // options?: DecryptOptions
40
- // ): Promise<T> {
41
- // if (cipherData) {
42
- // const key = await this.keyGraphService.getJwkKey(keyOrId);
43
- // return (await this.encryptionService.decrypt(
44
- // key,
45
- // JSON.parse(cipherData),
46
- // options
47
- // )) as any;
48
- // }
49
- // return null;
50
- // }
51
36
  decryptMeta(metaHaver) {
52
37
  return __awaiter(this, void 0, void 0, function* () {
53
38
  if (metaHaver.cipherMeta) {
@@ -57,47 +42,6 @@ export class KeyMetaService {
57
42
  return null;
58
43
  });
59
44
  }
60
- // async decryptFile(keyId: string, file: any): Promise<any> {
61
- // const key = await this.keyGraphService.getJwkKey(keyId);
62
- // return (await this.encryptionService.decrypt(key, file, {
63
- // payloadType: 'ArrayBuffer',
64
- // })) as any;
65
- // }
66
- // // TODO rename this to encrypt() and use as the most common usecase
67
- // async encryptToString(
68
- // key: string | Key | JWK.Key,
69
- // content: any
70
- // ): Promise<string> {
71
- // // Empty string should be encrypted since you want to clear the field.
72
- // // Null is not encrypted because it's not valid JSON in the old JSON spec. Use
73
- // // empty string instead. It'll function as a logic false as well.
74
- // // Note that passing in empty string means it'll be encrypted which verifies
75
- // // it's integrity. But we still want to have a way to set the DB field
76
- // // to NULL, so we explicitly return null when content == null. A null
77
- // // variable in graphql mutation on KC server clears the field to NULL.
78
- // if (content == null) {
79
- // return null;
80
- // }
81
- // const jwk =
82
- // asJwk(key) || (await this.keyGraphService.getJwkKey(key as string | Key));
83
- // return JSON.stringify(await this.encryptionService.encrypt(jwk, content));
84
- // }
85
- // // Wraps a symmetric encryption key.
86
- // // Throws exception if wrapping public keys.
87
- // async wrapKey<T>(
88
- // wrappingKey: string | Key | JWK.Key,
89
- // key: JWK.Key
90
- // ): Promise<string> {
91
- // if (!isSymmetricKey(key)) {
92
- // throw new LrBadArgumentException(
93
- // 'Only allowing wrapping of symmetric keys.'
94
- // );
95
- // }
96
- // return this.encryptToString(wrappingKey, key.toJSON(true));
97
- // }
98
- // // TODO
99
- // // async wrapPublicKey<T>();
100
- // // async wrapPrivateKey<T>();
101
45
  doubleWrapContent(secureContent, categoryIds, fileContent) {
102
46
  return __awaiter(this, void 0, void 0, function* () {
103
47
  const key = yield this.keyFactory.createKey();
@@ -206,4 +150,4 @@ KeyMetaService.ctorParameters = () => [
206
150
  { type: KeyService },
207
151
  { type: KeyFactoryService }
208
152
  ];
209
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key-meta.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/key/key-meta.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Injectable } from '@angular/core';\nimport { JWK } from 'node-jose';\nimport { LrApolloService } from '../api/lr-apollo.service';\nimport { ID } from '../api/types';\n// import { GetCategoryKeyIdQuery } from '../category/category.gql';\nimport { EncryptionService } from '../encryption/encryption.service';\nimport { gqlTyped } from '../_common/ast';\nimport { KeyFactoryService } from './key-factory.service';\nimport { KeyGraphService } from './key-graph.service';\nimport { KeyService } from './key.service';\n\nexport interface DirectoryKeyQueryResult {\n  directory: {\n    keyId: ID;\n  };\n}\nexport const DirectoryKeyQuery = gqlTyped<DirectoryKeyQueryResult>`\nquery DirectoryKeyQuery($id: LrRelayIdInput!) {\n  directory(id: $id) {\n    keyId\n  }\n}\n`;\n\nexport interface HasCipherMeta {\n  keyId: string;\n  cipherMeta: string;\n}\n\nexport class WrappedContent {\n  key: JWK.Key;\n  cipherMeta: string;\n  wrappedKeys?: WrappingKey[];\n  rootKey?: WrappingKey;\n}\n\nexport class WrappingKey {\n  directoryId?: string;\n  wrappingKeyId: string;\n  wrappedKey: string;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class KeyMetaService {\n  constructor(\n    private encryptionService: EncryptionService,\n    private keyGraph: KeyGraphService,\n    private lrApollo: LrApolloService,\n    private keyService: KeyService,\n    private keyFactory: KeyFactoryService\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.keyGraphService.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 decryptMeta<T>(metaHaver: HasCipherMeta): Promise<T> {\n    if (metaHaver.cipherMeta) {\n      const key = await this.keyGraph.getJwkKey(metaHaver.keyId);\n      return (await this.encryptionService.decrypt(\n        key,\n        JSON.parse(metaHaver.cipherMeta)\n      )) as any;\n    }\n    return null;\n  }\n\n  // async decryptFile(keyId: string, file: any): Promise<any> {\n  //   const key = await this.keyGraphService.getJwkKey(keyId);\n  //   return (await this.encryptionService.decrypt(key, file, {\n  //     payloadType: 'ArrayBuffer',\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 =\n  //     asJwk(key) || (await this.keyGraphService.getJwkKey(key as string | Key));\n  //   return JSON.stringify(await this.encryptionService.encrypt(jwk, content));\n  // }\n\n  // // Wraps a symmetric encryption key.\n  // // Throws exception if wrapping public keys.\n  // async wrapKey<T>(\n  //   wrappingKey: string | Key | JWK.Key,\n  //   key: JWK.Key\n  // ): Promise<string> {\n  //   if (!isSymmetricKey(key)) {\n  //     throw new LrBadArgumentException(\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 doubleWrapContent(\n    secureContent: any,\n    categoryIds: string[],\n    fileContent?: ArrayBuffer\n  ) {\n    const key = await this.keyFactory.createKey();\n\n    const wrappedContent = await this.wrapContent(\n      key.toJSON(true),\n      categoryIds\n    );\n\n    return {\n      rootKey: wrappedContent.rootKey,\n      wrappedKeys: wrappedContent.wrappedKeys,\n      doubleWrappedKey: wrappedContent.cipherMeta,\n      cipherMeta: secureContent\n        ? JSON.stringify(\n            await this.encryptionService.encrypt(key, secureContent)\n          )\n        : null,\n      cipherFileContent: fileContent\n        ? JSON.stringify(await this.encryptionService.encrypt(key, fileContent))\n        : null,\n    };\n  }\n\n  async reWrapContent(keyId: string, secureContent: any) {\n    const key = await this.keyGraph.getJwkKey(keyId);\n    const newKey = await this.keyFactory.createKey();\n\n    return {\n      doubleWrappedKey: JSON.stringify(\n        await this.encryptionService.encrypt(key, newKey.toJSON(true))\n      ),\n      cipherMeta: secureContent\n        ? JSON.stringify(\n            await this.encryptionService.encrypt(newKey, secureContent)\n          )\n        : null,\n    };\n  }\n\n  async wrapContent(\n    secureContent: any,\n    categoryIds?: string[]\n  ): Promise<WrappedContent> {\n    const key = await this.keyFactory.createKey();\n\n    let wrappedKeys: WrappingKey[];\n    let rootWrappingKey: WrappingKey;\n\n    if (categoryIds && categoryIds.length) {\n      wrappedKeys = await Promise.all(\n        categoryIds.map(async (categoryId) => {\n          const parentKey = await this.getDirectoryKeyId(categoryId);\n          const wrappedKey = JSON.stringify(\n            await this.encryptionService.encrypt(\n              parentKey.key,\n              key.toJSON(true)\n            )\n          );\n          return {\n            directoryId: categoryId,\n            wrappingKeyId: parentKey.keyId,\n            wrappedKey,\n          };\n        })\n      );\n    } else {\n      // Adding to root directory\n      const rootKey = this.keyService.currentRootKey;\n      const wrappedKey = JSON.stringify(\n        await this.encryptionService.encrypt(rootKey.jwk, key.toJSON(true))\n      );\n      rootWrappingKey = {\n        wrappingKeyId: rootKey.id,\n        wrappedKey,\n      };\n    }\n\n    return {\n      key,\n      rootKey: rootWrappingKey,\n      wrappedKeys,\n      cipherMeta: secureContent\n        ? JSON.stringify(\n            await this.encryptionService.encrypt(key, secureContent)\n          )\n        : null,\n    };\n  }\n\n  async wrapContentWithKey(\n    secureContent: any,\n    keyId: string\n  ): Promise<WrappedContent> {\n    const key = await this.keyFactory.createKey();\n\n    const wrappedKey = await this.keyGraph.encryptToString(\n      keyId,\n      key.toJSON(true)\n    );\n\n    return {\n      key,\n      rootKey: {\n        wrappingKeyId: keyId,\n        wrappedKey,\n      },\n      cipherMeta: secureContent\n        ? JSON.stringify(\n            await this.encryptionService.encrypt(key, secureContent)\n          )\n        : null,\n    };\n  }\n\n  private async getDirectoryKeyId(\n    categoryId: string\n  ): Promise<{ keyId: string; key: any }> {\n    const { directory } = await this.lrApollo.query<any>({\n      query: DirectoryKeyQuery,\n      variables: {\n        id: categoryId,\n      },\n    });\n\n    return {\n      keyId: directory.keyId,\n      key: await this.keyGraph.getJwkKey(directory.keyId),\n    };\n  }\n}\n"]}
153
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key-meta.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/key/key-meta.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Injectable } from '@angular/core';\nimport { JWK } from 'node-jose';\nimport { LrApolloService } from '../api/lr-apollo.service';\nimport { ID } from '../api/types';\n// import { GetCategoryKeyIdQuery } from '../category/category.gql';\nimport { EncryptionService } from '../encryption/encryption.service';\nimport { gqlTyped } from '../_common/ast';\nimport { KeyFactoryService } from './key-factory.service';\nimport { KeyGraphService } from './key-graph.service';\nimport { KeyService } from './key.service';\n\nexport interface DirectoryKeyQueryResult {\n  directory: {\n    keyId: ID;\n  };\n}\nexport const DirectoryKeyQuery = gqlTyped<DirectoryKeyQueryResult>`\nquery DirectoryKeyQuery($id: LrRelayIdInput!) {\n  directory(id: $id) {\n    keyId\n  }\n}\n`;\n\nexport interface HasCipherMeta {\n  keyId: string;\n  cipherMeta: string;\n}\n\nexport class WrappedContent {\n  key: JWK.Key;\n  cipherMeta: string;\n  wrappedKeys?: WrappingKey[];\n  rootKey?: WrappingKey;\n}\n\nexport class WrappingKey {\n  directoryId?: string;\n  wrappingKeyId: string;\n  wrappedKey: string;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class KeyMetaService {\n  constructor(\n    private encryptionService: EncryptionService,\n    private keyGraph: KeyGraphService,\n    private lrApollo: LrApolloService,\n    private keyService: KeyService,\n    private keyFactory: KeyFactoryService\n  ) {}\n\n  async decryptMeta<T>(metaHaver: HasCipherMeta): Promise<T> {\n    if (metaHaver.cipherMeta) {\n      const key = await this.keyGraph.getJwkKey(metaHaver.keyId);\n      return (await this.encryptionService.decrypt(\n        key,\n        JSON.parse(metaHaver.cipherMeta)\n      )) as any;\n    }\n    return null;\n  }\n\n  async doubleWrapContent(\n    secureContent: any,\n    categoryIds: string[],\n    fileContent?: ArrayBuffer\n  ) {\n    const key = await this.keyFactory.createKey();\n\n    const wrappedContent = await this.wrapContent(\n      key.toJSON(true),\n      categoryIds\n    );\n\n    return {\n      rootKey: wrappedContent.rootKey,\n      wrappedKeys: wrappedContent.wrappedKeys,\n      doubleWrappedKey: wrappedContent.cipherMeta,\n      cipherMeta: secureContent\n        ? JSON.stringify(\n            await this.encryptionService.encrypt(key, secureContent)\n          )\n        : null,\n      cipherFileContent: fileContent\n        ? JSON.stringify(await this.encryptionService.encrypt(key, fileContent))\n        : null,\n    };\n  }\n\n  async reWrapContent(keyId: string, secureContent: any) {\n    const key = await this.keyGraph.getJwkKey(keyId);\n    const newKey = await this.keyFactory.createKey();\n\n    return {\n      doubleWrappedKey: JSON.stringify(\n        await this.encryptionService.encrypt(key, newKey.toJSON(true))\n      ),\n      cipherMeta: secureContent\n        ? JSON.stringify(\n            await this.encryptionService.encrypt(newKey, secureContent)\n          )\n        : null,\n    };\n  }\n\n  async wrapContent(\n    secureContent: any,\n    categoryIds?: string[]\n  ): Promise<WrappedContent> {\n    const key = await this.keyFactory.createKey();\n\n    let wrappedKeys: WrappingKey[];\n    let rootWrappingKey: WrappingKey;\n\n    if (categoryIds && categoryIds.length) {\n      wrappedKeys = await Promise.all(\n        categoryIds.map(async (categoryId) => {\n          const parentKey = await this.getDirectoryKeyId(categoryId);\n          const wrappedKey = JSON.stringify(\n            await this.encryptionService.encrypt(\n              parentKey.key,\n              key.toJSON(true)\n            )\n          );\n          return {\n            directoryId: categoryId,\n            wrappingKeyId: parentKey.keyId,\n            wrappedKey,\n          };\n        })\n      );\n    } else {\n      // Adding to root directory\n      const rootKey = this.keyService.currentRootKey;\n      const wrappedKey = JSON.stringify(\n        await this.encryptionService.encrypt(rootKey.jwk, key.toJSON(true))\n      );\n      rootWrappingKey = {\n        wrappingKeyId: rootKey.id,\n        wrappedKey,\n      };\n    }\n\n    return {\n      key,\n      rootKey: rootWrappingKey,\n      wrappedKeys,\n      cipherMeta: secureContent\n        ? JSON.stringify(\n            await this.encryptionService.encrypt(key, secureContent)\n          )\n        : null,\n    };\n  }\n\n  async wrapContentWithKey(\n    secureContent: any,\n    keyId: string\n  ): Promise<WrappedContent> {\n    const key = await this.keyFactory.createKey();\n\n    const wrappedKey = await this.keyGraph.encryptToString(\n      keyId,\n      key.toJSON(true)\n    );\n\n    return {\n      key,\n      rootKey: {\n        wrappingKeyId: keyId,\n        wrappedKey,\n      },\n      cipherMeta: secureContent\n        ? JSON.stringify(\n            await this.encryptionService.encrypt(key, secureContent)\n          )\n        : null,\n    };\n  }\n\n  private async getDirectoryKeyId(\n    categoryId: string\n  ): Promise<{ keyId: string; key: any }> {\n    const { directory } = await this.lrApollo.query<any>({\n      query: DirectoryKeyQuery,\n      variables: {\n        id: categoryId,\n      },\n    });\n\n    return {\n      keyId: directory.keyId,\n      key: await this.keyGraph.getJwkKey(directory.keyId),\n    };\n  }\n}\n"]}
@@ -8,4 +8,9 @@ export var KeyGraphEdgeType;
8
8
  KeyGraphEdgeType["KeyLink"] = "keyLink";
9
9
  KeyGraphEdgeType["PassKeyLink"] = "passKeyLink";
10
10
  })(KeyGraphEdgeType || (KeyGraphEdgeType = {}));
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5LnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9zcmMvbGliL2tleS9rZXkudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbURBLE1BQU0sQ0FBTixJQUFZLGdCQUdYO0FBSEQsV0FBWSxnQkFBZ0I7SUFDMUIsK0JBQVcsQ0FBQTtJQUNYLHVDQUFtQixDQUFBO0FBQ3JCLENBQUMsRUFIVyxnQkFBZ0IsS0FBaEIsZ0JBQWdCLFFBRzNCO0FBT0QsTUFBTSxDQUFOLElBQVksZ0JBR1g7QUFIRCxXQUFZLGdCQUFnQjtJQUMxQix1Q0FBbUIsQ0FBQTtJQUNuQiwrQ0FBMkIsQ0FBQTtBQUM3QixDQUFDLEVBSFcsZ0JBQWdCLEtBQWhCLGdCQUFnQixRQUczQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEpXSyB9IGZyb20gJ25vZGUtam9zZSc7XG5pbXBvcnQgeyBKU09OT2JqZWN0LCBQYXNzS2V5Tm9kZSB9IGZyb20gJy4uL2FwaS90eXBlcyc7XG5pbXBvcnQgeyBIYXNFZGdlcywgU29tZVJlcXVpcmVkIH0gZnJvbSAnLi4vX2NvbW1vbi90eXBlcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgS2V5IHtcbiAgaWQ6IHN0cmluZztcbiAgcGJrPzogc3RyaW5nO1xuICBqd2s/OiBKV0suS2V5O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBhc3NLZXlQYXJhbXMge1xuICBraWQ6IHN0cmluZztcbiAgc2FsdDogc3RyaW5nO1xuICBpdGVyYXRpb25zOiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFzc0lkcFBhcmFtcyB7XG4gIHNhbHQ6IHN0cmluZztcbiAgaXRlcmF0aW9uczogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExib3BLZXlQYXJhbXMge1xuICBraWQ6IHN0cmluZztcbiAgc2FsdDogc3RyaW5nO1xuICBpdGVyYXRpb25zOiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFzc0lkcFZlcmlmaWVyIHtcbiAgd3JhcHBlZFBySzogUmVjb3JkPHN0cmluZywgSlNPTk9iamVjdD47XG4gIHBiazogUmVjb3JkPHN0cmluZywgSlNPTk9iamVjdD47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGJvcEtleVZlcmlmaWVyIHtcbiAgd3JhcHBlZEtleTogUmVjb3JkPHN0cmluZywgSlNPTk9iamVjdD47XG4gIGtleTogUmVjb3JkPHN0cmluZywgSlNPTk9iamVjdD47XG59XG5cbmV4cG9ydCB0eXBlIFBhc3NLZXkgPSBTb21lUmVxdWlyZWQ8UGFzc0tleU5vZGUsICdpZCc+O1xuXG5leHBvcnQgaW50ZXJmYWNlIEtleUxpbmsge1xuICBrZXlJZDogc3RyaW5nO1xuICB3cmFwcGluZ0tleUlkOiBzdHJpbmc7XG4gIHdyYXBwZWRLZXk6IHN0cmluZzsgLy8gSldFIGpzb24gc3RyaW5nXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFzc0tleUxpbmsge1xuICBrZXlJZDogc3RyaW5nO1xuICBwYXNzS2V5SWQ6IHN0cmluZztcbiAgd3JhcHBlZEtleTogc3RyaW5nOyAvLyBKV0UganNvbiBzdHJpbmdcbn1cblxuZXhwb3J0IGVudW0gS2V5R3JhcGhOb2RlVHlwZSB7XG4gIEtleSA9ICdrZXknLFxuICBQYXNzS2V5ID0gJ3Bhc3NLZXknLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEtleUdyYXBoTm9kZSB7XG4gIHR5cGU6IEtleUdyYXBoTm9kZVR5cGU7XG4gIGRhdGE6IEtleSB8IFBhc3NLZXk7XG59XG5cbmV4cG9ydCBlbnVtIEtleUdyYXBoRWRnZVR5cGUge1xuICBLZXlMaW5rID0gJ2tleUxpbmsnLFxuICBQYXNzS2V5TGluayA9ICdwYXNzS2V5TGluaycsXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgS2V5R3JhcGhFZGdlIHtcbiAgdHlwZTogS2V5R3JhcGhFZGdlVHlwZTtcbiAgZGF0YTogS2V5TGluayB8IFBhc3NLZXlMaW5rO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEtleUdyYXBoUmVzcG9uc2Uge1xuICBrZXlzPzogS2V5W107XG4gIGtleUxpbmtzPzogS2V5TGlua1tdO1xuICBwYXNzS2V5cz86IFBhc3NLZXlbXTtcbiAgcGFzc0tleUxpbmtzPzogUGFzc0tleUxpbmtbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBIYXNLZXlHcmFwaCB7XG4gIC8vIFRoZSBuYW1lIG9mIHRoZSBrZXlHcmFwaCBmaWVsZCByZXR1cm5lZCBmcm9tIGJvdGggcXVlcmllcyBhbmQgbXV0YXRpb25zIGFyZSB0aGUgc2FtZVxuICBrZXlHcmFwaD86IEtleUdyYXBoUmVzcG9uc2U7XG59XG5cbmV4cG9ydCB0eXBlIFBheWxvYWRUeXBlID0gJ2pzb24nIHwgJ0FycmF5QnVmZmVyJztcblxuZXhwb3J0IGludGVyZmFjZSBEZXJpdmVLZXlSZXN1bHQge1xuICBqd2s6IEpXSy5LZXk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGVyaXZlUGFzc0lkcFBhcmFtcyBleHRlbmRzIFBhc3NJZHBQYXJhbXMge1xuICBwYXNzd29yZDogQ3J5cHRvS2V5O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERlcml2ZVBhc3NLZXlQYXJhbXMgZXh0ZW5kcyBQYXNzS2V5UGFyYW1zIHtcbiAgcGFzc3dvcmQ6IENyeXB0b0tleTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEZXJpdmVMYm9wS2V5UGFyYW1zIGV4dGVuZHMgUGFzc0tleVBhcmFtcyB7XG4gIHBhc3N3b3JkOiBDcnlwdG9LZXk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSGFzS2V5R3JhcGhFZGdlczxUPiBleHRlbmRzIEhhc0tleUdyYXBoIHtcbiAgbGlzdDogSGFzRWRnZXM8VD47XG59XG4iXX0=
11
+ export var PayloadType;
12
+ (function (PayloadType) {
13
+ PayloadType["JSON"] = "JSON";
14
+ PayloadType["UINT_8_ARRAY"] = "UINT_8_ARRAY";
15
+ })(PayloadType || (PayloadType = {}));
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5LnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9zcmMvbGliL2tleS9rZXkudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbURBLE1BQU0sQ0FBTixJQUFZLGdCQUdYO0FBSEQsV0FBWSxnQkFBZ0I7SUFDMUIsK0JBQVcsQ0FBQTtJQUNYLHVDQUFtQixDQUFBO0FBQ3JCLENBQUMsRUFIVyxnQkFBZ0IsS0FBaEIsZ0JBQWdCLFFBRzNCO0FBT0QsTUFBTSxDQUFOLElBQVksZ0JBR1g7QUFIRCxXQUFZLGdCQUFnQjtJQUMxQix1Q0FBbUIsQ0FBQTtJQUNuQiwrQ0FBMkIsQ0FBQTtBQUM3QixDQUFDLEVBSFcsZ0JBQWdCLEtBQWhCLGdCQUFnQixRQUczQjtBQW1CRCxNQUFNLENBQU4sSUFBWSxXQUdYO0FBSEQsV0FBWSxXQUFXO0lBQ3JCLDRCQUFhLENBQUE7SUFDYiw0Q0FBNkIsQ0FBQTtBQUMvQixDQUFDLEVBSFcsV0FBVyxLQUFYLFdBQVcsUUFHdEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBKV0sgfSBmcm9tICdub2RlLWpvc2UnO1xuaW1wb3J0IHsgSlNPTk9iamVjdCwgUGFzc0tleU5vZGUgfSBmcm9tICcuLi9hcGkvdHlwZXMnO1xuaW1wb3J0IHsgSGFzRWRnZXMsIFNvbWVSZXF1aXJlZCB9IGZyb20gJy4uL19jb21tb24vdHlwZXMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEtleSB7XG4gIGlkOiBzdHJpbmc7XG4gIHBiaz86IHN0cmluZztcbiAgandrPzogSldLLktleTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQYXNzS2V5UGFyYW1zIHtcbiAga2lkOiBzdHJpbmc7XG4gIHNhbHQ6IHN0cmluZztcbiAgaXRlcmF0aW9uczogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBhc3NJZHBQYXJhbXMge1xuICBzYWx0OiBzdHJpbmc7XG4gIGl0ZXJhdGlvbnM6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMYm9wS2V5UGFyYW1zIHtcbiAga2lkOiBzdHJpbmc7XG4gIHNhbHQ6IHN0cmluZztcbiAgaXRlcmF0aW9uczogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBhc3NJZHBWZXJpZmllciB7XG4gIHdyYXBwZWRQcks6IFJlY29yZDxzdHJpbmcsIEpTT05PYmplY3Q+O1xuICBwYms6IFJlY29yZDxzdHJpbmcsIEpTT05PYmplY3Q+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExib3BLZXlWZXJpZmllciB7XG4gIHdyYXBwZWRLZXk6IFJlY29yZDxzdHJpbmcsIEpTT05PYmplY3Q+O1xuICBrZXk6IFJlY29yZDxzdHJpbmcsIEpTT05PYmplY3Q+O1xufVxuXG5leHBvcnQgdHlwZSBQYXNzS2V5ID0gU29tZVJlcXVpcmVkPFBhc3NLZXlOb2RlLCAnaWQnPjtcblxuZXhwb3J0IGludGVyZmFjZSBLZXlMaW5rIHtcbiAga2V5SWQ6IHN0cmluZztcbiAgd3JhcHBpbmdLZXlJZDogc3RyaW5nO1xuICB3cmFwcGVkS2V5OiBzdHJpbmc7IC8vIEpXRSBqc29uIHN0cmluZ1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBhc3NLZXlMaW5rIHtcbiAga2V5SWQ6IHN0cmluZztcbiAgcGFzc0tleUlkOiBzdHJpbmc7XG4gIHdyYXBwZWRLZXk6IHN0cmluZzsgLy8gSldFIGpzb24gc3RyaW5nXG59XG5cbmV4cG9ydCBlbnVtIEtleUdyYXBoTm9kZVR5cGUge1xuICBLZXkgPSAna2V5JyxcbiAgUGFzc0tleSA9ICdwYXNzS2V5Jyxcbn1cblxuZXhwb3J0IGludGVyZmFjZSBLZXlHcmFwaE5vZGUge1xuICB0eXBlOiBLZXlHcmFwaE5vZGVUeXBlO1xuICBkYXRhOiBLZXkgfCBQYXNzS2V5O1xufVxuXG5leHBvcnQgZW51bSBLZXlHcmFwaEVkZ2VUeXBlIHtcbiAgS2V5TGluayA9ICdrZXlMaW5rJyxcbiAgUGFzc0tleUxpbmsgPSAncGFzc0tleUxpbmsnLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEtleUdyYXBoRWRnZSB7XG4gIHR5cGU6IEtleUdyYXBoRWRnZVR5cGU7XG4gIGRhdGE6IEtleUxpbmsgfCBQYXNzS2V5TGluaztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBLZXlHcmFwaFJlc3BvbnNlIHtcbiAga2V5cz86IEtleVtdO1xuICBrZXlMaW5rcz86IEtleUxpbmtbXTtcbiAgcGFzc0tleXM/OiBQYXNzS2V5W107XG4gIHBhc3NLZXlMaW5rcz86IFBhc3NLZXlMaW5rW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSGFzS2V5R3JhcGgge1xuICAvLyBUaGUgbmFtZSBvZiB0aGUga2V5R3JhcGggZmllbGQgcmV0dXJuZWQgZnJvbSBib3RoIHF1ZXJpZXMgYW5kIG11dGF0aW9ucyBhcmUgdGhlIHNhbWVcbiAga2V5R3JhcGg/OiBLZXlHcmFwaFJlc3BvbnNlO1xufVxuXG5leHBvcnQgZW51bSBQYXlsb2FkVHlwZSB7XG4gIEpTT04gPSAnSlNPTicsXG4gIFVJTlRfOF9BUlJBWSA9ICdVSU5UXzhfQVJSQVknLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIERlcml2ZUtleVJlc3VsdCB7XG4gIGp3azogSldLLktleTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEZXJpdmVQYXNzSWRwUGFyYW1zIGV4dGVuZHMgUGFzc0lkcFBhcmFtcyB7XG4gIHBhc3N3b3JkOiBDcnlwdG9LZXk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGVyaXZlUGFzc0tleVBhcmFtcyBleHRlbmRzIFBhc3NLZXlQYXJhbXMge1xuICBwYXNzd29yZDogQ3J5cHRvS2V5O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERlcml2ZUxib3BLZXlQYXJhbXMgZXh0ZW5kcyBQYXNzS2V5UGFyYW1zIHtcbiAgcGFzc3dvcmQ6IENyeXB0b0tleTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBIYXNLZXlHcmFwaEVkZ2VzPFQ+IGV4dGVuZHMgSGFzS2V5R3JhcGgge1xuICBsaXN0OiBIYXNFZGdlczxUPjtcbn1cbiJdfQ==
@@ -19,6 +19,22 @@ import { Keepalive, NgIdleKeepaliveModule } from '@ng-idle/keepalive';
19
19
  import { Slip39Helper, Slip39 } from 'slip39';
20
20
  import Auth from '@aws-amplify/auth';
21
21
 
22
+ var KeyGraphNodeType;
23
+ (function (KeyGraphNodeType) {
24
+ KeyGraphNodeType["Key"] = "key";
25
+ KeyGraphNodeType["PassKey"] = "passKey";
26
+ })(KeyGraphNodeType || (KeyGraphNodeType = {}));
27
+ var KeyGraphEdgeType;
28
+ (function (KeyGraphEdgeType) {
29
+ KeyGraphEdgeType["KeyLink"] = "keyLink";
30
+ KeyGraphEdgeType["PassKeyLink"] = "passKeyLink";
31
+ })(KeyGraphEdgeType || (KeyGraphEdgeType = {}));
32
+ var PayloadType;
33
+ (function (PayloadType) {
34
+ PayloadType["JSON"] = "JSON";
35
+ PayloadType["UINT_8_ARRAY"] = "UINT_8_ARRAY";
36
+ })(PayloadType || (PayloadType = {}));
37
+
22
38
  function handleApolloError(errors) {
23
39
  if (!errors || !errors.length)
24
40
  return;
@@ -411,11 +427,11 @@ var JoseSerialization;
411
427
  JoseSerialization["COMPACT"] = "COMPACT";
412
428
  })(JoseSerialization || (JoseSerialization = {}));
413
429
  const VERIFY_OPTIONS_DEFAULT = {
414
- payloadType: 'json',
430
+ payloadType: PayloadType.JSON,
415
431
  returnOnlyPayload: true,
416
432
  };
417
433
  const DECRYPT_OPTIONS_DEFAULT = {
418
- payloadType: 'json',
434
+ payloadType: PayloadType.JSON,
419
435
  returnOnlyPayload: true,
420
436
  serializations: [JoseSerialization.JSON],
421
437
  };
@@ -483,7 +499,7 @@ class EncryptionService {
483
499
  }
484
500
  });
485
501
  }
486
- // TODO rename this to encrypt() and use as the most common usecase
502
+ // TODO rename this to encrypt() and use as the most common use case
487
503
  encryptToString(key, content) {
488
504
  return __awaiter(this, void 0, void 0, function* () {
489
505
  return JSON.stringify(yield this.encrypt(key, content));
@@ -565,9 +581,9 @@ class EncryptionService {
565
581
  }
566
582
  decodePayload(payloadType, payload) {
567
583
  switch (payloadType) {
568
- case 'json':
584
+ case PayloadType.JSON:
569
585
  return JSON.parse(new TextDecoder().decode(payload));
570
- case 'ArrayBuffer':
586
+ case PayloadType.UINT_8_ARRAY:
571
587
  return payload;
572
588
  default:
573
589
  throw new KcBadArgumentException(`Unknown payloadType: ${payloadType}`);
@@ -1199,17 +1215,6 @@ KeyService.ctorParameters = () => [
1199
1215
  { type: PersistService }
1200
1216
  ];
1201
1217
 
1202
- var KeyGraphNodeType;
1203
- (function (KeyGraphNodeType) {
1204
- KeyGraphNodeType["Key"] = "key";
1205
- KeyGraphNodeType["PassKey"] = "passKey";
1206
- })(KeyGraphNodeType || (KeyGraphNodeType = {}));
1207
- var KeyGraphEdgeType;
1208
- (function (KeyGraphEdgeType) {
1209
- KeyGraphEdgeType["KeyLink"] = "keyLink";
1210
- KeyGraphEdgeType["PassKeyLink"] = "passKeyLink";
1211
- })(KeyGraphEdgeType || (KeyGraphEdgeType = {}));
1212
-
1213
1218
  class KeyGraphService {
1214
1219
  // private keyCache: {
1215
1220
  // [id: string]: Key;
@@ -1431,7 +1436,7 @@ class KeyGraphService {
1431
1436
  return __awaiter(this, void 0, void 0, function* () {
1432
1437
  const key = yield this.getJwkKey(keyId);
1433
1438
  return (yield this.encryptionService.decrypt(key, file, {
1434
- payloadType: 'ArrayBuffer',
1439
+ payloadType: PayloadType.UINT_8_ARRAY,
1435
1440
  }));
1436
1441
  });
1437
1442
  }
@@ -3255,21 +3260,6 @@ class KeyMetaService {
3255
3260
  this.keyService = keyService;
3256
3261
  this.keyFactory = keyFactory;
3257
3262
  }
3258
- // async decryptFromString<T>(
3259
- // keyOrId: string | Key,
3260
- // cipherData: string,
3261
- // options?: DecryptOptions
3262
- // ): Promise<T> {
3263
- // if (cipherData) {
3264
- // const key = await this.keyGraphService.getJwkKey(keyOrId);
3265
- // return (await this.encryptionService.decrypt(
3266
- // key,
3267
- // JSON.parse(cipherData),
3268
- // options
3269
- // )) as any;
3270
- // }
3271
- // return null;
3272
- // }
3273
3263
  decryptMeta(metaHaver) {
3274
3264
  return __awaiter(this, void 0, void 0, function* () {
3275
3265
  if (metaHaver.cipherMeta) {
@@ -3279,47 +3269,6 @@ class KeyMetaService {
3279
3269
  return null;
3280
3270
  });
3281
3271
  }
3282
- // async decryptFile(keyId: string, file: any): Promise<any> {
3283
- // const key = await this.keyGraphService.getJwkKey(keyId);
3284
- // return (await this.encryptionService.decrypt(key, file, {
3285
- // payloadType: 'ArrayBuffer',
3286
- // })) as any;
3287
- // }
3288
- // // TODO rename this to encrypt() and use as the most common usecase
3289
- // async encryptToString(
3290
- // key: string | Key | JWK.Key,
3291
- // content: any
3292
- // ): Promise<string> {
3293
- // // Empty string should be encrypted since you want to clear the field.
3294
- // // Null is not encrypted because it's not valid JSON in the old JSON spec. Use
3295
- // // empty string instead. It'll function as a logic false as well.
3296
- // // Note that passing in empty string means it'll be encrypted which verifies
3297
- // // it's integrity. But we still want to have a way to set the DB field
3298
- // // to NULL, so we explicitly return null when content == null. A null
3299
- // // variable in graphql mutation on KC server clears the field to NULL.
3300
- // if (content == null) {
3301
- // return null;
3302
- // }
3303
- // const jwk =
3304
- // asJwk(key) || (await this.keyGraphService.getJwkKey(key as string | Key));
3305
- // return JSON.stringify(await this.encryptionService.encrypt(jwk, content));
3306
- // }
3307
- // // Wraps a symmetric encryption key.
3308
- // // Throws exception if wrapping public keys.
3309
- // async wrapKey<T>(
3310
- // wrappingKey: string | Key | JWK.Key,
3311
- // key: JWK.Key
3312
- // ): Promise<string> {
3313
- // if (!isSymmetricKey(key)) {
3314
- // throw new LrBadArgumentException(
3315
- // 'Only allowing wrapping of symmetric keys.'
3316
- // );
3317
- // }
3318
- // return this.encryptToString(wrappingKey, key.toJSON(true));
3319
- // }
3320
- // // TODO
3321
- // // async wrapPublicKey<T>();
3322
- // // async wrapPrivateKey<T>();
3323
3272
  doubleWrapContent(secureContent, categoryIds, fileContent) {
3324
3273
  return __awaiter(this, void 0, void 0, function* () {
3325
3274
  const key = yield this.keyFactory.createKey();
@@ -6100,7 +6049,7 @@ let Item2Service = Item2Service_1 = class Item2Service extends LrService {
6100
6049
  const fileContent = yield this.fileUploadService.downloadEncryptedFile(options.fileStateNodeId);
6101
6050
  const fileStateKey = yield this.keyGraph.getKey(options.fileStateKeyId, () => this.getFileStateKeyId(options.fileStateNodeId));
6102
6051
  return this.keyGraph.decryptFromString(fileStateKey, fileContent, {
6103
- payloadType: 'ArrayBuffer',
6052
+ payloadType: PayloadType.UINT_8_ARRAY,
6104
6053
  });
6105
6054
  });
6106
6055
  }