@lifeready/core 6.0.5 → 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 +3485 -7369
- 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/auth2/auth.config.js +57 -0
- package/esm2015/lib/auth2/auth2.gql.private.js +8 -1
- package/esm2015/lib/auth2/auth2.service.js +3 -4
- package/esm2015/lib/auth2/auth2.types.js +1 -1
- package/esm2015/lib/encryption/encryption.service.js +7 -6
- package/esm2015/lib/file-upload/file-upload.service.js +4 -4
- package/esm2015/lib/idle/idle.service.js +1 -2
- package/esm2015/lib/item2/item2.service.js +17 -46
- package/esm2015/lib/key/key-graph.service.js +3 -3
- package/esm2015/lib/key/key-meta.service.js +16 -64
- package/esm2015/lib/key/key.types.js +6 -1
- package/esm2015/lib/key-exchange/key-exchange2.service.js +6 -25
- package/esm2015/lib/life-ready.module.js +2 -9
- package/esm2015/lib/password/password.service.js +1 -1
- package/esm2015/lib/profile/profile-details.service.js +120 -75
- package/esm2015/lib/profile/profile.gql.js +134 -1
- package/esm2015/lib/profile/profile.service.js +8 -5
- package/esm2015/lib/profile/profile.types.js +14 -3
- package/esm2015/lib/shared-contact-card/shared-contact-card.service.js +2 -2
- package/esm2015/lib/tp-password-reset/tp-password-reset.types.js +1 -1
- package/esm2015/lib/trusted-party/trusted-party2.service.js +3 -7
- package/esm2015/lifeready-core.js +7 -9
- package/esm2015/public-api.js +2 -20
- package/fesm2015/lifeready-core.js +3223 -6588
- package/fesm2015/lifeready-core.js.map +1 -1
- package/lib/auth2/auth2.gql.private.d.ts +15 -2
- package/lib/auth2/auth2.service.d.ts +1 -1
- package/lib/auth2/auth2.types.d.ts +19 -2
- package/lib/file-upload/file-upload.service.d.ts +2 -2
- package/lib/item2/item2.service.d.ts +12 -75
- package/lib/key/key-meta.service.d.ts +8 -1
- package/lib/key/key.types.d.ts +4 -1
- package/lib/key-exchange/key-exchange2.service.d.ts +5 -66
- package/lib/password/password.service.d.ts +1 -1
- package/lib/profile/profile-details.service.d.ts +10 -11
- package/lib/profile/profile.gql.d.ts +12 -0
- package/lib/profile/profile.service.d.ts +1 -3
- package/lib/profile/profile.types.d.ts +31 -4
- package/lib/shared-contact-card/shared-contact-card.service.d.ts +1 -2
- package/lib/tp-password-reset/tp-password-reset.types.d.ts +3 -3
- package/lib/trusted-party/trusted-party2.service.d.ts +2 -7
- package/lifeready-core.d.ts +6 -8
- package/lifeready-core.metadata.json +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -19
- package/esm2015/lib/auth/auth.config.js +0 -57
- package/esm2015/lib/auth/auth.gql.js +0 -16
- package/esm2015/lib/auth/auth.types.js +0 -18
- package/esm2015/lib/auth/life-ready-auth.service.js +0 -568
- package/esm2015/lib/category/category-meta.service.js +0 -99
- package/esm2015/lib/category/category.gql.js +0 -385
- package/esm2015/lib/category/category.service.js +0 -361
- package/esm2015/lib/category/category.types.js +0 -29
- package/esm2015/lib/key-exchange/key-exchange.gql.js +0 -188
- package/esm2015/lib/key-exchange/key-exchange.service.js +0 -436
- package/esm2015/lib/key-exchange/key-exchange.types.js +0 -7
- package/esm2015/lib/message/message.gql.js +0 -32
- package/esm2015/lib/message/message.service.js +0 -118
- package/esm2015/lib/message/message.types.js +0 -2
- package/esm2015/lib/plan/plan.gql.js +0 -123
- package/esm2015/lib/plan/plan.service.js +0 -150
- package/esm2015/lib/plan/plan.types.js +0 -11
- package/esm2015/lib/record/record-attachment.service.js +0 -102
- package/esm2015/lib/record/record.gql.js +0 -182
- package/esm2015/lib/record/record.service.js +0 -194
- package/esm2015/lib/record/record.types.js +0 -15
- package/esm2015/lib/record-type/record-type.service.js +0 -75
- package/esm2015/lib/record-type/record-type.types.js +0 -28
- package/esm2015/lib/trusted-party/trusted-party.gql.js +0 -148
- package/esm2015/lib/trusted-party/trusted-party.service.js +0 -308
- package/esm2015/lib/trusted-party/trusted-party.types.js +0 -41
- package/lib/auth/auth.gql.d.ts +0 -12
- package/lib/auth/auth.types.d.ts +0 -52
- package/lib/auth/life-ready-auth.service.d.ts +0 -73
- package/lib/category/category-meta.service.d.ts +0 -23
- package/lib/category/category.gql.d.ts +0 -44
- package/lib/category/category.service.d.ts +0 -66
- package/lib/category/category.types.d.ts +0 -75
- package/lib/key-exchange/key-exchange.gql.d.ts +0 -9
- package/lib/key-exchange/key-exchange.service.d.ts +0 -37
- package/lib/key-exchange/key-exchange.types.d.ts +0 -188
- package/lib/message/message.gql.d.ts +0 -13
- package/lib/message/message.service.d.ts +0 -36
- package/lib/message/message.types.d.ts +0 -12
- package/lib/plan/plan.gql.d.ts +0 -11
- package/lib/plan/plan.service.d.ts +0 -34
- package/lib/plan/plan.types.d.ts +0 -32
- package/lib/record/record-attachment.service.d.ts +0 -16
- package/lib/record/record.gql.d.ts +0 -14
- package/lib/record/record.service.d.ts +0 -25
- package/lib/record/record.types.d.ts +0 -56
- package/lib/record-type/record-type.service.d.ts +0 -11
- package/lib/record-type/record-type.types.d.ts +0 -50
- package/lib/trusted-party/trusted-party.gql.d.ts +0 -9
- package/lib/trusted-party/trusted-party.service.d.ts +0 -43
- package/lib/trusted-party/trusted-party.types.d.ts +0 -101
- /package/lib/{auth → auth2}/auth.config.d.ts +0 -0
|
@@ -1,182 +0,0 @@
|
|
|
1
|
-
import gql from 'graphql-tag';
|
|
2
|
-
import { DEFAULT_BREADCRUMB_DEPTH, parentCategoriesField, } from '../category/category.gql';
|
|
3
|
-
import { KeyGraphFragment } from '../_common/queries.gql';
|
|
4
|
-
export var FileType;
|
|
5
|
-
(function (FileType) {
|
|
6
|
-
FileType["RecordContent"] = "record-content";
|
|
7
|
-
FileType["RecordAttachment"] = "record-attachment";
|
|
8
|
-
})(FileType || (FileType = {}));
|
|
9
|
-
export const RecordContentFilter = JSON.stringify({
|
|
10
|
-
filter: [
|
|
11
|
-
{
|
|
12
|
-
contains: {
|
|
13
|
-
fileType: FileType.RecordContent,
|
|
14
|
-
},
|
|
15
|
-
},
|
|
16
|
-
],
|
|
17
|
-
});
|
|
18
|
-
export const RecordAttachmentFilter = JSON.stringify({
|
|
19
|
-
filter: [
|
|
20
|
-
{
|
|
21
|
-
contains: {
|
|
22
|
-
fileType: FileType.RecordAttachment,
|
|
23
|
-
},
|
|
24
|
-
},
|
|
25
|
-
],
|
|
26
|
-
});
|
|
27
|
-
export const GetRecordQuery = (depth = DEFAULT_BREADCRUMB_DEPTH) => gql `
|
|
28
|
-
query Record(
|
|
29
|
-
$id: LrRelayIdInput!,
|
|
30
|
-
$cachedKeyIds: [LrRelayIdInput!],
|
|
31
|
-
$categoryFilter: LrJSONFilter,
|
|
32
|
-
$contentFilter: LrJSONFilter,
|
|
33
|
-
$attachmentsFilter: LrJSONFilter,
|
|
34
|
-
) {
|
|
35
|
-
record: directory(id: $id) {
|
|
36
|
-
id
|
|
37
|
-
keyId
|
|
38
|
-
archived
|
|
39
|
-
plainMeta
|
|
40
|
-
cipherMeta
|
|
41
|
-
created
|
|
42
|
-
modified
|
|
43
|
-
confidentiality {
|
|
44
|
-
isConfidential
|
|
45
|
-
method
|
|
46
|
-
}
|
|
47
|
-
${parentCategoriesField(depth)}
|
|
48
|
-
content: childFileLinks(plainMeta: $contentFilter) {
|
|
49
|
-
edges {
|
|
50
|
-
node {
|
|
51
|
-
childFile {
|
|
52
|
-
id
|
|
53
|
-
keyId
|
|
54
|
-
archived
|
|
55
|
-
currentVersion {
|
|
56
|
-
state {
|
|
57
|
-
id
|
|
58
|
-
keyId
|
|
59
|
-
plainMeta
|
|
60
|
-
cipherMeta
|
|
61
|
-
created
|
|
62
|
-
modified
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
versions {
|
|
66
|
-
edges {
|
|
67
|
-
node {
|
|
68
|
-
operation
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
attachments: childFileLinks(plainMeta: $attachmentsFilter) {
|
|
77
|
-
edges {
|
|
78
|
-
node {
|
|
79
|
-
childFile {
|
|
80
|
-
id
|
|
81
|
-
keyId
|
|
82
|
-
archived
|
|
83
|
-
currentVersion {
|
|
84
|
-
state {
|
|
85
|
-
id
|
|
86
|
-
keyId
|
|
87
|
-
plainMeta
|
|
88
|
-
cipherMeta
|
|
89
|
-
contentResource
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
versions {
|
|
93
|
-
edges {
|
|
94
|
-
node {
|
|
95
|
-
operation
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
keyGraph(cachedKeyIds: $cachedKeyIds) {
|
|
105
|
-
...KeyGraphFragment
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
${KeyGraphFragment}
|
|
109
|
-
`;
|
|
110
|
-
export const CreateRecordContainerMutation = gql `
|
|
111
|
-
mutation CreateRecordContainer(
|
|
112
|
-
$plainMeta: LrJSONString
|
|
113
|
-
$cipherMeta: String
|
|
114
|
-
$parentDirectories: [ParentDirectoryInput!]
|
|
115
|
-
$parentRootDirectory: ParentRootDirectoryInput
|
|
116
|
-
) {
|
|
117
|
-
new: createDirectory(
|
|
118
|
-
input: {
|
|
119
|
-
plainMeta: $plainMeta
|
|
120
|
-
cipherMeta: $cipherMeta
|
|
121
|
-
parentDirectories: $parentDirectories
|
|
122
|
-
parentRootDirectory: $parentRootDirectory
|
|
123
|
-
}
|
|
124
|
-
) {
|
|
125
|
-
category: directory {
|
|
126
|
-
id
|
|
127
|
-
keyId
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
`;
|
|
132
|
-
export const CreateRecordMutation = gql `
|
|
133
|
-
mutation CreateFile($input: CreateFileInput!) {
|
|
134
|
-
createFile(input: $input) {
|
|
135
|
-
file {
|
|
136
|
-
id
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
`;
|
|
141
|
-
export const UpdateRecordContainerMutation = gql `
|
|
142
|
-
mutation UpdateRecord($input: UpdateDirectoryInput!) {
|
|
143
|
-
updateDirectory(input: $input) {
|
|
144
|
-
directory {
|
|
145
|
-
id
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
`;
|
|
150
|
-
export const UpdateRecordMutation = gql `
|
|
151
|
-
mutation UpdateFile($input: UpdateFileInput!) {
|
|
152
|
-
updateFile(input: $input) {
|
|
153
|
-
file {
|
|
154
|
-
id
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
`;
|
|
159
|
-
export const DeleteRecordMutation = gql `
|
|
160
|
-
mutation DeleteRecord($recordId: LrRelayIdInput!) {
|
|
161
|
-
deleteDirectory(input: { directoryId: $recordId }) {
|
|
162
|
-
id
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
`;
|
|
166
|
-
export const CreateFileMutation = gql `
|
|
167
|
-
mutation CreateFile($input: CreateFileInput!) {
|
|
168
|
-
createFile(input: $input) {
|
|
169
|
-
file {
|
|
170
|
-
id
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
`;
|
|
175
|
-
export const DeleteFileMutation = gql `
|
|
176
|
-
mutation DeleteFile($fileId: LrRelayIdInput!) {
|
|
177
|
-
deleteFile(input: { fileId: $fileId }) {
|
|
178
|
-
id
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
`;
|
|
182
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLmdxbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9yZWNvcmQvcmVjb3JkLmdxbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEdBQUcsTUFBTSxhQUFhLENBQUM7QUFDOUIsT0FBTyxFQUNMLHdCQUF3QixFQUN4QixxQkFBcUIsR0FDdEIsTUFBTSwwQkFBMEIsQ0FBQztBQUNsQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUUxRCxNQUFNLENBQU4sSUFBWSxRQUdYO0FBSEQsV0FBWSxRQUFRO0lBQ2xCLDRDQUFnQyxDQUFBO0lBQ2hDLGtEQUFzQyxDQUFBO0FBQ3hDLENBQUMsRUFIVyxRQUFRLEtBQVIsUUFBUSxRQUduQjtBQUVELE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDaEQsTUFBTSxFQUFFO1FBQ047WUFDRSxRQUFRLEVBQUU7Z0JBQ1IsUUFBUSxFQUFFLFFBQVEsQ0FBQyxhQUFhO2FBQ2pDO1NBQ0Y7S0FDRjtDQUNGLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDbkQsTUFBTSxFQUFFO1FBQ047WUFDRSxRQUFRLEVBQUU7Z0JBQ1IsUUFBUSxFQUFFLFFBQVEsQ0FBQyxnQkFBZ0I7YUFDcEM7U0FDRjtLQUNGO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLENBQUMsS0FBSyxHQUFHLHdCQUF3QixFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O01Bb0JqRSxxQkFBcUIsQ0FBQyxLQUFLLENBQUM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7RUE2RGhDLGdCQUFnQjtDQUNqQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sNkJBQTZCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Q0FxQi9DLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7O0NBUXRDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSw2QkFBNkIsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7O0NBUS9DLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7O0NBUXRDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxHQUFHLENBQUE7Ozs7OztDQU10QyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7OztDQVFwQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7Q0FNcEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBncWwgZnJvbSAnZ3JhcGhxbC10YWcnO1xuaW1wb3J0IHtcbiAgREVGQVVMVF9CUkVBRENSVU1CX0RFUFRILFxuICBwYXJlbnRDYXRlZ29yaWVzRmllbGQsXG59IGZyb20gJy4uL2NhdGVnb3J5L2NhdGVnb3J5LmdxbCc7XG5pbXBvcnQgeyBLZXlHcmFwaEZyYWdtZW50IH0gZnJvbSAnLi4vX2NvbW1vbi9xdWVyaWVzLmdxbCc7XG5cbmV4cG9ydCBlbnVtIEZpbGVUeXBlIHtcbiAgUmVjb3JkQ29udGVudCA9ICdyZWNvcmQtY29udGVudCcsXG4gIFJlY29yZEF0dGFjaG1lbnQgPSAncmVjb3JkLWF0dGFjaG1lbnQnLFxufVxuXG5leHBvcnQgY29uc3QgUmVjb3JkQ29udGVudEZpbHRlciA9IEpTT04uc3RyaW5naWZ5KHtcbiAgZmlsdGVyOiBbXG4gICAge1xuICAgICAgY29udGFpbnM6IHtcbiAgICAgICAgZmlsZVR5cGU6IEZpbGVUeXBlLlJlY29yZENvbnRlbnQsXG4gICAgICB9LFxuICAgIH0sXG4gIF0sXG59KTtcblxuZXhwb3J0IGNvbnN0IFJlY29yZEF0dGFjaG1lbnRGaWx0ZXIgPSBKU09OLnN0cmluZ2lmeSh7XG4gIGZpbHRlcjogW1xuICAgIHtcbiAgICAgIGNvbnRhaW5zOiB7XG4gICAgICAgIGZpbGVUeXBlOiBGaWxlVHlwZS5SZWNvcmRBdHRhY2htZW50LFxuICAgICAgfSxcbiAgICB9LFxuICBdLFxufSk7XG5cbmV4cG9ydCBjb25zdCBHZXRSZWNvcmRRdWVyeSA9IChkZXB0aCA9IERFRkFVTFRfQlJFQURDUlVNQl9ERVBUSCkgPT4gZ3FsYFxucXVlcnkgUmVjb3JkKFxuICAkaWQ6IExyUmVsYXlJZElucHV0ISxcbiAgJGNhY2hlZEtleUlkczogW0xyUmVsYXlJZElucHV0IV0sXG4gICRjYXRlZ29yeUZpbHRlcjogTHJKU09ORmlsdGVyLFxuICAkY29udGVudEZpbHRlcjogTHJKU09ORmlsdGVyLFxuICAkYXR0YWNobWVudHNGaWx0ZXI6IExySlNPTkZpbHRlcixcbikge1xuICByZWNvcmQ6IGRpcmVjdG9yeShpZDogJGlkKSB7XG4gICAgaWRcbiAgICBrZXlJZFxuICAgIGFyY2hpdmVkXG4gICAgcGxhaW5NZXRhXG4gICAgY2lwaGVyTWV0YVxuICAgIGNyZWF0ZWRcbiAgICBtb2RpZmllZFxuICAgIGNvbmZpZGVudGlhbGl0eSB7XG4gICAgICBpc0NvbmZpZGVudGlhbFxuICAgICAgbWV0aG9kXG4gICAgfVxuICAgICR7cGFyZW50Q2F0ZWdvcmllc0ZpZWxkKGRlcHRoKX1cbiAgICBjb250ZW50OiBjaGlsZEZpbGVMaW5rcyhwbGFpbk1ldGE6ICRjb250ZW50RmlsdGVyKSB7XG4gICAgICBlZGdlcyB7XG4gICAgICAgIG5vZGUge1xuICAgICAgICAgIGNoaWxkRmlsZSB7XG4gICAgICAgICAgICBpZFxuICAgICAgICAgICAga2V5SWRcbiAgICAgICAgICAgIGFyY2hpdmVkXG4gICAgICAgICAgICBjdXJyZW50VmVyc2lvbiB7XG4gICAgICAgICAgICAgIHN0YXRlIHtcbiAgICAgICAgICAgICAgICBpZFxuICAgICAgICAgICAgICAgIGtleUlkXG4gICAgICAgICAgICAgICAgcGxhaW5NZXRhXG4gICAgICAgICAgICAgICAgY2lwaGVyTWV0YVxuICAgICAgICAgICAgICAgIGNyZWF0ZWRcbiAgICAgICAgICAgICAgICBtb2RpZmllZFxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICB2ZXJzaW9ucyB7XG4gICAgICAgICAgICAgIGVkZ2VzIHtcbiAgICAgICAgICAgICAgICBub2RlIHtcbiAgICAgICAgICAgICAgICAgIG9wZXJhdGlvblxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgICBhdHRhY2htZW50czogY2hpbGRGaWxlTGlua3MocGxhaW5NZXRhOiAkYXR0YWNobWVudHNGaWx0ZXIpIHtcbiAgICAgIGVkZ2VzIHtcbiAgICAgICAgbm9kZSB7XG4gICAgICAgICAgY2hpbGRGaWxlIHtcbiAgICAgICAgICAgIGlkXG4gICAgICAgICAgICBrZXlJZFxuICAgICAgICAgICAgYXJjaGl2ZWRcbiAgICAgICAgICAgIGN1cnJlbnRWZXJzaW9uIHtcbiAgICAgICAgICAgICAgc3RhdGUge1xuICAgICAgICAgICAgICAgIGlkXG4gICAgICAgICAgICAgICAga2V5SWRcbiAgICAgICAgICAgICAgICBwbGFpbk1ldGFcbiAgICAgICAgICAgICAgICBjaXBoZXJNZXRhXG4gICAgICAgICAgICAgICAgY29udGVudFJlc291cmNlXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHZlcnNpb25zIHtcbiAgICAgICAgICAgICAgZWRnZXMge1xuICAgICAgICAgICAgICAgIG5vZGUge1xuICAgICAgICAgICAgICAgICAgb3BlcmF0aW9uXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9XG4gIGtleUdyYXBoKGNhY2hlZEtleUlkczogJGNhY2hlZEtleUlkcykge1xuICAgIC4uLktleUdyYXBoRnJhZ21lbnRcbiAgfVxufVxuJHtLZXlHcmFwaEZyYWdtZW50fVxuYDtcblxuZXhwb3J0IGNvbnN0IENyZWF0ZVJlY29yZENvbnRhaW5lck11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBDcmVhdGVSZWNvcmRDb250YWluZXIoXG4gICAgJHBsYWluTWV0YTogTHJKU09OU3RyaW5nXG4gICAgJGNpcGhlck1ldGE6IFN0cmluZ1xuICAgICRwYXJlbnREaXJlY3RvcmllczogW1BhcmVudERpcmVjdG9yeUlucHV0IV1cbiAgICAkcGFyZW50Um9vdERpcmVjdG9yeTogUGFyZW50Um9vdERpcmVjdG9yeUlucHV0XG4gICkge1xuICAgIG5ldzogY3JlYXRlRGlyZWN0b3J5KFxuICAgICAgaW5wdXQ6IHtcbiAgICAgICAgcGxhaW5NZXRhOiAkcGxhaW5NZXRhXG4gICAgICAgIGNpcGhlck1ldGE6ICRjaXBoZXJNZXRhXG4gICAgICAgIHBhcmVudERpcmVjdG9yaWVzOiAkcGFyZW50RGlyZWN0b3JpZXNcbiAgICAgICAgcGFyZW50Um9vdERpcmVjdG9yeTogJHBhcmVudFJvb3REaXJlY3RvcnlcbiAgICAgIH1cbiAgICApIHtcbiAgICAgIGNhdGVnb3J5OiBkaXJlY3Rvcnkge1xuICAgICAgICBpZFxuICAgICAgICBrZXlJZFxuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IENyZWF0ZVJlY29yZE11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBDcmVhdGVGaWxlKCRpbnB1dDogQ3JlYXRlRmlsZUlucHV0ISkge1xuICAgIGNyZWF0ZUZpbGUoaW5wdXQ6ICRpbnB1dCkge1xuICAgICAgZmlsZSB7XG4gICAgICAgIGlkXG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgVXBkYXRlUmVjb3JkQ29udGFpbmVyTXV0YXRpb24gPSBncWxgXG4gIG11dGF0aW9uIFVwZGF0ZVJlY29yZCgkaW5wdXQ6IFVwZGF0ZURpcmVjdG9yeUlucHV0ISkge1xuICAgIHVwZGF0ZURpcmVjdG9yeShpbnB1dDogJGlucHV0KSB7XG4gICAgICBkaXJlY3Rvcnkge1xuICAgICAgICBpZFxuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFVwZGF0ZVJlY29yZE11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBVcGRhdGVGaWxlKCRpbnB1dDogVXBkYXRlRmlsZUlucHV0ISkge1xuICAgIHVwZGF0ZUZpbGUoaW5wdXQ6ICRpbnB1dCkge1xuICAgICAgZmlsZSB7XG4gICAgICAgIGlkXG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgRGVsZXRlUmVjb3JkTXV0YXRpb24gPSBncWxgXG4gIG11dGF0aW9uIERlbGV0ZVJlY29yZCgkcmVjb3JkSWQ6IExyUmVsYXlJZElucHV0ISkge1xuICAgIGRlbGV0ZURpcmVjdG9yeShpbnB1dDogeyBkaXJlY3RvcnlJZDogJHJlY29yZElkIH0pIHtcbiAgICAgIGlkXG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgQ3JlYXRlRmlsZU11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBDcmVhdGVGaWxlKCRpbnB1dDogQ3JlYXRlRmlsZUlucHV0ISkge1xuICAgIGNyZWF0ZUZpbGUoaW5wdXQ6ICRpbnB1dCkge1xuICAgICAgZmlsZSB7XG4gICAgICAgIGlkXG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgRGVsZXRlRmlsZU11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBEZWxldGVGaWxlKCRmaWxlSWQ6IExyUmVsYXlJZElucHV0ISkge1xuICAgIGRlbGV0ZUZpbGUoaW5wdXQ6IHsgZmlsZUlkOiAkZmlsZUlkIH0pIHtcbiAgICAgIGlkXG4gICAgfVxuICB9XG5gO1xuIl19
|
|
@@ -1,194 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
3
|
-
import { Injectable } from '@angular/core';
|
|
4
|
-
import { LrApolloService } from '../api/lr-apollo.service';
|
|
5
|
-
import { CategoryFilter, DirectoryType } from '../category/category.gql';
|
|
6
|
-
import { CategoryService } from '../category/category.service';
|
|
7
|
-
import { KeyMetaService } from '../key/key-meta.service';
|
|
8
|
-
import { RecordAttachmentService } from './record-attachment.service';
|
|
9
|
-
import { CreateRecordContainerMutation, CreateRecordMutation, DeleteRecordMutation, FileType, GetRecordQuery, RecordAttachmentFilter, RecordContentFilter, UpdateRecordMutation, } from './record.gql';
|
|
10
|
-
import * as i0 from "@angular/core";
|
|
11
|
-
import * as i1 from "../api/lr-apollo.service";
|
|
12
|
-
import * as i2 from "../key/key-meta.service";
|
|
13
|
-
import * as i3 from "../category/category.service";
|
|
14
|
-
import * as i4 from "./record-attachment.service";
|
|
15
|
-
export class RecordService {
|
|
16
|
-
constructor(lrApollo, keyMetaService, categoryService, recordAttachmentService) {
|
|
17
|
-
this.lrApollo = lrApollo;
|
|
18
|
-
this.keyMetaService = keyMetaService;
|
|
19
|
-
this.categoryService = categoryService;
|
|
20
|
-
this.recordAttachmentService = recordAttachmentService;
|
|
21
|
-
}
|
|
22
|
-
getRecord(recordId) {
|
|
23
|
-
var _a;
|
|
24
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
25
|
-
const { record } = yield this.lrApollo.query({
|
|
26
|
-
query: GetRecordQuery(),
|
|
27
|
-
variables: {
|
|
28
|
-
id: recordId,
|
|
29
|
-
categoryFilter: CategoryFilter,
|
|
30
|
-
contentFilter: RecordContentFilter,
|
|
31
|
-
attachmentsFilter: RecordAttachmentFilter,
|
|
32
|
-
},
|
|
33
|
-
});
|
|
34
|
-
const contents = record.content.edges[0].node.childFile;
|
|
35
|
-
const { name, recordType, fields } = (yield this.keyMetaService.decryptMeta(contents.currentVersion.state)) ||
|
|
36
|
-
{};
|
|
37
|
-
const categories = yield Promise.all(record.parentCategories.edges.map((x) => __awaiter(this, void 0, void 0, function* () {
|
|
38
|
-
return [
|
|
39
|
-
...(yield this.categoryService.mapParentCategories(x.node.parentDirectory)),
|
|
40
|
-
yield this.categoryService.mapCategory(x.node.parentDirectory),
|
|
41
|
-
];
|
|
42
|
-
})));
|
|
43
|
-
const attachments = yield this.mapAttachments(record.attachments.edges);
|
|
44
|
-
return {
|
|
45
|
-
id: record.id,
|
|
46
|
-
keyId: record.keyId,
|
|
47
|
-
updateKeyId: contents.keyId,
|
|
48
|
-
updateId: contents.id,
|
|
49
|
-
name,
|
|
50
|
-
recordType,
|
|
51
|
-
fields,
|
|
52
|
-
categories,
|
|
53
|
-
attachments,
|
|
54
|
-
isArchived: !!record.archived,
|
|
55
|
-
isConfidential: !!((_a = record.confidentiality) === null || _a === void 0 ? void 0 : _a.isConfidential),
|
|
56
|
-
createdOn: record.created,
|
|
57
|
-
lastModified: new Date(record.modified) >
|
|
58
|
-
new Date(contents.currentVersion.state.modified)
|
|
59
|
-
? record.modified
|
|
60
|
-
: contents.currentVersion.state.modified,
|
|
61
|
-
};
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
mapAttachments(attachments) {
|
|
65
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
66
|
-
return yield Promise.all(attachments
|
|
67
|
-
.map((x) => x.node.childFile)
|
|
68
|
-
.map((x) => __awaiter(this, void 0, void 0, function* () {
|
|
69
|
-
const { name, fieldId, fileType, fileSize, lastModified } = (yield this.keyMetaService.decryptMeta(x.currentVersion.state)) ||
|
|
70
|
-
{};
|
|
71
|
-
return {
|
|
72
|
-
fileId: x.id,
|
|
73
|
-
keyId: x.currentVersion.state.keyId,
|
|
74
|
-
contentId: x.currentVersion.state.id,
|
|
75
|
-
fieldId,
|
|
76
|
-
name,
|
|
77
|
-
fileType,
|
|
78
|
-
fileSize,
|
|
79
|
-
lastModified,
|
|
80
|
-
};
|
|
81
|
-
})));
|
|
82
|
-
});
|
|
83
|
-
}
|
|
84
|
-
createRecord(newRecord) {
|
|
85
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
86
|
-
// Create directory that holds the record
|
|
87
|
-
const wrappedContent = yield this.keyMetaService.wrapContent(null, newRecord.categoryIds);
|
|
88
|
-
const response = yield this.lrApollo.mutate({
|
|
89
|
-
mutation: CreateRecordContainerMutation,
|
|
90
|
-
variables: {
|
|
91
|
-
plainMeta: JSON.stringify({
|
|
92
|
-
directoryType: DirectoryType.Record,
|
|
93
|
-
isHidden: false,
|
|
94
|
-
}),
|
|
95
|
-
parentDirectories: wrappedContent.wrappedKeys,
|
|
96
|
-
parentRootDirectory: wrappedContent.rootKey,
|
|
97
|
-
},
|
|
98
|
-
});
|
|
99
|
-
const recordId = response.new.category.id;
|
|
100
|
-
const secureContent = {
|
|
101
|
-
name: newRecord.name,
|
|
102
|
-
recordType: newRecord.recordType,
|
|
103
|
-
fields: newRecord.fields,
|
|
104
|
-
};
|
|
105
|
-
const doubleWrappedContent = yield this.keyMetaService.doubleWrapContent(secureContent, [recordId]);
|
|
106
|
-
// Create the file that holds the record contents
|
|
107
|
-
yield this.lrApollo.mutate({
|
|
108
|
-
mutation: CreateRecordMutation,
|
|
109
|
-
variables: {
|
|
110
|
-
input: {
|
|
111
|
-
plainMeta: JSON.stringify({ fileType: FileType.RecordContent }),
|
|
112
|
-
wrappedStateKey: doubleWrappedContent.doubleWrappedKey,
|
|
113
|
-
cipherMeta: doubleWrappedContent.cipherMeta,
|
|
114
|
-
parentDirectories: doubleWrappedContent.wrappedKeys.map((x) => ({
|
|
115
|
-
directoryId: x.directoryId,
|
|
116
|
-
wrappingKeyId: x.wrappingKeyId,
|
|
117
|
-
wrappedFileKey: x.wrappedKey,
|
|
118
|
-
})),
|
|
119
|
-
},
|
|
120
|
-
},
|
|
121
|
-
});
|
|
122
|
-
try {
|
|
123
|
-
yield this.recordAttachmentService.uploadAttachments(recordId, newRecord.attachments);
|
|
124
|
-
}
|
|
125
|
-
catch (e) {
|
|
126
|
-
console.error(e);
|
|
127
|
-
return { recordId, attachmentError: e };
|
|
128
|
-
}
|
|
129
|
-
return { recordId };
|
|
130
|
-
});
|
|
131
|
-
}
|
|
132
|
-
updateRecord(recordId, updateId, updateKeyId, updatedRecord) {
|
|
133
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
134
|
-
const secureContent = {
|
|
135
|
-
name: updatedRecord.name,
|
|
136
|
-
recordType: updatedRecord.recordType,
|
|
137
|
-
fields: updatedRecord.fields,
|
|
138
|
-
};
|
|
139
|
-
const reWrappedContent = yield this.keyMetaService.reWrapContent(updateKeyId, secureContent);
|
|
140
|
-
yield this.lrApollo.mutate({
|
|
141
|
-
mutation: UpdateRecordMutation,
|
|
142
|
-
variables: {
|
|
143
|
-
input: {
|
|
144
|
-
fileId: updateId,
|
|
145
|
-
plainMeta: JSON.stringify({ fileType: FileType.RecordContent }),
|
|
146
|
-
wrappedStateKey: reWrappedContent.doubleWrappedKey,
|
|
147
|
-
cipherMeta: reWrappedContent.cipherMeta,
|
|
148
|
-
},
|
|
149
|
-
},
|
|
150
|
-
});
|
|
151
|
-
try {
|
|
152
|
-
yield this.recordAttachmentService.uploadAttachments(recordId, updatedRecord.attachments);
|
|
153
|
-
}
|
|
154
|
-
catch (e) {
|
|
155
|
-
console.error(e);
|
|
156
|
-
return { recordId, attachmentError: e };
|
|
157
|
-
}
|
|
158
|
-
return { recordId };
|
|
159
|
-
});
|
|
160
|
-
}
|
|
161
|
-
archiveRecord(recordId) {
|
|
162
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
163
|
-
// All content of the record should also be archived, hence, recursive=true
|
|
164
|
-
return this.categoryService.archiveDirectory(recordId, true);
|
|
165
|
-
});
|
|
166
|
-
}
|
|
167
|
-
unarchiveRecord(recordId) {
|
|
168
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
169
|
-
// All content of the record should also be unarchived, hence, recursive=true
|
|
170
|
-
return this.categoryService.unarchiveDirectory(recordId, true);
|
|
171
|
-
});
|
|
172
|
-
}
|
|
173
|
-
deleteRecord(recordId) {
|
|
174
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
175
|
-
yield this.lrApollo.mutate({
|
|
176
|
-
mutation: DeleteRecordMutation,
|
|
177
|
-
variables: { recordId },
|
|
178
|
-
});
|
|
179
|
-
});
|
|
180
|
-
}
|
|
181
|
-
}
|
|
182
|
-
RecordService.ɵprov = i0.ɵɵdefineInjectable({ factory: function RecordService_Factory() { return new RecordService(i0.ɵɵinject(i1.LrApolloService), i0.ɵɵinject(i2.KeyMetaService), i0.ɵɵinject(i3.CategoryService), i0.ɵɵinject(i4.RecordAttachmentService)); }, token: RecordService, providedIn: "root" });
|
|
183
|
-
RecordService.decorators = [
|
|
184
|
-
{ type: Injectable, args: [{
|
|
185
|
-
providedIn: 'root',
|
|
186
|
-
},] }
|
|
187
|
-
];
|
|
188
|
-
RecordService.ctorParameters = () => [
|
|
189
|
-
{ type: LrApolloService },
|
|
190
|
-
{ type: KeyMetaService },
|
|
191
|
-
{ type: CategoryService },
|
|
192
|
-
{ type: RecordAttachmentService }
|
|
193
|
-
];
|
|
194
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"record.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/record/record.service.ts"],"names":[],"mappings":";AAAA,uDAAuD;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzE,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAE/D,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AACtE,OAAO,EACL,6BAA6B,EAC7B,oBAAoB,EACpB,oBAAoB,EACpB,QAAQ,EACR,cAAc,EACd,sBAAsB,EACtB,mBAAmB,EACnB,oBAAoB,GACrB,MAAM,cAAc,CAAC;;;;;;AAWtB,MAAM,OAAO,aAAa;IACxB,YACU,QAAyB,EACzB,cAA8B,EAC9B,eAAgC,EAChC,uBAAgD;QAHhD,aAAQ,GAAR,QAAQ,CAAiB;QACzB,mBAAc,GAAd,cAAc,CAAgB;QAC9B,oBAAe,GAAf,eAAe,CAAiB;QAChC,4BAAuB,GAAvB,uBAAuB,CAAyB;IACvD,CAAC;IAES,SAAS,CAAC,QAAgB;;;YACrC,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAM;gBAChD,KAAK,EAAE,cAAc,EAAE;gBACvB,SAAS,EAAE;oBACT,EAAE,EAAE,QAAQ;oBACZ,cAAc,EAAE,cAAc;oBAC9B,aAAa,EAAE,mBAAmB;oBAClC,iBAAiB,EAAE,sBAAsB;iBAC1C;aACF,CAAC,CAAC;YACH,MAAM,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC;YACxD,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,GAChC,CAAC,MAAM,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,QAAQ,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;gBACtE,EAAE,CAAC;YACL,MAAM,UAAU,GAAG,MAAM,OAAO,CAAC,GAAG,CAClC,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAO,CAAM,EAAE,EAAE;gBAAC,OAAA;oBAClD,GAAG,CAAC,MAAM,IAAI,CAAC,eAAe,CAAC,mBAAmB,CAChD,CAAC,CAAC,IAAI,CAAC,eAAe,CACvB,CAAC;oBACF,MAAM,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC;iBAC/D,CAAA;cAAA,CAAC,CACH,CAAC;YACF,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YAExE,OAAO;gBACL,EAAE,EAAE,MAAM,CAAC,EAAE;gBACb,KAAK,EAAE,MAAM,CAAC,KAAK;gBACnB,WAAW,EAAE,QAAQ,CAAC,KAAK;gBAC3B,QAAQ,EAAE,QAAQ,CAAC,EAAE;gBACrB,IAAI;gBACJ,UAAU;gBACV,MAAM;gBACN,UAAU;gBACV,WAAW;gBACX,UAAU,EAAE,CAAC,CAAC,MAAM,CAAC,QAAQ;gBAC7B,cAAc,EAAE,CAAC,QAAC,MAAM,CAAC,eAAe,0CAAE,cAAc,CAAA;gBACxD,SAAS,EAAE,MAAM,CAAC,OAAO;gBACzB,YAAY,EACV,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;oBACzB,IAAI,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,KAAK,CAAC,QAAQ,CAAC;oBAC9C,CAAC,CAAC,MAAM,CAAC,QAAQ;oBACjB,CAAC,CAAC,QAAQ,CAAC,cAAc,CAAC,KAAK,CAAC,QAAQ;aAC7C,CAAC;;KACH;IAEa,cAAc,CAC1B,WAAkB;;YAElB,OAAO,MAAM,OAAO,CAAC,GAAG,CACtB,WAAW;iBACR,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC;iBAC5B,GAAG,CAAC,CAAO,CAAM,EAAE,EAAE;gBACpB,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,YAAY,EAAE,GACvD,CAAC,MAAM,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;oBAC/D,EAAE,CAAC;gBAEL,OAAO;oBACL,MAAM,EAAE,CAAC,CAAC,EAAE;oBACZ,KAAK,EAAE,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,KAAK;oBACnC,SAAS,EAAE,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,EAAE;oBACpC,OAAO;oBACP,IAAI;oBACJ,QAAQ;oBACR,QAAQ;oBACR,YAAY;iBACb,CAAC;YACJ,CAAC,CAAA,CAAC,CACL,CAAC;QACJ,CAAC;KAAA;IAEY,YAAY,CACvB,SAAoB;;YAEpB,yCAAyC;YACzC,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,WAAW,CAC1D,IAAI,EACJ,SAAS,CAAC,WAAW,CACtB,CAAC;YACF,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAM;gBAC/C,QAAQ,EAAE,6BAA6B;gBACvC,SAAS,EAAE;oBACT,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC;wBACxB,aAAa,EAAE,aAAa,CAAC,MAAM;wBACnC,QAAQ,EAAE,KAAK;qBAChB,CAAC;oBACF,iBAAiB,EAAE,cAAc,CAAC,WAAW;oBAC7C,mBAAmB,EAAE,cAAc,CAAC,OAAO;iBAC5C;aACF,CAAC,CAAC;YACH,MAAM,QAAQ,GAAG,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC1C,MAAM,aAAa,GAAG;gBACpB,IAAI,EAAE,SAAS,CAAC,IAAI;gBACpB,UAAU,EAAE,SAAS,CAAC,UAAU;gBAChC,MAAM,EAAE,SAAS,CAAC,MAAM;aACzB,CAAC;YACF,MAAM,oBAAoB,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,iBAAiB,CACtE,aAAa,EACb,CAAC,QAAQ,CAAC,CACX,CAAC;YAEF,iDAAiD;YACjD,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;gBACzB,QAAQ,EAAE,oBAAoB;gBAC9B,SAAS,EAAE;oBACT,KAAK,EAAE;wBACL,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,QAAQ,CAAC,aAAa,EAAE,CAAC;wBAC/D,eAAe,EAAE,oBAAoB,CAAC,gBAAgB;wBACtD,UAAU,EAAE,oBAAoB,CAAC,UAAU;wBAC3C,iBAAiB,EAAE,oBAAoB,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;4BAC9D,WAAW,EAAE,CAAC,CAAC,WAAW;4BAC1B,aAAa,EAAE,CAAC,CAAC,aAAa;4BAC9B,cAAc,EAAE,CAAC,CAAC,UAAU;yBAC7B,CAAC,CAAC;qBACJ;iBACF;aACF,CAAC,CAAC;YAEH,IAAI;gBACF,MAAM,IAAI,CAAC,uBAAuB,CAAC,iBAAiB,CAClD,QAAQ,EACR,SAAS,CAAC,WAAW,CACtB,CAAC;aACH;YAAC,OAAO,CAAC,EAAE;gBACV,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBACjB,OAAO,EAAE,QAAQ,EAAE,eAAe,EAAE,CAAC,EAAE,CAAC;aACzC;YACD,OAAO,EAAE,QAAQ,EAAE,CAAC;QACtB,CAAC;KAAA;IAEY,YAAY,CACvB,QAAgB,EAChB,QAAgB,EAChB,WAAmB,EACnB,aAA4B;;YAE5B,MAAM,aAAa,GAAG;gBACpB,IAAI,EAAE,aAAa,CAAC,IAAI;gBACxB,UAAU,EAAE,aAAa,CAAC,UAAU;gBACpC,MAAM,EAAE,aAAa,CAAC,MAAM;aAC7B,CAAC;YACF,MAAM,gBAAgB,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,aAAa,CAC9D,WAAW,EACX,aAAa,CACd,CAAC;YAEF,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;gBACzB,QAAQ,EAAE,oBAAoB;gBAC9B,SAAS,EAAE;oBACT,KAAK,EAAE;wBACL,MAAM,EAAE,QAAQ;wBAChB,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,QAAQ,CAAC,aAAa,EAAE,CAAC;wBAC/D,eAAe,EAAE,gBAAgB,CAAC,gBAAgB;wBAClD,UAAU,EAAE,gBAAgB,CAAC,UAAU;qBACxC;iBACF;aACF,CAAC,CAAC;YAEH,IAAI;gBACF,MAAM,IAAI,CAAC,uBAAuB,CAAC,iBAAiB,CAClD,QAAQ,EACR,aAAa,CAAC,WAAW,CAC1B,CAAC;aACH;YAAC,OAAO,CAAC,EAAE;gBACV,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBACjB,OAAO,EAAE,QAAQ,EAAE,eAAe,EAAE,CAAC,EAAE,CAAC;aACzC;YACD,OAAO,EAAE,QAAQ,EAAE,CAAC;QACtB,CAAC;KAAA;IAEY,aAAa,CAAC,QAAgB;;YACzC,2EAA2E;YAC3E,OAAO,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;QAC/D,CAAC;KAAA;IAEY,eAAe,CAAC,QAAgB;;YAC3C,6EAA6E;YAC7E,OAAO,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;QACjE,CAAC;KAAA;IAEY,YAAY,CAAC,QAAgB;;YACxC,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;gBACzB,QAAQ,EAAE,oBAAoB;gBAC9B,SAAS,EAAE,EAAE,QAAQ,EAAE;aACxB,CAAC,CAAC;QACL,CAAC;KAAA;;;;YAnMF,UAAU,SAAC;gBACV,UAAU,EAAE,MAAM;aACnB;;;YAzBQ,eAAe;YAIf,cAAc;YAFd,eAAe;YAGf,uBAAuB","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Injectable } from '@angular/core';\nimport { LrApolloService } from '../api/lr-apollo.service';\nimport { CategoryFilter, DirectoryType } from '../category/category.gql';\nimport { CategoryService } from '../category/category.service';\nimport { Category } from '../category/category.types';\nimport { KeyMetaService } from '../key/key-meta.service';\nimport { RecordAttachmentService } from './record-attachment.service';\nimport {\n  CreateRecordContainerMutation,\n  CreateRecordMutation,\n  DeleteRecordMutation,\n  FileType,\n  GetRecordQuery,\n  RecordAttachmentFilter,\n  RecordContentFilter,\n  UpdateRecordMutation,\n} from './record.gql';\nimport {\n  LrRecord,\n  NewRecord,\n  RecordAttachment,\n  UpdatedRecord,\n} from './record.types';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class RecordService {\n  constructor(\n    private lrApollo: LrApolloService,\n    private keyMetaService: KeyMetaService,\n    private categoryService: CategoryService,\n    private recordAttachmentService: RecordAttachmentService\n  ) {}\n\n  public async getRecord(recordId: string): Promise<LrRecord> {\n    const { record } = await this.lrApollo.query<any>({\n      query: GetRecordQuery(),\n      variables: {\n        id: recordId,\n        categoryFilter: CategoryFilter,\n        contentFilter: RecordContentFilter,\n        attachmentsFilter: RecordAttachmentFilter,\n      },\n    });\n    const contents = record.content.edges[0].node.childFile;\n    const { name, recordType, fields } =\n      (await this.keyMetaService.decryptMeta(contents.currentVersion.state)) ||\n      {};\n    const categories = await Promise.all<Category[]>(\n      record.parentCategories.edges.map(async (x: any) => [\n        ...(await this.categoryService.mapParentCategories(\n          x.node.parentDirectory\n        )),\n        await this.categoryService.mapCategory(x.node.parentDirectory),\n      ])\n    );\n    const attachments = await this.mapAttachments(record.attachments.edges);\n\n    return {\n      id: record.id,\n      keyId: record.keyId,\n      updateKeyId: contents.keyId,\n      updateId: contents.id,\n      name,\n      recordType,\n      fields,\n      categories,\n      attachments,\n      isArchived: !!record.archived,\n      isConfidential: !!record.confidentiality?.isConfidential,\n      createdOn: record.created,\n      lastModified:\n        new Date(record.modified) >\n        new Date(contents.currentVersion.state.modified)\n          ? record.modified\n          : contents.currentVersion.state.modified,\n    };\n  }\n\n  private async mapAttachments(\n    attachments: any[]\n  ): Promise<RecordAttachment[]> {\n    return await Promise.all<RecordAttachment>(\n      attachments\n        .map((x) => x.node.childFile)\n        .map(async (x: any) => {\n          const { name, fieldId, fileType, fileSize, lastModified } =\n            (await this.keyMetaService.decryptMeta(x.currentVersion.state)) ||\n            {};\n\n          return {\n            fileId: x.id,\n            keyId: x.currentVersion.state.keyId,\n            contentId: x.currentVersion.state.id,\n            fieldId,\n            name,\n            fileType,\n            fileSize,\n            lastModified,\n          };\n        })\n    );\n  }\n\n  public async createRecord(\n    newRecord: NewRecord\n  ): Promise<{ recordId: string; attachmentError?: Error }> {\n    // Create directory that holds the record\n    const wrappedContent = await this.keyMetaService.wrapContent(\n      null,\n      newRecord.categoryIds\n    );\n    const response = await this.lrApollo.mutate<any>({\n      mutation: CreateRecordContainerMutation,\n      variables: {\n        plainMeta: JSON.stringify({\n          directoryType: DirectoryType.Record,\n          isHidden: false,\n        }),\n        parentDirectories: wrappedContent.wrappedKeys,\n        parentRootDirectory: wrappedContent.rootKey,\n      },\n    });\n    const recordId = response.new.category.id;\n    const secureContent = {\n      name: newRecord.name,\n      recordType: newRecord.recordType,\n      fields: newRecord.fields,\n    };\n    const doubleWrappedContent = await this.keyMetaService.doubleWrapContent(\n      secureContent,\n      [recordId]\n    );\n\n    // Create the file that holds the record contents\n    await this.lrApollo.mutate({\n      mutation: CreateRecordMutation,\n      variables: {\n        input: {\n          plainMeta: JSON.stringify({ fileType: FileType.RecordContent }),\n          wrappedStateKey: doubleWrappedContent.doubleWrappedKey,\n          cipherMeta: doubleWrappedContent.cipherMeta,\n          parentDirectories: doubleWrappedContent.wrappedKeys.map((x) => ({\n            directoryId: x.directoryId,\n            wrappingKeyId: x.wrappingKeyId,\n            wrappedFileKey: x.wrappedKey,\n          })),\n        },\n      },\n    });\n\n    try {\n      await this.recordAttachmentService.uploadAttachments(\n        recordId,\n        newRecord.attachments\n      );\n    } catch (e) {\n      console.error(e);\n      return { recordId, attachmentError: e };\n    }\n    return { recordId };\n  }\n\n  public async updateRecord(\n    recordId: string,\n    updateId: string,\n    updateKeyId: string,\n    updatedRecord: UpdatedRecord\n  ): Promise<{ recordId: string; attachmentError?: Error }> {\n    const secureContent = {\n      name: updatedRecord.name,\n      recordType: updatedRecord.recordType,\n      fields: updatedRecord.fields,\n    };\n    const reWrappedContent = await this.keyMetaService.reWrapContent(\n      updateKeyId,\n      secureContent\n    );\n\n    await this.lrApollo.mutate({\n      mutation: UpdateRecordMutation,\n      variables: {\n        input: {\n          fileId: updateId,\n          plainMeta: JSON.stringify({ fileType: FileType.RecordContent }),\n          wrappedStateKey: reWrappedContent.doubleWrappedKey,\n          cipherMeta: reWrappedContent.cipherMeta,\n        },\n      },\n    });\n\n    try {\n      await this.recordAttachmentService.uploadAttachments(\n        recordId,\n        updatedRecord.attachments\n      );\n    } catch (e) {\n      console.error(e);\n      return { recordId, attachmentError: e };\n    }\n    return { recordId };\n  }\n\n  public async archiveRecord(recordId: string): Promise<void> {\n    // All content of the record should also be archived, hence, recursive=true\n    return this.categoryService.archiveDirectory(recordId, true);\n  }\n\n  public async unarchiveRecord(recordId: string): Promise<void> {\n    // All content of the record should also be unarchived, hence, recursive=true\n    return this.categoryService.unarchiveDirectory(recordId, true);\n  }\n\n  public async deleteRecord(recordId: string): Promise<void> {\n    await this.lrApollo.mutate({\n      mutation: DeleteRecordMutation,\n      variables: { recordId },\n    });\n  }\n}\n"]}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
export class RecordField {
|
|
2
|
-
}
|
|
3
|
-
export class RecordAttachment {
|
|
4
|
-
}
|
|
5
|
-
export class LrRecord {
|
|
6
|
-
}
|
|
7
|
-
export class NewAttachment {
|
|
8
|
-
}
|
|
9
|
-
export class NewRecord {
|
|
10
|
-
}
|
|
11
|
-
export class NewOrUpdatedAttachment extends NewAttachment {
|
|
12
|
-
}
|
|
13
|
-
export class UpdatedRecord {
|
|
14
|
-
}
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9zcmMvbGliL3JlY29yZC9yZWNvcmQudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY0EsTUFBTSxPQUFPLFdBQVc7Q0FNdkI7QUFFRCxNQUFNLE9BQU8sZ0JBQWdCO0NBVTVCO0FBRUQsTUFBTSxPQUFPLFFBQVE7Q0FrQnBCO0FBRUQsTUFBTSxPQUFPLGFBQWE7Q0FJekI7QUFFRCxNQUFNLE9BQU8sU0FBUztDQU9yQjtBQUVELE1BQU0sT0FBTyxzQkFBdUIsU0FBUSxhQUFhO0NBR3hEO0FBRUQsTUFBTSxPQUFPLGFBQWE7Q0FNekIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDYXRlZ29yeSB9IGZyb20gJy4uL2NhdGVnb3J5L2NhdGVnb3J5LnR5cGVzJztcbmltcG9ydCB7XG4gIFJlY29yZEZpZWxkVHlwZSxcbiAgUmVjb3JkVHlwZUZpZWxkT3B0aW9uLFxuICBSZWNvcmRUeXBlU3VtbWFyeSxcbn0gZnJvbSAnLi4vcmVjb3JkLXR5cGUvcmVjb3JkLXR5cGUudHlwZXMnO1xuXG5leHBvcnQgdHlwZSBSZWNvcmRGaWVsZFZhbHVlID1cbiAgfCBzdHJpbmdcbiAgfCBzdHJpbmdbXVxuICB8IFJlY29yZFR5cGVGaWVsZE9wdGlvblxuICB8IFJlY29yZFR5cGVGaWVsZE9wdGlvbltdXG4gIHwgUmVjb3JkRmllbGRbXTtcblxuZXhwb3J0IGNsYXNzIFJlY29yZEZpZWxkIHtcbiAgaWQ/OiBzdHJpbmc7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHR5cGU6IFJlY29yZEZpZWxkVHlwZTtcblxuICB2YWx1ZT86IFJlY29yZEZpZWxkVmFsdWU7XG59XG5cbmV4cG9ydCBjbGFzcyBSZWNvcmRBdHRhY2htZW50IHtcbiAgZmlsZUlkOiBzdHJpbmc7XG4gIGtleUlkOiBzdHJpbmc7XG4gIGZpZWxkSWQ/OiBzdHJpbmc7XG4gIGNvbnRlbnRJZDogc3RyaW5nO1xuXG4gIG5hbWU6IHN0cmluZztcbiAgZmlsZVR5cGU6IHN0cmluZztcbiAgZmlsZVNpemU6IG51bWJlcjtcbiAgbGFzdE1vZGlmaWVkOiBudW1iZXIgfCBEYXRlO1xufVxuXG5leHBvcnQgY2xhc3MgTHJSZWNvcmQge1xuICBpZDogc3RyaW5nO1xuICAvLyBUaGlzIGlzIHRoZSBrZXkgb2YgdGhlIGRpcmVjdG9yeSB0aGF0IHJlcHJlc2VudHMgdGhlIHJlY29yZFxuICBrZXlJZDogc3RyaW5nO1xuICAvLyBUaGlzIGlzIHRoZSBrZXkgb2YgdGhlIGZpbGUgY29udGFpbmVkIGluIHNpZGUgdGhlIHJlY29yZCB0aGF0IGhvbGRzIHRoZSByZWNvcmQncyBmaWVsZHMuXG4gIHVwZGF0ZUtleUlkOiBzdHJpbmc7XG4gIHVwZGF0ZUlkOiBzdHJpbmc7XG5cbiAgbmFtZTogc3RyaW5nO1xuICBjYXRlZ29yaWVzPzogQ2F0ZWdvcnlbXVtdO1xuICBmaWVsZHM/OiBSZWNvcmRGaWVsZFtdO1xuICBhdHRhY2htZW50cz86IFJlY29yZEF0dGFjaG1lbnRbXTtcblxuICByZWNvcmRUeXBlOiBSZWNvcmRUeXBlU3VtbWFyeTtcbiAgY3JlYXRlZE9uOiBzdHJpbmcgfCBEYXRlO1xuICBsYXN0TW9kaWZpZWQ6IHN0cmluZyB8IERhdGU7XG4gIGlzQXJjaGl2ZWQ6IGJvb2xlYW47XG4gIGlzQ29uZmlkZW50aWFsOiBib29sZWFuO1xufVxuXG5leHBvcnQgY2xhc3MgTmV3QXR0YWNobWVudCB7XG4gIGZpZWxkSWQ/OiBzdHJpbmc7XG4gIG5hbWU6IHN0cmluZztcbiAgZmlsZT86IEZpbGU7XG59XG5cbmV4cG9ydCBjbGFzcyBOZXdSZWNvcmQge1xuICBuYW1lOiBzdHJpbmc7XG4gIHJlY29yZFR5cGU6IFJlY29yZFR5cGVTdW1tYXJ5O1xuICBjYXRlZ29yeUlkczogc3RyaW5nW107XG5cbiAgZmllbGRzPzogUmVjb3JkRmllbGRbXTtcbiAgYXR0YWNobWVudHM/OiBOZXdBdHRhY2htZW50W107XG59XG5cbmV4cG9ydCBjbGFzcyBOZXdPclVwZGF0ZWRBdHRhY2htZW50IGV4dGVuZHMgTmV3QXR0YWNobWVudCB7XG4gIGZpbGVJZD86IHN0cmluZztcbiAgaXNEZWxldGVkPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGNsYXNzIFVwZGF0ZWRSZWNvcmQge1xuICBuYW1lOiBzdHJpbmc7XG4gIHJlY29yZFR5cGU6IFJlY29yZFR5cGVTdW1tYXJ5O1xuXG4gIGZpZWxkcz86IFJlY29yZEZpZWxkW107XG4gIGF0dGFjaG1lbnRzPzogTmV3T3JVcGRhdGVkQXR0YWNobWVudFtdO1xufVxuIl19
|
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { HttpClient } from '@angular/common/http';
|
|
3
|
-
import { Injectable } from '@angular/core';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "@angular/common/http";
|
|
6
|
-
const arraysEqual = (a, b) => {
|
|
7
|
-
if (a === b)
|
|
8
|
-
return true;
|
|
9
|
-
if (a == null || b == null)
|
|
10
|
-
return false;
|
|
11
|
-
if (a.length !== b.length)
|
|
12
|
-
return false;
|
|
13
|
-
for (let i = 0; i < a.length; ++i) {
|
|
14
|
-
if (a[i] !== b[i])
|
|
15
|
-
return false;
|
|
16
|
-
}
|
|
17
|
-
return true;
|
|
18
|
-
};
|
|
19
|
-
const ɵ0 = arraysEqual;
|
|
20
|
-
export class RecordTypeService {
|
|
21
|
-
constructor(http) {
|
|
22
|
-
this.http = http;
|
|
23
|
-
}
|
|
24
|
-
getRecordTypes() {
|
|
25
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
26
|
-
if (!this.recordTypes) {
|
|
27
|
-
this.recordTypes = yield this.http
|
|
28
|
-
.get('/assets/meta/record-types.json')
|
|
29
|
-
.toPromise();
|
|
30
|
-
}
|
|
31
|
-
if (!this.categories) {
|
|
32
|
-
this.categories = yield this.http
|
|
33
|
-
.get('/assets/meta/categories.json')
|
|
34
|
-
.toPromise();
|
|
35
|
-
}
|
|
36
|
-
const subCategories = this.categories
|
|
37
|
-
.map((cat) => cat.subCategories)
|
|
38
|
-
.reduce((acc, next) => [...acc, ...next], []);
|
|
39
|
-
const recordTypesWithCategories = this.recordTypes.map((recordType) => (Object.assign(Object.assign({}, recordType), { categoryNames: recordType.categories.map((cat) => {
|
|
40
|
-
return cat.map((categoryCode) => {
|
|
41
|
-
const subCat = subCategories.find((c) => c.code === categoryCode);
|
|
42
|
-
if (subCat) {
|
|
43
|
-
return subCat.name;
|
|
44
|
-
}
|
|
45
|
-
else {
|
|
46
|
-
return this.categories.find((c) => c.code === categoryCode).name;
|
|
47
|
-
}
|
|
48
|
-
});
|
|
49
|
-
}) })));
|
|
50
|
-
return Promise.resolve(recordTypesWithCategories);
|
|
51
|
-
});
|
|
52
|
-
}
|
|
53
|
-
getRecordType(recordTypeId) {
|
|
54
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
55
|
-
return (yield this.getRecordTypes()).find((x) => x.id === recordTypeId);
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
getRecordTypesForCategory(categoryTree) {
|
|
59
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
60
|
-
const recordTypes = yield this.getRecordTypes();
|
|
61
|
-
return recordTypes.filter((x) => x.categories.some((y) => arraysEqual(y, categoryTree)));
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
RecordTypeService.ɵprov = i0.ɵɵdefineInjectable({ factory: function RecordTypeService_Factory() { return new RecordTypeService(i0.ɵɵinject(i1.HttpClient)); }, token: RecordTypeService, providedIn: "root" });
|
|
66
|
-
RecordTypeService.decorators = [
|
|
67
|
-
{ type: Injectable, args: [{
|
|
68
|
-
providedIn: 'root',
|
|
69
|
-
},] }
|
|
70
|
-
];
|
|
71
|
-
RecordTypeService.ctorParameters = () => [
|
|
72
|
-
{ type: HttpClient }
|
|
73
|
-
];
|
|
74
|
-
export { ɵ0 };
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLXR5cGUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9yZWNvcmQtdHlwZS9yZWNvcmQtdHlwZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBSTNDLE1BQU0sV0FBVyxHQUFHLENBQUMsQ0FBVyxFQUFFLENBQVcsRUFBRSxFQUFFO0lBQy9DLElBQUksQ0FBQyxLQUFLLENBQUM7UUFBRSxPQUFPLElBQUksQ0FBQztJQUN6QixJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxJQUFJLElBQUk7UUFBRSxPQUFPLEtBQUssQ0FBQztJQUN6QyxJQUFJLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLE1BQU07UUFBRSxPQUFPLEtBQUssQ0FBQztJQUV4QyxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsRUFBRTtRQUNqQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQUUsT0FBTyxLQUFLLENBQUM7S0FDakM7SUFDRCxPQUFPLElBQUksQ0FBQztBQUNkLENBQUMsQ0FBQzs7QUFLRixNQUFNLE9BQU8saUJBQWlCO0lBSTVCLFlBQW9CLElBQWdCO1FBQWhCLFNBQUksR0FBSixJQUFJLENBQVk7SUFBRyxDQUFDO0lBRTNCLGNBQWM7O1lBQ3pCLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFO2dCQUNyQixJQUFJLENBQUMsV0FBVyxHQUFHLE1BQU0sSUFBSSxDQUFDLElBQUk7cUJBQy9CLEdBQUcsQ0FBZSxnQ0FBZ0MsQ0FBQztxQkFDbkQsU0FBUyxFQUFFLENBQUM7YUFDaEI7WUFDRCxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRTtnQkFDcEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxNQUFNLElBQUksQ0FBQyxJQUFJO3FCQUM5QixHQUFHLENBQW9CLDhCQUE4QixDQUFDO3FCQUN0RCxTQUFTLEVBQUUsQ0FBQzthQUNoQjtZQUVELE1BQU0sYUFBYSxHQUFHLElBQUksQ0FBQyxVQUFVO2lCQUNsQyxHQUFHLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLEdBQUcsQ0FBQyxhQUFhLENBQUM7aUJBQy9CLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUMsR0FBRyxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztZQUVoRCxNQUFNLHlCQUF5QixHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLENBQUMsVUFBVSxFQUFFLEVBQUUsQ0FBQyxpQ0FDbEUsVUFBVSxLQUNiLGFBQWEsRUFBRSxVQUFVLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO29CQUMvQyxPQUFPLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxZQUFZLEVBQUUsRUFBRTt3QkFDOUIsTUFBTSxNQUFNLEdBQUcsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxZQUFZLENBQUMsQ0FBQzt3QkFDbEUsSUFBSSxNQUFNLEVBQUU7NEJBQ1YsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDO3lCQUNwQjs2QkFBTTs0QkFDTCxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxLQUFLLFlBQVksQ0FBQyxDQUFDLElBQUksQ0FBQzt5QkFDbEU7b0JBQ0gsQ0FBQyxDQUFDLENBQUM7Z0JBQ0wsQ0FBQyxDQUFDLElBQ0YsQ0FBQyxDQUFDO1lBQ0osT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLHlCQUF5QixDQUFDLENBQUM7UUFDcEQsQ0FBQztLQUFBO0lBRVksYUFBYSxDQUFDLFlBQW9COztZQUM3QyxPQUFPLENBQUMsTUFBTSxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssWUFBWSxDQUFDLENBQUM7UUFDMUUsQ0FBQztLQUFBO0lBRVkseUJBQXlCLENBQ3BDLFlBQXNCOztZQUV0QixNQUFNLFdBQVcsR0FBRyxNQUFNLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUVoRCxPQUFPLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUM5QixDQUFDLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsV0FBVyxDQUFDLENBQUMsRUFBRSxZQUFZLENBQUMsQ0FBQyxDQUN2RCxDQUFDO1FBQ0osQ0FBQztLQUFBOzs7O1lBckRGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7O1lBbEJRLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGVmYXVsdENhdGVnb3J5IH0gZnJvbSAnLi4vY2F0ZWdvcnkvY2F0ZWdvcnkudHlwZXMnO1xuaW1wb3J0IHsgUmVjb3JkVHlwZSB9IGZyb20gJy4vcmVjb3JkLXR5cGUudHlwZXMnO1xuXG5jb25zdCBhcnJheXNFcXVhbCA9IChhOiBzdHJpbmdbXSwgYjogc3RyaW5nW10pID0+IHtcbiAgaWYgKGEgPT09IGIpIHJldHVybiB0cnVlO1xuICBpZiAoYSA9PSBudWxsIHx8IGIgPT0gbnVsbCkgcmV0dXJuIGZhbHNlO1xuICBpZiAoYS5sZW5ndGggIT09IGIubGVuZ3RoKSByZXR1cm4gZmFsc2U7XG5cbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBhLmxlbmd0aDsgKytpKSB7XG4gICAgaWYgKGFbaV0gIT09IGJbaV0pIHJldHVybiBmYWxzZTtcbiAgfVxuICByZXR1cm4gdHJ1ZTtcbn07XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBSZWNvcmRUeXBlU2VydmljZSB7XG4gIHByaXZhdGUgcmVjb3JkVHlwZXM6IFJlY29yZFR5cGVbXTtcbiAgcHJpdmF0ZSBjYXRlZ29yaWVzOiBEZWZhdWx0Q2F0ZWdvcnlbXTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGh0dHA6IEh0dHBDbGllbnQpIHt9XG5cbiAgcHVibGljIGFzeW5jIGdldFJlY29yZFR5cGVzKCk6IFByb21pc2U8UmVjb3JkVHlwZVtdPiB7XG4gICAgaWYgKCF0aGlzLnJlY29yZFR5cGVzKSB7XG4gICAgICB0aGlzLnJlY29yZFR5cGVzID0gYXdhaXQgdGhpcy5odHRwXG4gICAgICAgIC5nZXQ8UmVjb3JkVHlwZVtdPignL2Fzc2V0cy9tZXRhL3JlY29yZC10eXBlcy5qc29uJylcbiAgICAgICAgLnRvUHJvbWlzZSgpO1xuICAgIH1cbiAgICBpZiAoIXRoaXMuY2F0ZWdvcmllcykge1xuICAgICAgdGhpcy5jYXRlZ29yaWVzID0gYXdhaXQgdGhpcy5odHRwXG4gICAgICAgIC5nZXQ8RGVmYXVsdENhdGVnb3J5W10+KCcvYXNzZXRzL21ldGEvY2F0ZWdvcmllcy5qc29uJylcbiAgICAgICAgLnRvUHJvbWlzZSgpO1xuICAgIH1cblxuICAgIGNvbnN0IHN1YkNhdGVnb3JpZXMgPSB0aGlzLmNhdGVnb3JpZXNcbiAgICAgIC5tYXAoKGNhdCkgPT4gY2F0LnN1YkNhdGVnb3JpZXMpXG4gICAgICAucmVkdWNlKChhY2MsIG5leHQpID0+IFsuLi5hY2MsIC4uLm5leHRdLCBbXSk7XG5cbiAgICBjb25zdCByZWNvcmRUeXBlc1dpdGhDYXRlZ29yaWVzID0gdGhpcy5yZWNvcmRUeXBlcy5tYXAoKHJlY29yZFR5cGUpID0+ICh7XG4gICAgICAuLi5yZWNvcmRUeXBlLFxuICAgICAgY2F0ZWdvcnlOYW1lczogcmVjb3JkVHlwZS5jYXRlZ29yaWVzLm1hcCgoY2F0KSA9PiB7XG4gICAgICAgIHJldHVybiBjYXQubWFwKChjYXRlZ29yeUNvZGUpID0+IHtcbiAgICAgICAgICBjb25zdCBzdWJDYXQgPSBzdWJDYXRlZ29yaWVzLmZpbmQoKGMpID0+IGMuY29kZSA9PT0gY2F0ZWdvcnlDb2RlKTtcbiAgICAgICAgICBpZiAoc3ViQ2F0KSB7XG4gICAgICAgICAgICByZXR1cm4gc3ViQ2F0Lm5hbWU7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiB0aGlzLmNhdGVnb3JpZXMuZmluZCgoYykgPT4gYy5jb2RlID09PSBjYXRlZ29yeUNvZGUpLm5hbWU7XG4gICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICAgIH0pLFxuICAgIH0pKTtcbiAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKHJlY29yZFR5cGVzV2l0aENhdGVnb3JpZXMpO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGdldFJlY29yZFR5cGUocmVjb3JkVHlwZUlkOiBzdHJpbmcpOiBQcm9taXNlPFJlY29yZFR5cGU+IHtcbiAgICByZXR1cm4gKGF3YWl0IHRoaXMuZ2V0UmVjb3JkVHlwZXMoKSkuZmluZCgoeCkgPT4geC5pZCA9PT0gcmVjb3JkVHlwZUlkKTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBnZXRSZWNvcmRUeXBlc0ZvckNhdGVnb3J5KFxuICAgIGNhdGVnb3J5VHJlZTogc3RyaW5nW11cbiAgKTogUHJvbWlzZTxSZWNvcmRUeXBlW10+IHtcbiAgICBjb25zdCByZWNvcmRUeXBlcyA9IGF3YWl0IHRoaXMuZ2V0UmVjb3JkVHlwZXMoKTtcblxuICAgIHJldHVybiByZWNvcmRUeXBlcy5maWx0ZXIoKHgpID0+XG4gICAgICB4LmNhdGVnb3JpZXMuc29tZSgoeSkgPT4gYXJyYXlzRXF1YWwoeSwgY2F0ZWdvcnlUcmVlKSlcbiAgICApO1xuICB9XG59XG4iXX0=
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
export var RecordFieldType;
|
|
2
|
-
(function (RecordFieldType) {
|
|
3
|
-
RecordFieldType["Text"] = "text";
|
|
4
|
-
RecordFieldType["Email"] = "email";
|
|
5
|
-
RecordFieldType["Url"] = "url";
|
|
6
|
-
RecordFieldType["Phone"] = "phone";
|
|
7
|
-
RecordFieldType["Date"] = "date";
|
|
8
|
-
RecordFieldType["Password"] = "password";
|
|
9
|
-
RecordFieldType["TextArea"] = "textArea";
|
|
10
|
-
RecordFieldType["Select"] = "select";
|
|
11
|
-
RecordFieldType["SingleChoice"] = "singleChoice";
|
|
12
|
-
RecordFieldType["MultiChoice"] = "multiChoice";
|
|
13
|
-
RecordFieldType["File"] = "file";
|
|
14
|
-
RecordFieldType["MultiFile"] = "multiFile";
|
|
15
|
-
RecordFieldType["Record"] = "record";
|
|
16
|
-
RecordFieldType["MultiRecord"] = "multiRecord";
|
|
17
|
-
RecordFieldType["Group"] = "group";
|
|
18
|
-
RecordFieldType["Custom"] = "custom";
|
|
19
|
-
})(RecordFieldType || (RecordFieldType = {}));
|
|
20
|
-
export class RecordType {
|
|
21
|
-
}
|
|
22
|
-
export class RecordTypeFieldOption {
|
|
23
|
-
}
|
|
24
|
-
export class RecordTypeField {
|
|
25
|
-
}
|
|
26
|
-
export class RecordTypeSummary {
|
|
27
|
-
}
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLXR5cGUudHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3NyYy9saWIvcmVjb3JkLXR5cGUvcmVjb3JkLXR5cGUudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksZUFpQlg7QUFqQkQsV0FBWSxlQUFlO0lBQ3pCLGdDQUFhLENBQUE7SUFDYixrQ0FBZSxDQUFBO0lBQ2YsOEJBQVcsQ0FBQTtJQUNYLGtDQUFlLENBQUE7SUFDZixnQ0FBYSxDQUFBO0lBQ2Isd0NBQXFCLENBQUE7SUFDckIsd0NBQXFCLENBQUE7SUFDckIsb0NBQWlCLENBQUE7SUFDakIsZ0RBQTZCLENBQUE7SUFDN0IsOENBQTJCLENBQUE7SUFDM0IsZ0NBQWEsQ0FBQTtJQUNiLDBDQUF1QixDQUFBO0lBQ3ZCLG9DQUFpQixDQUFBO0lBQ2pCLDhDQUEyQixDQUFBO0lBQzNCLGtDQUFlLENBQUE7SUFDZixvQ0FBaUIsQ0FBQTtBQUNuQixDQUFDLEVBakJXLGVBQWUsS0FBZixlQUFlLFFBaUIxQjtBQUVELE1BQU0sT0FBTyxVQUFVO0NBWXRCO0FBRUQsTUFBTSxPQUFPLHFCQUFxQjtDQUlqQztBQUVELE1BQU0sT0FBTyxlQUFlO0NBWTNCO0FBRUQsTUFBTSxPQUFPLGlCQUFpQjtDQUk3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFJlY29yZEZpZWxkVHlwZSB7XG4gIFRleHQgPSAndGV4dCcsXG4gIEVtYWlsID0gJ2VtYWlsJyxcbiAgVXJsID0gJ3VybCcsXG4gIFBob25lID0gJ3Bob25lJyxcbiAgRGF0ZSA9ICdkYXRlJyxcbiAgUGFzc3dvcmQgPSAncGFzc3dvcmQnLFxuICBUZXh0QXJlYSA9ICd0ZXh0QXJlYScsXG4gIFNlbGVjdCA9ICdzZWxlY3QnLFxuICBTaW5nbGVDaG9pY2UgPSAnc2luZ2xlQ2hvaWNlJyxcbiAgTXVsdGlDaG9pY2UgPSAnbXVsdGlDaG9pY2UnLFxuICBGaWxlID0gJ2ZpbGUnLFxuICBNdWx0aUZpbGUgPSAnbXVsdGlGaWxlJyxcbiAgUmVjb3JkID0gJ3JlY29yZCcsXG4gIE11bHRpUmVjb3JkID0gJ211bHRpUmVjb3JkJyxcbiAgR3JvdXAgPSAnZ3JvdXAnLFxuICBDdXN0b20gPSAnY3VzdG9tJyxcbn1cblxuZXhwb3J0IGNsYXNzIFJlY29yZFR5cGUge1xuICBpZDogc3RyaW5nO1xuICB2ZXJzaW9uOiBudW1iZXI7XG4gIG5hbWU6IHN0cmluZztcbiAgdGFnczogc3RyaW5nW107XG5cbiAgYWxsb3dBdHRhY2htZW50czogYm9vbGVhbjtcbiAgYWxsb3dDdXN0b21GaWVsZHM6IGJvb2xlYW47XG5cbiAgZmllbGRzOiBSZWNvcmRUeXBlRmllbGRbXTtcbiAgY2F0ZWdvcmllczogc3RyaW5nW11bXTtcbiAgY2F0ZWdvcnlOYW1lczogc3RyaW5nW11bXTtcbn1cblxuZXhwb3J0IGNsYXNzIFJlY29yZFR5cGVGaWVsZE9wdGlvbiB7XG4gIG5hbWU6IHN0cmluZztcblxuICBjYXRlZ29yaWVzPzogc3RyaW5nW11bXTtcbn1cblxuZXhwb3J0IGNsYXNzIFJlY29yZFR5cGVGaWVsZCB7XG4gIGlkOiBzdHJpbmc7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHR5cGU6IFJlY29yZEZpZWxkVHlwZTtcbiAgcGxhY2Vob2xkZXI/OiBzdHJpbmc7XG4gIGhpbnQ/OiBzdHJpbmc7XG4gIGlzTWFuZGF0b3J5PzogYm9vbGVhbjtcblxuICBvcHRpb25zPzogUmVjb3JkVHlwZUZpZWxkT3B0aW9uW107XG4gIGV4dGVuc2lvbnM/OiBzdHJpbmc7XG4gIHJlY29yZFR5cGVJZHM/OiBzdHJpbmdbXTtcbiAgZmllbGRzPzogUmVjb3JkVHlwZUZpZWxkW107XG59XG5cbmV4cG9ydCBjbGFzcyBSZWNvcmRUeXBlU3VtbWFyeSB7XG4gIGlkOiBzdHJpbmc7XG4gIHZlcnNpb246IG51bWJlcjtcbiAgbmFtZTogc3RyaW5nO1xufVxuIl19
|