@lifeready/core 8.0.5 → 8.0.7
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 +207 -70
- 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/_common/utils.js +14 -1
- package/esm2015/lib/api/types/lr-graphql.types.js +2 -1
- package/esm2015/lib/item/item.service.js +24 -20
- package/esm2015/lib/item/item.types.js +1 -1
- package/esm2015/lib/scenario/scenario.private.gql.js +11 -1
- package/esm2015/lib/scenario/scenario.service.js +101 -20
- package/esm2015/lib/scenario/scenario.types.js +1 -1
- package/esm2015/lib/trusted-party/trusted-party.service.js +19 -2
- package/fesm2015/lifeready-core.js +161 -38
- package/fesm2015/lifeready-core.js.map +1 -1
- package/lib/_common/utils.d.ts +1 -0
- package/lib/api/types/lr-graphql.types.d.ts +13 -20
- package/lib/item/item.service.d.ts +2 -2
- package/lib/item/item.types.d.ts +3 -8
- package/lib/scenario/scenario.service.d.ts +223 -0
- package/lib/scenario/scenario.types.d.ts +15 -3
- package/lib/trusted-party/trusted-party.service.d.ts +6 -0
- package/lifeready-core.metadata.json +1 -1
- package/package.json +1 -1
|
@@ -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 { CompleteDetachedDirectoryShareMutation, CompleteDetachedFileShareMutation, CompleteTpMkReshareMutation, CreateDirectoryShareMutation, CreateFileShareMutation, DeleteDirectoryShareMutation, DeleteTpMutation, RequestTpMkReshareMutation, RespondTpMkReshareMutation, UpdateDirectoryShareMutation, UpdateFileShareMutation, } from './trusted-party.gql';
|
|
12
|
+
import { CompleteDetachedDirectoryShareMutation, CompleteDetachedFileShareMutation, CompleteTpMkReshareMutation, CreateDirectoryShareMutation, CreateFileShareMutation, DeleteDirectoryShareMutation, DeleteFileShareMutation, DeleteTpMutation, RequestTpMkReshareMutation, RespondTpMkReshareMutation, UpdateDirectoryShareMutation, UpdateFileShareMutation, } 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";
|
|
@@ -140,6 +140,23 @@ let TrustedPartyService = class TrustedPartyService extends LrService {
|
|
|
140
140
|
});
|
|
141
141
|
});
|
|
142
142
|
}
|
|
143
|
+
deleteFileShare(id) {
|
|
144
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
145
|
+
return this.mutate(this.deleteFileShareMutation(id));
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
deleteFileShareMutation(id) {
|
|
149
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
150
|
+
return new LrMutation({
|
|
151
|
+
mutation: DeleteFileShareMutation,
|
|
152
|
+
variables: {
|
|
153
|
+
input: {
|
|
154
|
+
id,
|
|
155
|
+
},
|
|
156
|
+
},
|
|
157
|
+
});
|
|
158
|
+
});
|
|
159
|
+
}
|
|
143
160
|
completeDetachedDirectoryShare(options) {
|
|
144
161
|
return __awaiter(this, void 0, void 0, function* () {
|
|
145
162
|
return this.mutate(this.completeDetachedDirectoryShareMutation(options));
|
|
@@ -305,4 +322,4 @@ TrustedPartyService = __decorate([
|
|
|
305
322
|
})
|
|
306
323
|
], TrustedPartyService);
|
|
307
324
|
export { TrustedPartyService };
|
|
308
|
-
//# 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  CompleteDetachedDirectoryShareMutation,\n  CompleteDetachedFileShareMutation,\n  CompleteTpMkReshareMutation,\n  CreateDirectoryShareMutation,\n  CreateFileShareMutation,\n  DeleteDirectoryShareMutation,\n  DeleteTpMutation,\n  RequestTpMkReshareMutation,\n  RespondTpMkReshareMutation,\n  UpdateDirectoryShareMutation,\n  UpdateFileShareMutation,\n} from './trusted-party.gql';\nimport { TpCurrentUserSharedKeyQuery } from './trusted-party.gql.private';\nimport {\n  CompleteDetachedItemShareOptions,\n  CreateItemShareOptions,\n  UpdateItemShareOptions,\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 createDirectoryShare(options: CreateItemShareOptions) {\n    return this.mutate(this.createDirectoryShareMutation(options));\n  }\n\n  async createDirectoryShareMutation(options: CreateItemShareOptions) {\n    return new LrMutation({\n      mutation: CreateDirectoryShareMutation,\n      variables: await this.prepareCreateItemShareMutation({\n        ...options,\n        isDirectory: true,\n      }),\n    });\n  }\n\n  async createFileShare(options: CreateItemShareOptions) {\n    return this.mutate(this.createFileShareMutation(options));\n  }\n\n  async createFileShareMutation(options: CreateItemShareOptions) {\n    return new LrMutation({\n      mutation: CreateFileShareMutation,\n      variables: await this.prepareCreateItemShareMutation({\n        ...options,\n        isDirectory: false,\n      }),\n    });\n  }\n\n  private async prepareCreateItemShareMutation(\n    options: CreateItemShareOptions & { isDirectory: boolean }\n  ) {\n    const {\n      itemId,\n      itemKeyId,\n      tpId,\n      tpSharedKeyId,\n      accessRole,\n      isDirectory,\n      shareType,\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\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 updateDirectoryShare(options: UpdateItemShareOptions) {\n    return this.mutate(this.updateDirectoryShareMutation(options));\n  }\n\n  async updateDirectoryShareMutation(options: UpdateItemShareOptions) {\n    return new LrMutation({\n      mutation: UpdateDirectoryShareMutation,\n      variables: this.prepareUpdateItemShareMutation(options),\n    });\n  }\n\n  async updateFileShare(options: UpdateItemShareOptions) {\n    return this.mutate(this.updateFileShareMutation(options));\n  }\n\n  async updateFileShareMutation(options: UpdateItemShareOptions) {\n    return new LrMutation({\n      mutation: UpdateFileShareMutation,\n      variables: this.prepareUpdateItemShareMutation(options),\n    });\n  }\n\n  private prepareUpdateItemShareMutation(options: UpdateItemShareOptions) {\n    const { itemShareId, accessRole } = options;\n\n    return {\n      input: {\n        id: itemShareId,\n        accessRole,\n      },\n    };\n  }\n\n  async deleteDirectoryShare(id: string) {\n    return this.mutate(this.deleteDirectoryShareMutation(id));\n  }\n\n  async deleteDirectoryShareMutation(id: string) {\n    return new LrMutation({\n      mutation: DeleteDirectoryShareMutation,\n      variables: {\n        input: {\n          id,\n        },\n      },\n    });\n  }\n\n  async completeDetachedDirectoryShare(\n    options: CompleteDetachedItemShareOptions\n  ) {\n    return this.mutate(this.completeDetachedDirectoryShareMutation(options));\n  }\n\n  async completeDetachedDirectoryShareMutation(\n    options: CompleteDetachedItemShareOptions\n  ) {\n    return new LrMutation({\n      mutation: CompleteDetachedDirectoryShareMutation,\n      variables: await this.prepareCompleteDetachedItemShareMutation({\n        ...options,\n        isDirectory: true,\n      }),\n    });\n  }\n\n  async completeDetachedFileShare(options: CompleteDetachedItemShareOptions) {\n    return this.mutate(this.completeDetachedFileShareMutation(options));\n  }\n\n  async completeDetachedFileShareMutation(\n    options: CompleteDetachedItemShareOptions\n  ) {\n    return new LrMutation({\n      mutation: CompleteDetachedFileShareMutation,\n      variables: await this.prepareCompleteDetachedItemShareMutation({\n        ...options,\n        isDirectory: false,\n      }),\n    });\n  }\n\n  private async prepareCompleteDetachedItemShareMutation(\n    options: CompleteDetachedItemShareOptions & { isDirectory: boolean }\n  ) {\n    const { itemShareId, itemKeyId, isDirectory } = options;\n\n    const itemKey = await this.keyGraph.getKey(itemKeyId, () =>\n      isDirectory\n        ? this.itemService.getDirectoryKeyIdFromDirectoryShare(itemShareId)\n        : this.itemService.getFileKeyIdFromFileShare(itemShareId)\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: itemShareId,\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"]}
|
|
325
|
+
//# 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  CompleteDetachedDirectoryShareMutation,\n  CompleteDetachedFileShareMutation,\n  CompleteTpMkReshareMutation,\n  CreateDirectoryShareMutation,\n  CreateFileShareMutation,\n  DeleteDirectoryShareMutation,\n  DeleteFileShareMutation,\n  DeleteTpMutation,\n  RequestTpMkReshareMutation,\n  RespondTpMkReshareMutation,\n  UpdateDirectoryShareMutation,\n  UpdateFileShareMutation,\n} from './trusted-party.gql';\nimport { TpCurrentUserSharedKeyQuery } from './trusted-party.gql.private';\nimport {\n  CompleteDetachedItemShareOptions,\n  CreateItemShareOptions,\n  UpdateItemShareOptions,\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 createDirectoryShare(options: CreateItemShareOptions) {\n    return this.mutate(this.createDirectoryShareMutation(options));\n  }\n\n  async createDirectoryShareMutation(options: CreateItemShareOptions) {\n    return new LrMutation({\n      mutation: CreateDirectoryShareMutation,\n      variables: await this.prepareCreateItemShareMutation({\n        ...options,\n        isDirectory: true,\n      }),\n    });\n  }\n\n  async createFileShare(options: CreateItemShareOptions) {\n    return this.mutate(this.createFileShareMutation(options));\n  }\n\n  async createFileShareMutation(options: CreateItemShareOptions) {\n    return new LrMutation({\n      mutation: CreateFileShareMutation,\n      variables: await this.prepareCreateItemShareMutation({\n        ...options,\n        isDirectory: false,\n      }),\n    });\n  }\n\n  private async prepareCreateItemShareMutation(\n    options: CreateItemShareOptions & { isDirectory: boolean }\n  ) {\n    const {\n      itemId,\n      itemKeyId,\n      tpId,\n      tpSharedKeyId,\n      accessRole,\n      isDirectory,\n      shareType,\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\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 updateDirectoryShare(options: UpdateItemShareOptions) {\n    return this.mutate(this.updateDirectoryShareMutation(options));\n  }\n\n  async updateDirectoryShareMutation(options: UpdateItemShareOptions) {\n    return new LrMutation({\n      mutation: UpdateDirectoryShareMutation,\n      variables: this.prepareUpdateItemShareMutation(options),\n    });\n  }\n\n  async updateFileShare(options: UpdateItemShareOptions) {\n    return this.mutate(this.updateFileShareMutation(options));\n  }\n\n  async updateFileShareMutation(options: UpdateItemShareOptions) {\n    return new LrMutation({\n      mutation: UpdateFileShareMutation,\n      variables: this.prepareUpdateItemShareMutation(options),\n    });\n  }\n\n  private prepareUpdateItemShareMutation(options: UpdateItemShareOptions) {\n    const { itemShareId, accessRole } = options;\n\n    return {\n      input: {\n        id: itemShareId,\n        accessRole,\n      },\n    };\n  }\n\n  async deleteDirectoryShare(id: string) {\n    return this.mutate(this.deleteDirectoryShareMutation(id));\n  }\n\n  async deleteDirectoryShareMutation(id: string) {\n    return new LrMutation({\n      mutation: DeleteDirectoryShareMutation,\n      variables: {\n        input: {\n          id,\n        },\n      },\n    });\n  }\n\n  async deleteFileShare(id: string) {\n    return this.mutate(this.deleteFileShareMutation(id));\n  }\n\n  async deleteFileShareMutation(id: string) {\n    return new LrMutation({\n      mutation: DeleteFileShareMutation,\n      variables: {\n        input: {\n          id,\n        },\n      },\n    });\n  }\n\n  async completeDetachedDirectoryShare(\n    options: CompleteDetachedItemShareOptions\n  ) {\n    return this.mutate(this.completeDetachedDirectoryShareMutation(options));\n  }\n\n  async completeDetachedDirectoryShareMutation(\n    options: CompleteDetachedItemShareOptions\n  ) {\n    return new LrMutation({\n      mutation: CompleteDetachedDirectoryShareMutation,\n      variables: await this.prepareCompleteDetachedItemShareMutation({\n        ...options,\n        isDirectory: true,\n      }),\n    });\n  }\n\n  async completeDetachedFileShare(options: CompleteDetachedItemShareOptions) {\n    return this.mutate(this.completeDetachedFileShareMutation(options));\n  }\n\n  async completeDetachedFileShareMutation(\n    options: CompleteDetachedItemShareOptions\n  ) {\n    return new LrMutation({\n      mutation: CompleteDetachedFileShareMutation,\n      variables: await this.prepareCompleteDetachedItemShareMutation({\n        ...options,\n        isDirectory: false,\n      }),\n    });\n  }\n\n  private async prepareCompleteDetachedItemShareMutation(\n    options: CompleteDetachedItemShareOptions & { isDirectory: boolean }\n  ) {\n    const { itemShareId, itemKeyId, isDirectory } = options;\n\n    const itemKey = await this.keyGraph.getKey(itemKeyId, () =>\n      isDirectory\n        ? this.itemService.getDirectoryKeyIdFromDirectoryShare(itemShareId)\n        : this.itemService.getFileKeyIdFromFileShare(itemShareId)\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: itemShareId,\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"]}
|
|
@@ -279,6 +279,18 @@ function getAccessJwtToken(auth) {
|
|
|
279
279
|
}
|
|
280
280
|
});
|
|
281
281
|
}
|
|
282
|
+
function assert_xor(options) {
|
|
283
|
+
const keys = Object.keys(options);
|
|
284
|
+
if (keys.length != 2) {
|
|
285
|
+
throw new KcBadLogicException('You must provide exactly 2 fields in the argument.');
|
|
286
|
+
}
|
|
287
|
+
if (options[keys[0]] != null && options[keys[1]] != null) {
|
|
288
|
+
throw new KcBadLogicException(`You can not specify both ${keys[0]} and ${keys[1]}`);
|
|
289
|
+
}
|
|
290
|
+
if (options[keys[0]] == null && options[keys[1]] == null) {
|
|
291
|
+
throw new KcBadLogicException(`You must specify either ${keys[0]} and ${keys[1]}`);
|
|
292
|
+
}
|
|
293
|
+
}
|
|
282
294
|
|
|
283
295
|
// Ref: https://stackoverflow.com/questions/59735280/angular-8-moment-error-cannot-call-a-namespace-moment
|
|
284
296
|
const moment = moment_;
|
|
@@ -2844,6 +2856,7 @@ var LinkTypeField;
|
|
|
2844
2856
|
(function (LinkTypeField) {
|
|
2845
2857
|
LinkTypeField["HARD"] = "HARD";
|
|
2846
2858
|
LinkTypeField["SOFT"] = "SOFT";
|
|
2859
|
+
LinkTypeField["REFERENCE"] = "REFERENCE";
|
|
2847
2860
|
})(LinkTypeField || (LinkTypeField = {}));
|
|
2848
2861
|
var PlanStateField;
|
|
2849
2862
|
(function (PlanStateField) {
|
|
@@ -6452,15 +6465,27 @@ let ItemService = ItemService_1 = class ItemService extends LrService {
|
|
|
6452
6465
|
// ------------------------------------------------------------------------------
|
|
6453
6466
|
prepareParentDirectory(options, newKey) {
|
|
6454
6467
|
return __awaiter(this, void 0, void 0, function* () {
|
|
6455
|
-
|
|
6456
|
-
|
|
6457
|
-
|
|
6458
|
-
|
|
6459
|
-
|
|
6460
|
-
|
|
6461
|
-
|
|
6462
|
-
|
|
6463
|
-
|
|
6468
|
+
const { directoryId, linkType, wrappingKeyId } = options;
|
|
6469
|
+
if (linkType == LinkTypeField.REFERENCE) {
|
|
6470
|
+
if (wrappingKeyId) {
|
|
6471
|
+
throw new KcBadArgumentException('Do not specify wrappingKeyId when link type is REFERENCE.');
|
|
6472
|
+
}
|
|
6473
|
+
return {
|
|
6474
|
+
directoryId,
|
|
6475
|
+
linkType,
|
|
6476
|
+
};
|
|
6477
|
+
}
|
|
6478
|
+
else {
|
|
6479
|
+
// If directory's key is not already in the key graph, then need to
|
|
6480
|
+
// fetch the directory's key.
|
|
6481
|
+
const wrappingKey = yield this.getDirectoryKey(directoryId, wrappingKeyId);
|
|
6482
|
+
return {
|
|
6483
|
+
directoryId,
|
|
6484
|
+
wrappingKeyId: wrappingKey.id,
|
|
6485
|
+
wrappedKey: yield this.keyGraph.wrapKey(wrappingKey, newKey),
|
|
6486
|
+
linkType,
|
|
6487
|
+
};
|
|
6488
|
+
}
|
|
6464
6489
|
});
|
|
6465
6490
|
}
|
|
6466
6491
|
getFileStateKeyId(fileStateNodeId) {
|
|
@@ -6550,16 +6575,7 @@ let ItemService = ItemService_1 = class ItemService extends LrService {
|
|
|
6550
6575
|
prepareCreateFile(options) {
|
|
6551
6576
|
return __awaiter(this, void 0, void 0, function* () {
|
|
6552
6577
|
const fileKey = yield this.keyFactory.createKey();
|
|
6553
|
-
const parentDirectories = yield Promise.all(options.parentDirectories.map((t) =>
|
|
6554
|
-
const { directoryId, wrappingKeyId, wrappedKey } = yield this.prepareParentDirectory(t, fileKey);
|
|
6555
|
-
// remap from ParentDirectoryInput to FileParentDirectoryInput
|
|
6556
|
-
// TODO the server should really just use wrappedKey instead of wrappedFileKey
|
|
6557
|
-
return {
|
|
6558
|
-
directoryId,
|
|
6559
|
-
wrappingKeyId,
|
|
6560
|
-
wrappedFileKey: wrappedKey,
|
|
6561
|
-
};
|
|
6562
|
-
})));
|
|
6578
|
+
const parentDirectories = yield Promise.all(options.parentDirectories.map((t) => this.prepareParentDirectory(t, fileKey)));
|
|
6563
6579
|
const input = yield this.prepareCreateFileState(fileKey, options);
|
|
6564
6580
|
return Object.assign(Object.assign({}, input), { parentDirectories });
|
|
6565
6581
|
});
|
|
@@ -8579,6 +8595,9 @@ query ScenarioQuery(
|
|
|
8579
8595
|
id
|
|
8580
8596
|
}
|
|
8581
8597
|
accessRole
|
|
8598
|
+
|
|
8599
|
+
# The itemKey is the same as directory.keyId. It's here so we can detect
|
|
8600
|
+
# when the directory key has been rotated.
|
|
8582
8601
|
itemKey {
|
|
8583
8602
|
id
|
|
8584
8603
|
}
|
|
@@ -8598,9 +8617,16 @@ query ScenarioQuery(
|
|
|
8598
8617
|
id
|
|
8599
8618
|
}
|
|
8600
8619
|
accessRole
|
|
8620
|
+
|
|
8621
|
+
# The itemKey is the same as file.keyId. It's here so we can detect
|
|
8622
|
+
# when the file key has been rotated.
|
|
8601
8623
|
itemKey {
|
|
8602
8624
|
id
|
|
8603
8625
|
}
|
|
8626
|
+
file {
|
|
8627
|
+
id
|
|
8628
|
+
keyId
|
|
8629
|
+
}
|
|
8604
8630
|
}
|
|
8605
8631
|
}
|
|
8606
8632
|
}
|
|
@@ -8722,6 +8748,8 @@ let ScenarioService = class ScenarioService extends LrService {
|
|
|
8722
8748
|
this.encryptionService = encryptionService;
|
|
8723
8749
|
this.prepareAddReceiverDirectory = this.prepareReceiverDirectory;
|
|
8724
8750
|
this.prepareUpdateReceiverDirectory = this.prepareReceiverDirectory;
|
|
8751
|
+
this.prepareAddReceiverFile = this.prepareReceiverFile;
|
|
8752
|
+
this.prepareUpdateReceiverFile = this.prepareReceiverFile;
|
|
8725
8753
|
}
|
|
8726
8754
|
// Scenarios
|
|
8727
8755
|
createScenario(options) {
|
|
@@ -9014,38 +9042,86 @@ let ScenarioService = class ScenarioService extends LrService {
|
|
|
9014
9042
|
};
|
|
9015
9043
|
});
|
|
9016
9044
|
}
|
|
9017
|
-
|
|
9045
|
+
prepareReceiverItem(options) {
|
|
9018
9046
|
return __awaiter(this, void 0, void 0, function* () {
|
|
9019
|
-
|
|
9020
|
-
|
|
9021
|
-
|
|
9022
|
-
|
|
9023
|
-
|
|
9047
|
+
const { receiverItemOptions, receiverSharedKey, assemblyKey, directory, file, } = options;
|
|
9048
|
+
assert_xor({ directory, file });
|
|
9049
|
+
const { accessRole } = receiverItemOptions;
|
|
9050
|
+
if (accessRole == AccessRoleChoice.DENY) {
|
|
9051
|
+
const ret = {
|
|
9052
|
+
accessRole,
|
|
9024
9053
|
wrappedItemKey: null,
|
|
9025
9054
|
sharedCipherData: null,
|
|
9026
9055
|
};
|
|
9056
|
+
if (directory) {
|
|
9057
|
+
// Cryptographic access to item is not required.
|
|
9058
|
+
return Object.assign(Object.assign({}, ret), { directoryId: directory.id });
|
|
9059
|
+
}
|
|
9060
|
+
else {
|
|
9061
|
+
return Object.assign(Object.assign({}, ret), { fileId: file.id });
|
|
9062
|
+
}
|
|
9027
9063
|
}
|
|
9028
9064
|
else {
|
|
9029
9065
|
// TODO this should be batched
|
|
9030
|
-
|
|
9031
|
-
|
|
9032
|
-
|
|
9066
|
+
let itemKey;
|
|
9067
|
+
if (directory) {
|
|
9068
|
+
itemKey = yield this.itemService.getDirectoryKey(directory.id, directory.keyId);
|
|
9069
|
+
}
|
|
9070
|
+
else {
|
|
9071
|
+
itemKey = yield this.itemService.getFileKey(file.id, file.keyId);
|
|
9072
|
+
}
|
|
9073
|
+
let wrappedItemKey = yield this.keyGraph.encryptToString(receiverSharedKey, itemKey.jwk.toJSON(true));
|
|
9074
|
+
const sharedCipherData = yield this.keyGraph.encryptToString(receiverSharedKey, receiverItemOptions.sharedCipherDataClearJson || '');
|
|
9033
9075
|
wrappedItemKey = yield this.keyGraph.encryptToString(assemblyKey, wrappedItemKey);
|
|
9034
|
-
|
|
9035
|
-
|
|
9036
|
-
accessRole: options.accessRole,
|
|
9076
|
+
const ret = {
|
|
9077
|
+
accessRole,
|
|
9037
9078
|
wrappedItemKey,
|
|
9038
9079
|
sharedCipherData,
|
|
9039
9080
|
};
|
|
9081
|
+
if (directory) {
|
|
9082
|
+
return Object.assign(Object.assign({}, ret), { directoryId: directory.id });
|
|
9083
|
+
}
|
|
9084
|
+
else {
|
|
9085
|
+
return Object.assign(Object.assign({}, ret), { fileId: file.id });
|
|
9086
|
+
}
|
|
9040
9087
|
}
|
|
9041
9088
|
});
|
|
9042
9089
|
}
|
|
9090
|
+
prepareReceiverDirectory(options, receiverSharedKey, assemblyKey) {
|
|
9091
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
9092
|
+
return this.prepareReceiverItem({
|
|
9093
|
+
receiverItemOptions: options,
|
|
9094
|
+
receiverSharedKey,
|
|
9095
|
+
assemblyKey,
|
|
9096
|
+
directory: {
|
|
9097
|
+
id: options.directoryId,
|
|
9098
|
+
keyId: options.directoryKeyId,
|
|
9099
|
+
},
|
|
9100
|
+
});
|
|
9101
|
+
});
|
|
9102
|
+
}
|
|
9103
|
+
prepareReceiverFile(options, receiverSharedKey, assemblyKey) {
|
|
9104
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
9105
|
+
return this.prepareReceiverItem({
|
|
9106
|
+
receiverItemOptions: options,
|
|
9107
|
+
receiverSharedKey,
|
|
9108
|
+
assemblyKey,
|
|
9109
|
+
file: {
|
|
9110
|
+
id: options.fileId,
|
|
9111
|
+
keyId: options.fileKeyId,
|
|
9112
|
+
},
|
|
9113
|
+
});
|
|
9114
|
+
});
|
|
9115
|
+
}
|
|
9043
9116
|
prepareCreateReceiver(options, assemblyKey) {
|
|
9044
9117
|
return __awaiter(this, void 0, void 0, function* () {
|
|
9045
9118
|
const { sharedKey, mutationInput } = yield this.prepareCreateParticipant(options);
|
|
9046
9119
|
const addDirectories = options.addDirectories &&
|
|
9047
9120
|
(yield Promise.all(options.addDirectories.map((x) => this.prepareAddReceiverDirectory(x, sharedKey.key, assemblyKey))));
|
|
9048
|
-
|
|
9121
|
+
const addFiles = options.addFiles &&
|
|
9122
|
+
(yield Promise.all(options.addFiles.map((x) => this.prepareAddReceiverFile(x, sharedKey.key, assemblyKey))));
|
|
9123
|
+
return Object.assign(Object.assign({}, mutationInput), { addDirectories,
|
|
9124
|
+
addFiles });
|
|
9049
9125
|
});
|
|
9050
9126
|
}
|
|
9051
9127
|
prepareUpdateReceiver(options, assemblyKey, existingReceiver) {
|
|
@@ -9053,6 +9129,8 @@ let ScenarioService = class ScenarioService extends LrService {
|
|
|
9053
9129
|
const sharedKeyId = existingReceiver.sharedKey.id;
|
|
9054
9130
|
const deleteDirectoriesOptions = options.deleteDirectories || [];
|
|
9055
9131
|
const updateDirectoriesOptions = options.updateDirectories || [];
|
|
9132
|
+
const deleteFilesOptions = options.deleteFiles || [];
|
|
9133
|
+
const updateFilesOptions = options.updateFiles || [];
|
|
9056
9134
|
// Fill in any missing update directories
|
|
9057
9135
|
mapEdges(existingReceiver.receiverItems.receiverDirectories).forEach((existingDirectory) => {
|
|
9058
9136
|
if (deleteDirectoriesOptions.includes(existingDirectory.directory.id)) {
|
|
@@ -9064,30 +9142,58 @@ let ScenarioService = class ScenarioService extends LrService {
|
|
|
9064
9142
|
updateDirectoriesOptions.push({
|
|
9065
9143
|
accessRole: existingDirectory.accessRole,
|
|
9066
9144
|
directoryId: existingDirectory.directory.id,
|
|
9145
|
+
directoryKeyId: existingDirectory.directory.keyId,
|
|
9067
9146
|
sharedCipherDataClearJson: existingDirectory.sharedCipherDataClearJson,
|
|
9068
9147
|
});
|
|
9069
9148
|
});
|
|
9149
|
+
// Fill in any missing update directories
|
|
9150
|
+
mapEdges(existingReceiver.receiverItems.receiverFiles).forEach((existingFile) => {
|
|
9151
|
+
if (deleteFilesOptions.includes(existingFile.file.id)) {
|
|
9152
|
+
return;
|
|
9153
|
+
}
|
|
9154
|
+
if (updateFilesOptions.find((x) => x.fileId === existingFile.file.id)) {
|
|
9155
|
+
return;
|
|
9156
|
+
}
|
|
9157
|
+
updateFilesOptions.push({
|
|
9158
|
+
accessRole: existingFile.accessRole,
|
|
9159
|
+
fileId: existingFile.file.id,
|
|
9160
|
+
fileKeyId: existingFile.file.keyId,
|
|
9161
|
+
sharedCipherDataClearJson: existingFile.sharedCipherDataClearJson,
|
|
9162
|
+
});
|
|
9163
|
+
});
|
|
9070
9164
|
const { sharedKey, mutationInput } = yield this.prepareUpdateParticipant(options, sharedKeyId);
|
|
9071
9165
|
const addDirectories = options.addDirectories &&
|
|
9072
9166
|
(yield Promise.all(options.addDirectories.map((x) => this.prepareAddReceiverDirectory(x, sharedKey, assemblyKey))));
|
|
9167
|
+
const addFiles = options.addFiles &&
|
|
9168
|
+
(yield Promise.all(options.addFiles.map((x) => this.prepareAddReceiverFile(x, sharedKey, assemblyKey))));
|
|
9073
9169
|
const updateDirectories = yield Promise.all(updateDirectoriesOptions.map((x) => this.prepareUpdateReceiverDirectory(x, sharedKey, assemblyKey)));
|
|
9170
|
+
const updateFiles = yield Promise.all(updateFilesOptions.map((x) => this.prepareUpdateReceiverFile(x, sharedKey, assemblyKey)));
|
|
9074
9171
|
return Object.assign(Object.assign({}, mutationInput), { addDirectories,
|
|
9075
|
-
|
|
9172
|
+
addFiles,
|
|
9173
|
+
updateDirectories,
|
|
9174
|
+
updateFiles, deleteDirectories: options.deleteDirectories, deleteFiles: options.deleteFiles });
|
|
9076
9175
|
});
|
|
9077
9176
|
}
|
|
9078
9177
|
prepareExistingReceiver(existingReceiver, assemblyKey) {
|
|
9079
9178
|
return __awaiter(this, void 0, void 0, function* () {
|
|
9080
|
-
const updateDirectories = mapEdges(existingReceiver.receiverItems.receiverDirectories).map((
|
|
9081
|
-
|
|
9082
|
-
|
|
9083
|
-
|
|
9084
|
-
|
|
9179
|
+
const updateDirectories = mapEdges(existingReceiver.receiverItems.receiverDirectories).map(({ accessRole, sharedCipherDataClearJson, directory }) => ({
|
|
9180
|
+
accessRole,
|
|
9181
|
+
sharedCipherDataClearJson,
|
|
9182
|
+
directoryId: directory.id,
|
|
9183
|
+
directoryKeyId: directory.keyId,
|
|
9184
|
+
}));
|
|
9185
|
+
const updateFiles = mapEdges(existingReceiver.receiverItems.receiverFiles).map(({ accessRole, sharedCipherDataClearJson, file }) => ({
|
|
9186
|
+
accessRole,
|
|
9187
|
+
sharedCipherDataClearJson,
|
|
9188
|
+
fileId: file.id,
|
|
9189
|
+
fileKeyId: file.keyId,
|
|
9085
9190
|
}));
|
|
9086
9191
|
// Fill it in with existing receiver.
|
|
9087
9192
|
return this.prepareUpdateReceiver({
|
|
9088
9193
|
tpId: existingReceiver.tp.id,
|
|
9089
9194
|
sharedCipherDataClearJson: existingReceiver.sharedCipherDataClearJson,
|
|
9090
9195
|
updateDirectories,
|
|
9196
|
+
updateFiles,
|
|
9091
9197
|
}, assemblyKey, existingReceiver);
|
|
9092
9198
|
});
|
|
9093
9199
|
}
|
|
@@ -10221,6 +10327,23 @@ let TrustedPartyService = class TrustedPartyService extends LrService {
|
|
|
10221
10327
|
});
|
|
10222
10328
|
});
|
|
10223
10329
|
}
|
|
10330
|
+
deleteFileShare(id) {
|
|
10331
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
10332
|
+
return this.mutate(this.deleteFileShareMutation(id));
|
|
10333
|
+
});
|
|
10334
|
+
}
|
|
10335
|
+
deleteFileShareMutation(id) {
|
|
10336
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
10337
|
+
return new LrMutation({
|
|
10338
|
+
mutation: DeleteFileShareMutation,
|
|
10339
|
+
variables: {
|
|
10340
|
+
input: {
|
|
10341
|
+
id,
|
|
10342
|
+
},
|
|
10343
|
+
},
|
|
10344
|
+
});
|
|
10345
|
+
});
|
|
10346
|
+
}
|
|
10224
10347
|
completeDetachedDirectoryShare(options) {
|
|
10225
10348
|
return __awaiter(this, void 0, void 0, function* () {
|
|
10226
10349
|
return this.mutate(this.completeDetachedDirectoryShareMutation(options));
|