@lifeready/core 8.0.12 → 8.0.13
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 +168 -25
- 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/scenario/scenario.service.js +3 -1
- package/esm2015/lib/trusted-party/trusted-party.gql.private.js +25 -1
- package/esm2015/lib/trusted-party/trusted-party.service.js +95 -15
- package/esm2015/lib/trusted-party/trusted-party.types.js +1 -1
- package/fesm2015/lifeready-core.js +117 -12
- package/fesm2015/lifeready-core.js.map +1 -1
- package/lib/scenario/scenario.service.d.ts +56 -0
- package/lib/trusted-party/trusted-party.gql.private.d.ts +16 -0
- package/lib/trusted-party/trusted-party.service.d.ts +55 -11
- package/lib/trusted-party/trusted-party.types.d.ts +6 -2
- package/lifeready-core.metadata.json +1 -1
- package/package.json +1 -1
|
@@ -2,15 +2,16 @@ import { __awaiter, __decorate } from "tslib";
|
|
|
2
2
|
import { Injectable, Injector, NgZone } from '@angular/core';
|
|
3
3
|
import { JWK } from 'node-jose';
|
|
4
4
|
import { LrMutation, LrService } from '../api/lr-graphql';
|
|
5
|
+
import { AccessRoleChoice } from '../api/types';
|
|
5
6
|
import { EncryptionService } from '../encryption/encryption.service';
|
|
6
7
|
import { ItemService } from '../item/item.service';
|
|
7
8
|
import { KeyFactoryService } from '../key/key-factory.service';
|
|
8
9
|
import { KeyGraphService } from '../key/key-graph.service';
|
|
9
10
|
import { KeyService } from '../key/key.service';
|
|
10
|
-
import { KcBadStateException } from '../_common/exceptions';
|
|
11
|
+
import { KcBadArgumentException, KcBadStateException, } from '../_common/exceptions';
|
|
11
12
|
import { RunOutsideAngular } from '../_common/run-outside-angular';
|
|
12
13
|
import { CompleteDetachedDirectoryShareMutation, CompleteDetachedFileShareMutation, CompleteTpMkReshareMutation, CreateDirectoryShareMutation, CreateFileShareMutation, DeleteDirectoryShareMutation, DeleteFileShareMutation, DeleteTpMutation, RequestTpMkReshareMutation, RespondTpMkReshareMutation, UpdateDirectoryShareMutation, UpdateFileShareMutation, } from './trusted-party.gql';
|
|
13
|
-
import { TpCurrentUserSharedKeyQuery } from './trusted-party.gql.private';
|
|
14
|
+
import { DirectoryShareQuery, FileShareQuery, TpCurrentUserSharedKeyQuery, } from './trusted-party.gql.private';
|
|
14
15
|
import * as i0 from "@angular/core";
|
|
15
16
|
import * as i1 from "../key/key-graph.service";
|
|
16
17
|
import * as i2 from "../item/item.service";
|
|
@@ -70,19 +71,35 @@ let TrustedPartyService = class TrustedPartyService extends LrService {
|
|
|
70
71
|
prepareCreateItemShareMutation(options) {
|
|
71
72
|
return __awaiter(this, void 0, void 0, function* () {
|
|
72
73
|
const { itemId, itemKeyId, tpId, tpSharedKeyId, accessRole, isDirectory, shareType, } = options;
|
|
74
|
+
if (accessRole == AccessRoleChoice.DENY) {
|
|
75
|
+
if (itemKeyId || tpSharedKeyId) {
|
|
76
|
+
throw new KcBadArgumentException('If accessRole is AccessRoleChoice.DENY, must not specify any of itemId, itemKeyId, or tpSharedKeyId parameters');
|
|
77
|
+
}
|
|
78
|
+
return {
|
|
79
|
+
input: {
|
|
80
|
+
itemId,
|
|
81
|
+
tpId,
|
|
82
|
+
accessRole,
|
|
83
|
+
itemKeyId: null,
|
|
84
|
+
wrappingKeyId: null,
|
|
85
|
+
wrappedItemKey: null,
|
|
86
|
+
shareType,
|
|
87
|
+
},
|
|
88
|
+
};
|
|
89
|
+
}
|
|
73
90
|
const itemKey = yield this.keyGraph.getKey(itemKeyId, () => isDirectory
|
|
74
91
|
? this.itemService.getDirectoryKeyId(itemId)
|
|
75
92
|
: this.itemService.getFileKeyId(itemId));
|
|
76
93
|
const wrappingKey = yield this.keyGraph.getKey(tpSharedKeyId, () => this.getTpCurrentUserSharedKey(tpId).then((res) => res.sharedKey.id));
|
|
77
|
-
const
|
|
94
|
+
const wrappedItemKey = yield this.keyGraph.wrapKey(wrappingKey, itemKey.jwk);
|
|
78
95
|
return {
|
|
79
96
|
input: {
|
|
80
|
-
|
|
97
|
+
itemId,
|
|
81
98
|
tpId,
|
|
82
99
|
accessRole,
|
|
83
|
-
|
|
100
|
+
itemKeyId: itemKey.id,
|
|
84
101
|
wrappingKeyId: wrappingKey.id,
|
|
85
|
-
|
|
102
|
+
wrappedItemKey,
|
|
86
103
|
shareType,
|
|
87
104
|
},
|
|
88
105
|
};
|
|
@@ -97,7 +114,7 @@ let TrustedPartyService = class TrustedPartyService extends LrService {
|
|
|
97
114
|
return __awaiter(this, void 0, void 0, function* () {
|
|
98
115
|
return new LrMutation({
|
|
99
116
|
mutation: UpdateDirectoryShareMutation,
|
|
100
|
-
variables: this.prepareUpdateItemShareMutation(options),
|
|
117
|
+
variables: yield this.prepareUpdateItemShareMutation(Object.assign(Object.assign({}, options), { isDirectory: true })),
|
|
101
118
|
});
|
|
102
119
|
});
|
|
103
120
|
}
|
|
@@ -110,18 +127,81 @@ let TrustedPartyService = class TrustedPartyService extends LrService {
|
|
|
110
127
|
return __awaiter(this, void 0, void 0, function* () {
|
|
111
128
|
return new LrMutation({
|
|
112
129
|
mutation: UpdateFileShareMutation,
|
|
113
|
-
variables: this.prepareUpdateItemShareMutation(options),
|
|
130
|
+
variables: yield this.prepareUpdateItemShareMutation(Object.assign(Object.assign({}, options), { isDirectory: false })),
|
|
114
131
|
});
|
|
115
132
|
});
|
|
116
133
|
}
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
134
|
+
getDirectoryShare(itemShareId) {
|
|
135
|
+
return this.lrGraphQL.query({
|
|
136
|
+
query: DirectoryShareQuery,
|
|
137
|
+
variables: {
|
|
121
138
|
id: itemShareId,
|
|
122
|
-
accessRole,
|
|
123
139
|
},
|
|
124
|
-
};
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
getFileShare(itemShareId) {
|
|
143
|
+
return this.lrGraphQL.query({
|
|
144
|
+
query: FileShareQuery,
|
|
145
|
+
variables: {
|
|
146
|
+
id: itemShareId,
|
|
147
|
+
},
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
prepareUpdateItemShareMutation(options) {
|
|
151
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
152
|
+
const { itemShareId, accessRole, isDirectory, itemId, itemKeyId, tpId, tpSharedKeyId, } = options;
|
|
153
|
+
if (accessRole == AccessRoleChoice.DENY) {
|
|
154
|
+
if (itemId || itemKeyId || tpId || tpSharedKeyId) {
|
|
155
|
+
throw new KcBadArgumentException('If accessRole is AccessRoleChoice.DENY, must not specify any of itemId, itemKeyId, tpId, or tpSharedKeyId parameters');
|
|
156
|
+
}
|
|
157
|
+
return {
|
|
158
|
+
input: {
|
|
159
|
+
id: itemShareId,
|
|
160
|
+
accessRole,
|
|
161
|
+
itemKeyId: null,
|
|
162
|
+
wrappingKeyId: null,
|
|
163
|
+
wrappedItemKey: null,
|
|
164
|
+
},
|
|
165
|
+
};
|
|
166
|
+
}
|
|
167
|
+
// Caching the result so we only need one call.
|
|
168
|
+
let itemShare;
|
|
169
|
+
const getItemShare = () => __awaiter(this, void 0, void 0, function* () {
|
|
170
|
+
if (!itemShare) {
|
|
171
|
+
if (isDirectory) {
|
|
172
|
+
itemShare = (yield this.getDirectoryShare(itemShareId))
|
|
173
|
+
.directoryShare;
|
|
174
|
+
}
|
|
175
|
+
else {
|
|
176
|
+
itemShare = (yield this.getFileShare(itemShareId)).fileShare;
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
return itemShare;
|
|
180
|
+
});
|
|
181
|
+
const itemKey = yield this.keyGraph.getKey(itemKeyId, () => __awaiter(this, void 0, void 0, function* () {
|
|
182
|
+
const itemId_ = itemId || (yield getItemShare()).item.id;
|
|
183
|
+
if (isDirectory) {
|
|
184
|
+
return this.itemService.getDirectoryKeyId(itemId_);
|
|
185
|
+
}
|
|
186
|
+
else {
|
|
187
|
+
return this.itemService.getFileKeyId(itemId_);
|
|
188
|
+
}
|
|
189
|
+
}));
|
|
190
|
+
const wrappingKey = yield this.keyGraph.getKey(tpSharedKeyId, () => __awaiter(this, void 0, void 0, function* () {
|
|
191
|
+
const tpId_ = tpId || (yield getItemShare()).tp.id;
|
|
192
|
+
return (yield this.getTpCurrentUserSharedKey(tpId_)).sharedKey.id;
|
|
193
|
+
}));
|
|
194
|
+
const wrappedItemKey = yield this.keyGraph.wrapKey(wrappingKey, itemKey.jwk);
|
|
195
|
+
return {
|
|
196
|
+
input: {
|
|
197
|
+
id: itemShareId,
|
|
198
|
+
accessRole,
|
|
199
|
+
itemKeyId: itemKey.id,
|
|
200
|
+
wrappingKeyId: wrappingKey.id,
|
|
201
|
+
wrappedItemKey,
|
|
202
|
+
},
|
|
203
|
+
};
|
|
204
|
+
});
|
|
125
205
|
}
|
|
126
206
|
deleteDirectoryShare(id) {
|
|
127
207
|
return __awaiter(this, void 0, void 0, function* () {
|
|
@@ -322,4 +402,4 @@ TrustedPartyService = __decorate([
|
|
|
322
402
|
})
|
|
323
403
|
], TrustedPartyService);
|
|
324
404
|
export { TrustedPartyService };
|
|
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"]}
|
|
405
|
+
//# 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 { AccessRoleChoice, 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 {\n  KcBadArgumentException,\n  KcBadStateException,\n} 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 {\n  DirectoryShareQuery,\n  DirectoryShareQueryResult,\n  FileShareQuery,\n  FileShareQueryResult,\n  ItemShareQueryResult,\n  TpCurrentUserSharedKeyQuery,\n} 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    if (accessRole == AccessRoleChoice.DENY) {\n      if (itemKeyId || tpSharedKeyId) {\n        throw new KcBadArgumentException(\n          'If accessRole is AccessRoleChoice.DENY, must not specify any of itemId, itemKeyId, or tpSharedKeyId parameters'\n        );\n      }\n\n      return {\n        input: {\n          itemId,\n          tpId,\n          accessRole,\n          itemKeyId: null,\n          wrappingKeyId: null,\n          wrappedItemKey: null,\n          shareType,\n        },\n      };\n    }\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 wrappedItemKey = await this.keyGraph.wrapKey(\n      wrappingKey,\n      itemKey.jwk\n    );\n\n    return {\n      input: {\n        itemId,\n        tpId,\n        accessRole,\n        itemKeyId: itemKey.id,\n        wrappingKeyId: wrappingKey.id,\n        wrappedItemKey,\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: await this.prepareUpdateItemShareMutation({\n        ...options,\n        isDirectory: true,\n      }),\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: await this.prepareUpdateItemShareMutation({\n        ...options,\n        isDirectory: false,\n      }),\n    });\n  }\n\n  private getDirectoryShare(\n    itemShareId: string\n  ): Promise<DirectoryShareQueryResult> {\n    return this.lrGraphQL.query({\n      query: DirectoryShareQuery,\n      variables: {\n        id: itemShareId,\n      },\n    });\n  }\n\n  private getFileShare(itemShareId: string): Promise<FileShareQueryResult> {\n    return this.lrGraphQL.query({\n      query: FileShareQuery,\n      variables: {\n        id: itemShareId,\n      },\n    });\n  }\n\n  private async prepareUpdateItemShareMutation(\n    options: UpdateItemShareOptions & { isDirectory: boolean }\n  ) {\n    const {\n      itemShareId,\n      accessRole,\n      isDirectory,\n      itemId,\n      itemKeyId,\n      tpId,\n      tpSharedKeyId,\n    } = options;\n\n    if (accessRole == AccessRoleChoice.DENY) {\n      if (itemId || itemKeyId || tpId || tpSharedKeyId) {\n        throw new KcBadArgumentException(\n          'If accessRole is AccessRoleChoice.DENY, must not specify any of itemId, itemKeyId, tpId, or tpSharedKeyId parameters'\n        );\n      }\n\n      return {\n        input: {\n          id: itemShareId,\n          accessRole,\n          itemKeyId: null,\n          wrappingKeyId: null,\n          wrappedItemKey: null,\n        },\n      };\n    }\n\n    // Caching the result so we only need one call.\n    let itemShare: ItemShareQueryResult;\n\n    const getItemShare = async (): Promise<ItemShareQueryResult> => {\n      if (!itemShare) {\n        if (isDirectory) {\n          itemShare = (await this.getDirectoryShare(itemShareId))\n            .directoryShare;\n        } else {\n          itemShare = (await this.getFileShare(itemShareId)).fileShare;\n        }\n      }\n\n      return itemShare;\n    };\n\n    const itemKey = await this.keyGraph.getKey(\n      itemKeyId,\n      async (): Promise<string> => {\n        const itemId_ = itemId || (await getItemShare()).item.id;\n        if (isDirectory) {\n          return this.itemService.getDirectoryKeyId(itemId_);\n        } else {\n          return this.itemService.getFileKeyId(itemId_);\n        }\n      }\n    );\n\n    const wrappingKey = await this.keyGraph.getKey(\n      tpSharedKeyId,\n      async (): Promise<string> => {\n        const tpId_ = tpId || (await getItemShare()).tp.id;\n        return (await this.getTpCurrentUserSharedKey(tpId_)).sharedKey.id;\n      }\n    );\n\n    const wrappedItemKey = await this.keyGraph.wrapKey(\n      wrappingKey,\n      itemKey.jwk\n    );\n\n    return {\n      input: {\n        id: itemShareId,\n        accessRole,\n        itemKeyId: itemKey.id,\n        wrappingKeyId: wrappingKey.id,\n        wrappedItemKey,\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"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1c3RlZC1wYXJ0eS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi90cnVzdGVkLXBhcnR5L3RydXN0ZWQtcGFydHkudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFjY2Vzc1JvbGVDaG9pY2UsXG4gIExyUmVsYXlJZElucHV0LFxuICBTaGFyZVR5cGVDaG9pY2UsXG59IGZyb20gJy4uL2FwaS90eXBlcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ3JlYXRlSXRlbVNoYXJlT3B0aW9ucyB7XG4gIGl0ZW1JZDogTHJSZWxheUlkSW5wdXQ7XG4gIHRwSWQ6IExyUmVsYXlJZElucHV0O1xuICBhY2Nlc3NSb2xlOiBBY2Nlc3NSb2xlQ2hvaWNlO1xuICBzaGFyZVR5cGU6IFNoYXJlVHlwZUNob2ljZTtcbiAgLy8gT3B0aW9uYWwgdG8gaW1wcm92ZSBlZmZpY2llbmN5XG4gIGl0ZW1LZXlJZD86IExyUmVsYXlJZElucHV0O1xuICB0cFNoYXJlZEtleUlkPzogTHJSZWxheUlkSW5wdXQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVXBkYXRlSXRlbVNoYXJlT3B0aW9ucyB7XG4gIGl0ZW1TaGFyZUlkOiBMclJlbGF5SWRJbnB1dDtcbiAgYWNjZXNzUm9sZTogQWNjZXNzUm9sZUNob2ljZTtcbiAgLy8gT3B0aW9uYWwgdG8gaW1wcm92ZSBlZmZpY2llbmN5XG4gIGl0ZW1JZD86IExyUmVsYXlJZElucHV0O1xuICBpdGVtS2V5SWQ/OiBMclJlbGF5SWRJbnB1dDtcbiAgdHBJZD86IExyUmVsYXlJZElucHV0O1xuICB0cFNoYXJlZEtleUlkPzogTHJSZWxheUlkSW5wdXQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29tcGxldGVEZXRhY2hlZEl0ZW1TaGFyZU9wdGlvbnMge1xuICBpdGVtU2hhcmVJZDogTHJSZWxheUlkSW5wdXQ7XG4gIC8vIE9wdGlvbmFsIHRvIGltcHJvdmUgZWZmaWNpZW5jeVxuICBpdGVtS2V5SWQ/OiBMclJlbGF5SWRJbnB1dDtcbn1cbiJdfQ==
|
|
@@ -9118,6 +9118,7 @@ let ScenarioService = class ScenarioService extends LrService {
|
|
|
9118
9118
|
if (accessRole == AccessRoleChoice.DENY) {
|
|
9119
9119
|
const ret = {
|
|
9120
9120
|
accessRole,
|
|
9121
|
+
itemKeyId: null,
|
|
9121
9122
|
wrappedItemKey: null,
|
|
9122
9123
|
sharedCipherData: null,
|
|
9123
9124
|
};
|
|
@@ -9143,6 +9144,7 @@ let ScenarioService = class ScenarioService extends LrService {
|
|
|
9143
9144
|
wrappedItemKey = yield this.keyGraph.encryptToString(assemblyKey, wrappedItemKey);
|
|
9144
9145
|
const ret = {
|
|
9145
9146
|
accessRole,
|
|
9147
|
+
itemKeyId: itemKey.id,
|
|
9146
9148
|
wrappedItemKey,
|
|
9147
9149
|
sharedCipherData,
|
|
9148
9150
|
};
|
|
@@ -10278,6 +10280,30 @@ query TpCurrentUserSharedKeyQuery($id: LrRelayIdInput!) {
|
|
|
10278
10280
|
}
|
|
10279
10281
|
}
|
|
10280
10282
|
`;
|
|
10283
|
+
const DirectoryShareQuery = gqlTyped `
|
|
10284
|
+
query DirectoryShareQuery($id: LrRelayIdInput!) {
|
|
10285
|
+
directoryShare(id: $id) {
|
|
10286
|
+
item {
|
|
10287
|
+
id
|
|
10288
|
+
}
|
|
10289
|
+
tp {
|
|
10290
|
+
id
|
|
10291
|
+
}
|
|
10292
|
+
}
|
|
10293
|
+
}
|
|
10294
|
+
`;
|
|
10295
|
+
const FileShareQuery = gqlTyped `
|
|
10296
|
+
query FileShareItemIdQuery($id: LrRelayIdInput!) {
|
|
10297
|
+
fileShare(id: $id) {
|
|
10298
|
+
item {
|
|
10299
|
+
id
|
|
10300
|
+
}
|
|
10301
|
+
tp {
|
|
10302
|
+
id
|
|
10303
|
+
}
|
|
10304
|
+
}
|
|
10305
|
+
}
|
|
10306
|
+
`;
|
|
10281
10307
|
|
|
10282
10308
|
let TrustedPartyService = class TrustedPartyService extends LrService {
|
|
10283
10309
|
constructor(ngZone, injector, keyGraph, itemService, keyService, keyFactory, encryptionService) {
|
|
@@ -10332,19 +10358,35 @@ let TrustedPartyService = class TrustedPartyService extends LrService {
|
|
|
10332
10358
|
prepareCreateItemShareMutation(options) {
|
|
10333
10359
|
return __awaiter(this, void 0, void 0, function* () {
|
|
10334
10360
|
const { itemId, itemKeyId, tpId, tpSharedKeyId, accessRole, isDirectory, shareType, } = options;
|
|
10361
|
+
if (accessRole == AccessRoleChoice.DENY) {
|
|
10362
|
+
if (itemKeyId || tpSharedKeyId) {
|
|
10363
|
+
throw new KcBadArgumentException('If accessRole is AccessRoleChoice.DENY, must not specify any of itemId, itemKeyId, or tpSharedKeyId parameters');
|
|
10364
|
+
}
|
|
10365
|
+
return {
|
|
10366
|
+
input: {
|
|
10367
|
+
itemId,
|
|
10368
|
+
tpId,
|
|
10369
|
+
accessRole,
|
|
10370
|
+
itemKeyId: null,
|
|
10371
|
+
wrappingKeyId: null,
|
|
10372
|
+
wrappedItemKey: null,
|
|
10373
|
+
shareType,
|
|
10374
|
+
},
|
|
10375
|
+
};
|
|
10376
|
+
}
|
|
10335
10377
|
const itemKey = yield this.keyGraph.getKey(itemKeyId, () => isDirectory
|
|
10336
10378
|
? this.itemService.getDirectoryKeyId(itemId)
|
|
10337
10379
|
: this.itemService.getFileKeyId(itemId));
|
|
10338
10380
|
const wrappingKey = yield this.keyGraph.getKey(tpSharedKeyId, () => this.getTpCurrentUserSharedKey(tpId).then((res) => res.sharedKey.id));
|
|
10339
|
-
const
|
|
10381
|
+
const wrappedItemKey = yield this.keyGraph.wrapKey(wrappingKey, itemKey.jwk);
|
|
10340
10382
|
return {
|
|
10341
10383
|
input: {
|
|
10342
|
-
|
|
10384
|
+
itemId,
|
|
10343
10385
|
tpId,
|
|
10344
10386
|
accessRole,
|
|
10345
|
-
|
|
10387
|
+
itemKeyId: itemKey.id,
|
|
10346
10388
|
wrappingKeyId: wrappingKey.id,
|
|
10347
|
-
|
|
10389
|
+
wrappedItemKey,
|
|
10348
10390
|
shareType,
|
|
10349
10391
|
},
|
|
10350
10392
|
};
|
|
@@ -10359,7 +10401,7 @@ let TrustedPartyService = class TrustedPartyService extends LrService {
|
|
|
10359
10401
|
return __awaiter(this, void 0, void 0, function* () {
|
|
10360
10402
|
return new LrMutation({
|
|
10361
10403
|
mutation: UpdateDirectoryShareMutation,
|
|
10362
|
-
variables: this.prepareUpdateItemShareMutation(options),
|
|
10404
|
+
variables: yield this.prepareUpdateItemShareMutation(Object.assign(Object.assign({}, options), { isDirectory: true })),
|
|
10363
10405
|
});
|
|
10364
10406
|
});
|
|
10365
10407
|
}
|
|
@@ -10372,18 +10414,81 @@ let TrustedPartyService = class TrustedPartyService extends LrService {
|
|
|
10372
10414
|
return __awaiter(this, void 0, void 0, function* () {
|
|
10373
10415
|
return new LrMutation({
|
|
10374
10416
|
mutation: UpdateFileShareMutation,
|
|
10375
|
-
variables: this.prepareUpdateItemShareMutation(options),
|
|
10417
|
+
variables: yield this.prepareUpdateItemShareMutation(Object.assign(Object.assign({}, options), { isDirectory: false })),
|
|
10376
10418
|
});
|
|
10377
10419
|
});
|
|
10378
10420
|
}
|
|
10379
|
-
|
|
10380
|
-
|
|
10381
|
-
|
|
10382
|
-
|
|
10421
|
+
getDirectoryShare(itemShareId) {
|
|
10422
|
+
return this.lrGraphQL.query({
|
|
10423
|
+
query: DirectoryShareQuery,
|
|
10424
|
+
variables: {
|
|
10383
10425
|
id: itemShareId,
|
|
10384
|
-
accessRole,
|
|
10385
10426
|
},
|
|
10386
|
-
};
|
|
10427
|
+
});
|
|
10428
|
+
}
|
|
10429
|
+
getFileShare(itemShareId) {
|
|
10430
|
+
return this.lrGraphQL.query({
|
|
10431
|
+
query: FileShareQuery,
|
|
10432
|
+
variables: {
|
|
10433
|
+
id: itemShareId,
|
|
10434
|
+
},
|
|
10435
|
+
});
|
|
10436
|
+
}
|
|
10437
|
+
prepareUpdateItemShareMutation(options) {
|
|
10438
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
10439
|
+
const { itemShareId, accessRole, isDirectory, itemId, itemKeyId, tpId, tpSharedKeyId, } = options;
|
|
10440
|
+
if (accessRole == AccessRoleChoice.DENY) {
|
|
10441
|
+
if (itemId || itemKeyId || tpId || tpSharedKeyId) {
|
|
10442
|
+
throw new KcBadArgumentException('If accessRole is AccessRoleChoice.DENY, must not specify any of itemId, itemKeyId, tpId, or tpSharedKeyId parameters');
|
|
10443
|
+
}
|
|
10444
|
+
return {
|
|
10445
|
+
input: {
|
|
10446
|
+
id: itemShareId,
|
|
10447
|
+
accessRole,
|
|
10448
|
+
itemKeyId: null,
|
|
10449
|
+
wrappingKeyId: null,
|
|
10450
|
+
wrappedItemKey: null,
|
|
10451
|
+
},
|
|
10452
|
+
};
|
|
10453
|
+
}
|
|
10454
|
+
// Caching the result so we only need one call.
|
|
10455
|
+
let itemShare;
|
|
10456
|
+
const getItemShare = () => __awaiter(this, void 0, void 0, function* () {
|
|
10457
|
+
if (!itemShare) {
|
|
10458
|
+
if (isDirectory) {
|
|
10459
|
+
itemShare = (yield this.getDirectoryShare(itemShareId))
|
|
10460
|
+
.directoryShare;
|
|
10461
|
+
}
|
|
10462
|
+
else {
|
|
10463
|
+
itemShare = (yield this.getFileShare(itemShareId)).fileShare;
|
|
10464
|
+
}
|
|
10465
|
+
}
|
|
10466
|
+
return itemShare;
|
|
10467
|
+
});
|
|
10468
|
+
const itemKey = yield this.keyGraph.getKey(itemKeyId, () => __awaiter(this, void 0, void 0, function* () {
|
|
10469
|
+
const itemId_ = itemId || (yield getItemShare()).item.id;
|
|
10470
|
+
if (isDirectory) {
|
|
10471
|
+
return this.itemService.getDirectoryKeyId(itemId_);
|
|
10472
|
+
}
|
|
10473
|
+
else {
|
|
10474
|
+
return this.itemService.getFileKeyId(itemId_);
|
|
10475
|
+
}
|
|
10476
|
+
}));
|
|
10477
|
+
const wrappingKey = yield this.keyGraph.getKey(tpSharedKeyId, () => __awaiter(this, void 0, void 0, function* () {
|
|
10478
|
+
const tpId_ = tpId || (yield getItemShare()).tp.id;
|
|
10479
|
+
return (yield this.getTpCurrentUserSharedKey(tpId_)).sharedKey.id;
|
|
10480
|
+
}));
|
|
10481
|
+
const wrappedItemKey = yield this.keyGraph.wrapKey(wrappingKey, itemKey.jwk);
|
|
10482
|
+
return {
|
|
10483
|
+
input: {
|
|
10484
|
+
id: itemShareId,
|
|
10485
|
+
accessRole,
|
|
10486
|
+
itemKeyId: itemKey.id,
|
|
10487
|
+
wrappingKeyId: wrappingKey.id,
|
|
10488
|
+
wrappedItemKey,
|
|
10489
|
+
},
|
|
10490
|
+
};
|
|
10491
|
+
});
|
|
10387
10492
|
}
|
|
10388
10493
|
deleteDirectoryShare(id) {
|
|
10389
10494
|
return __awaiter(this, void 0, void 0, function* () {
|