@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.
- package/bundles/lifeready-core.umd.js +23 -74
- package/bundles/lifeready-core.umd.js.map +1 -1
- package/bundles/lifeready-core.umd.min.js +1 -1
- package/bundles/lifeready-core.umd.min.js.map +1 -1
- package/esm2015/lib/encryption/encryption.service.js +7 -6
- package/esm2015/lib/item2/item2.service.js +3 -2
- package/esm2015/lib/key/key-graph.service.js +3 -3
- package/esm2015/lib/key/key-meta.service.js +1 -57
- package/esm2015/lib/key/key.types.js +6 -1
- package/fesm2015/lifeready-core.js +23 -74
- package/fesm2015/lifeready-core.js.map +1 -1
- package/lib/item2/item2.service.d.ts +1 -1
- package/lib/key/key.types.d.ts +4 -1
- package/lifeready-core.metadata.json +1 -1
- package/package.json +1 -1
|
@@ -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
|
-
|
|
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:
|
|
430
|
+
payloadType: PayloadType.JSON,
|
|
415
431
|
returnOnlyPayload: true,
|
|
416
432
|
};
|
|
417
433
|
const DECRYPT_OPTIONS_DEFAULT = {
|
|
418
|
-
payloadType:
|
|
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
|
|
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
|
|
584
|
+
case PayloadType.JSON:
|
|
569
585
|
return JSON.parse(new TextDecoder().decode(payload));
|
|
570
|
-
case
|
|
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:
|
|
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:
|
|
6052
|
+
payloadType: PayloadType.UINT_8_ARRAY,
|
|
6104
6053
|
});
|
|
6105
6054
|
});
|
|
6106
6055
|
}
|