@coralogix/rum-cli 1.1.38 → 1.1.41
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/README.md +1 -0
- package/api/base/base.api.ts +27 -30
- package/api/source-maps/source-maps.api.ts +78 -0
- package/cli/commands/source-maps/upload-source-maps-command.ts +3 -2
- package/consts/consts.ts +1 -0
- package/dist/api/base/base.api.d.ts +9 -7
- package/dist/api/base/base.api.js +14 -19
- package/dist/api/source-maps/source-maps.api.d.ts +5 -2
- package/dist/api/source-maps/source-maps.api.js +57 -3
- package/dist/cli/commands/source-maps/upload-source-maps-command.js +4 -3
- package/dist/consts/consts.js +3 -2
- package/dist/grpc-client/grpc-client-factory.d.ts +72 -0
- package/dist/models/source-maps-commands.model.d.ts +1 -0
- package/dist/models/source-maps-commands.model.js +1 -1
- package/dist/proto-models/com/coralogix/blobset/v2/blobset_query_service.d.ts +150 -0
- package/dist/proto-models/com/coralogix/blobset/v2/blobset_query_service.js +29 -1
- package/dist/proto-models/com/coralogix/blobset/v2/case_file.d.ts +36 -0
- package/dist/proto-models/com/coralogix/blobset/v2/case_file.js +161 -0
- package/dist/proto-models/com/coralogix/blobset/v2/dsym.d.ts +1 -0
- package/dist/proto-models/com/coralogix/blobset/v2/dsym.js +33 -3
- package/dist/proto-models/com/coralogix/blobset/v2/entity_metadata.d.ts +31 -0
- package/dist/proto-models/com/coralogix/blobset/v2/entity_metadata.js +215 -7
- package/dist/proto-models/com/coralogix/blobset/v2/entity_type.d.ts +3 -1
- package/dist/proto-models/com/coralogix/blobset/v2/entity_type.js +13 -1
- package/dist/proto-models/com/coralogix/blobset/v2/investigation_file.d.ts +36 -0
- package/dist/proto-models/com/coralogix/blobset/v2/investigation_file.js +161 -0
- package/dist/proto-models/com/coralogix/blobset/v2/proguard.d.ts +68 -0
- package/dist/proto-models/com/coralogix/blobset/v2/proguard.js +400 -0
- package/dist/proto-models/com/coralogix/rum/v2/application_releases.d.ts +38 -0
- package/dist/proto-models/com/coralogix/rum/v2/application_releases.js +180 -0
- package/dist/proto-models/com/coralogix/rum/v2/merge_error.d.ts +38 -0
- package/dist/proto-models/com/coralogix/rum/v2/merge_error.js +171 -0
- package/dist/proto-models/com/coralogix/rum/v2/release_entity_metadata.d.ts +4 -0
- package/dist/proto-models/com/coralogix/rum/v2/release_entity_metadata.js +93 -9
- package/dist/proto-models/com/coralogix/rum/v2/rum_merge_erros_service.d.ts +197 -0
- package/dist/proto-models/com/coralogix/rum/v2/rum_merge_erros_service.js +478 -0
- package/dist/proto-models/com/coralogix/rum/v2/rum_service.d.ts +107 -0
- package/dist/proto-models/com/coralogix/rum/v2/rum_service.js +385 -2
- package/dist/proto-models/com/coralogix/rum/v2/rum_source_map_service.d.ts +46 -0
- package/dist/proto-models/com/coralogix/rum/v2/rum_source_map_service.js +142 -2
- package/dist/proto-models/com/coralogix/rum/v2/saved_filter.d.ts +4 -1
- package/dist/proto-models/com/coralogix/rum/v2/saved_filter.js +19 -1
- package/dist/proto-models/com/coralogix/rum/v2/template.d.ts +2 -0
- package/dist/proto-models/com/coralogix/rum/v2/template.js +31 -3
- package/dist/services/source-maps/source-maps.service.d.ts +1 -0
- package/dist/services/source-maps/source-maps.service.js +23 -1
- package/models/source-maps-commands.model.ts +1 -0
- package/package.json +1 -1
- package/proto-models/com/coralogix/blobset/v2/blobset_query_service.ts +28 -0
- package/proto-models/com/coralogix/blobset/v2/case_file.ts +188 -0
- package/proto-models/com/coralogix/blobset/v2/dsym.ts +35 -1
- package/proto-models/com/coralogix/blobset/v2/entity_metadata.ts +243 -1
- package/proto-models/com/coralogix/blobset/v2/entity_type.ts +12 -0
- package/proto-models/com/coralogix/blobset/v2/investigation_file.ts +188 -0
- package/proto-models/com/coralogix/blobset/v2/proguard.ts +466 -0
- package/proto-models/com/coralogix/rum/v2/application_releases.ts +213 -0
- package/proto-models/com/coralogix/rum/v2/merge_error.ts +201 -0
- package/proto-models/com/coralogix/rum/v2/release_entity_metadata.ts +96 -4
- package/proto-models/com/coralogix/rum/v2/rum_merge_erros_service.ts +566 -0
- package/proto-models/com/coralogix/rum/v2/rum_service.ts +462 -0
- package/proto-models/com/coralogix/rum/v2/rum_source_map_service.ts +164 -0
- package/proto-models/com/coralogix/rum/v2/saved_filter.ts +18 -0
- package/proto-models/com/coralogix/rum/v2/template.ts +33 -1
- package/protofetch.lock +4 -4
- package/protofetch.toml +2 -2
- package/protos/com/coralogix/blobset/v2/blobset_query_service.proto +7 -0
- package/protos/com/coralogix/blobset/v2/case_file.proto +12 -0
- package/protos/com/coralogix/blobset/v2/dsym.proto +1 -0
- package/protos/com/coralogix/blobset/v2/entity_metadata.proto +14 -1
- package/protos/com/coralogix/blobset/v2/entity_type.proto +3 -1
- package/protos/com/coralogix/blobset/v2/investigation_file.proto +12 -0
- package/protos/com/coralogix/blobset/v2/proguard.proto +30 -0
- package/protos/com/coralogix/rum/v2/application_releases.proto +14 -0
- package/protos/com/coralogix/rum/v2/merge_error.proto +13 -0
- package/protos/com/coralogix/rum/v2/release_entity_metadata.proto +7 -0
- package/protos/com/coralogix/rum/v2/rum_merge_erros_service.proto +42 -0
- package/protos/com/coralogix/rum/v2/rum_service.proto +23 -0
- package/protos/com/coralogix/rum/v2/rum_source_map_service.proto +11 -0
- package/protos/com/coralogix/rum/v2/saved_filter.proto +3 -0
- package/protos/com/coralogix/rum/v2/template.proto +2 -0
- package/protoset.bin +0 -0
- package/services/source-maps/source-maps.service.ts +26 -0
package/README.md
CHANGED
|
@@ -68,6 +68,7 @@ coralogix-rum-cli upload-proguard -k <privateKey> -a <application> -v <version>
|
|
|
68
68
|
- `-c, --commit-hash <commitHash>`: GitHub commit hash (optional).
|
|
69
69
|
- `-n, --repo-name <repoName>`: GitHub repository name (optional).
|
|
70
70
|
- `-o, --org-name <orgName>`: GitHub organization name (optional).
|
|
71
|
+
- `--override`: Override existing source maps (optional).
|
|
71
72
|
- `-h, --help`: Display help.
|
|
72
73
|
|
|
73
74
|
## Environments
|
package/api/base/base.api.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Client, ClientError, Metadata, Status } from 'nice-grpc';
|
|
2
2
|
import { BlobSetServiceDefinition, UploadBlobRequest } from '../../proto-models/com/coralogix/blobset/v2/blobset_service';
|
|
3
|
-
import {
|
|
3
|
+
import { createUploadBlobRequestChunks, validateCompressedFilesSize } from '../../utils/shared.utils';
|
|
4
4
|
import { GrpcClientFactory } from '../../grpc-client/grpc-client-factory';
|
|
5
5
|
import { CreateEntityReleaseRequest, RumSourceMapServiceDefinition } from '../../proto-models/com/coralogix/rum/v2/rum_source_map_service';
|
|
6
6
|
import { EntityType } from '../../proto-models/com/coralogix/blobset/v2/entity_type';
|
|
@@ -18,6 +18,7 @@ export abstract class BaseApi {
|
|
|
18
18
|
repoName?: string,
|
|
19
19
|
commitHash?: string,
|
|
20
20
|
orgName?: string,
|
|
21
|
+
internalVersion?: number,
|
|
21
22
|
): ReleaseEntityMetadata;
|
|
22
23
|
protected abstract buildEntityMetadata(
|
|
23
24
|
application: string,
|
|
@@ -25,9 +26,10 @@ export abstract class BaseApi {
|
|
|
25
26
|
repoName?: string,
|
|
26
27
|
commitHash?: string,
|
|
27
28
|
orgName?: string,
|
|
29
|
+
internalVersion?: number,
|
|
28
30
|
): EntityMetadata;
|
|
29
31
|
|
|
30
|
-
|
|
32
|
+
protected async uploadBlob(
|
|
31
33
|
blobSetClient: Client<typeof BlobSetServiceDefinition>,
|
|
32
34
|
request: UploadBlobRequest,
|
|
33
35
|
entityMetadata: EntityMetadata | undefined,
|
|
@@ -41,8 +43,8 @@ export abstract class BaseApi {
|
|
|
41
43
|
await blobSetClient.uploadBlob(iterableRequest, { metadata });
|
|
42
44
|
}
|
|
43
45
|
|
|
44
|
-
|
|
45
|
-
|
|
46
|
+
protected async createEntityRelease(
|
|
47
|
+
rumClient: Client<typeof RumSourceMapServiceDefinition>,
|
|
46
48
|
releaseEntityMetadata: ReleaseEntityMetadata | undefined,
|
|
47
49
|
metadata: Metadata,
|
|
48
50
|
): Promise<void> {
|
|
@@ -51,23 +53,23 @@ export abstract class BaseApi {
|
|
|
51
53
|
releaseEntityMetadata,
|
|
52
54
|
};
|
|
53
55
|
|
|
54
|
-
await
|
|
56
|
+
await rumClient.createEntityRelease(request, { metadata });
|
|
55
57
|
}
|
|
56
58
|
|
|
57
|
-
|
|
59
|
+
protected createGrpcMetadata(privateKey: string): Metadata {
|
|
58
60
|
const metadata: Metadata = new Metadata();
|
|
59
61
|
metadata.set('Authorization', `Bearer ${privateKey}`);
|
|
60
62
|
return metadata;
|
|
61
63
|
}
|
|
62
64
|
|
|
63
|
-
|
|
64
|
-
|
|
65
|
+
protected async checkEntityReleaseExists(
|
|
66
|
+
rumClient: Client<typeof RumSourceMapServiceDefinition>,
|
|
65
67
|
application: string,
|
|
66
68
|
version: string,
|
|
67
69
|
metadata: Metadata,
|
|
68
70
|
): Promise<boolean> {
|
|
69
71
|
try {
|
|
70
|
-
const { exists } = await
|
|
72
|
+
const { exists } = await rumClient.isEntityReleaseExists(
|
|
71
73
|
{ releaseId: version, application, releaseEntityType: this.getReleaseEntityType() },
|
|
72
74
|
{ metadata },
|
|
73
75
|
);
|
|
@@ -94,32 +96,27 @@ export abstract class BaseApi {
|
|
|
94
96
|
): Promise<void> {
|
|
95
97
|
const metadata: Metadata = this.createGrpcMetadata(privateKey);
|
|
96
98
|
const blobSetClient = GrpcClientFactory.getBlobSetGrpcClient(env, this.getMaxCompressedFileSize());
|
|
97
|
-
const
|
|
99
|
+
const rumClient = GrpcClientFactory.getRumSourceMapGrpcClient(env, this.getMaxCompressedFileSize());
|
|
98
100
|
|
|
99
|
-
|
|
100
|
-
validateCompressedFilesSize(request.data.length, this.getMaxCompressedFileSize());
|
|
101
|
-
|
|
102
|
-
const releaseExists: boolean = await this.checkEntityReleaseExists(rumSourceMapClient, application, version, metadata);
|
|
101
|
+
validateCompressedFilesSize(request.data.length, this.getMaxCompressedFileSize());
|
|
103
102
|
|
|
104
|
-
|
|
105
|
-
throw new Error(`Entity release already exists for releaseId: ${version} and application: ${application}`);
|
|
106
|
-
}
|
|
103
|
+
const releaseExists = await this.checkEntityReleaseExists(rumClient, application, version, metadata);
|
|
107
104
|
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
repoName,
|
|
112
|
-
commitHash,
|
|
113
|
-
orgName,
|
|
114
|
-
);
|
|
105
|
+
if (releaseExists) {
|
|
106
|
+
throw new Error(`Entity release already exists for releaseId: ${version} and application: ${application}`);
|
|
107
|
+
}
|
|
115
108
|
|
|
116
|
-
|
|
109
|
+
const releaseEntityMetadata: ReleaseEntityMetadata = this.buildReleaseEntityMetadata(
|
|
110
|
+
application,
|
|
111
|
+
version,
|
|
112
|
+
repoName,
|
|
113
|
+
commitHash,
|
|
114
|
+
orgName,
|
|
115
|
+
);
|
|
117
116
|
|
|
118
|
-
|
|
117
|
+
const entityMetadata: EntityMetadata = this.buildEntityMetadata(application, version, repoName, commitHash, orgName);
|
|
119
118
|
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
throw error;
|
|
123
|
-
}
|
|
119
|
+
await this.uploadBlob(blobSetClient, request, entityMetadata, metadata);
|
|
120
|
+
await this.createEntityRelease(rumClient, releaseEntityMetadata, metadata);
|
|
124
121
|
}
|
|
125
122
|
}
|
|
@@ -4,6 +4,11 @@ import config from '../../config/config';
|
|
|
4
4
|
import { BaseApi } from '../base/base.api';
|
|
5
5
|
import { ReleaseEntityMetadata } from '../../proto-models/com/coralogix/rum/v2/release_entity_metadata';
|
|
6
6
|
import { EntityMetadata } from '../../proto-models/com/coralogix/blobset/v2/entity_metadata';
|
|
7
|
+
import { UploadBlobRequest } from '../../proto-models/com/coralogix/blobset/v2/blobset_service';
|
|
8
|
+
import { Client, ClientError, Metadata, Status } from 'nice-grpc';
|
|
9
|
+
import { GrpcClientFactory } from '../../grpc-client/grpc-client-factory';
|
|
10
|
+
import { validateCompressedFilesSize } from '../../utils/shared.utils';
|
|
11
|
+
import { RumSourceMapServiceDefinition } from '../../proto-models/com/coralogix/rum/v2/rum_source_map_service';
|
|
7
12
|
|
|
8
13
|
export class SourceMapsApi extends BaseApi {
|
|
9
14
|
protected getEntityType(): EntityType {
|
|
@@ -24,6 +29,7 @@ export class SourceMapsApi extends BaseApi {
|
|
|
24
29
|
repoName?: string,
|
|
25
30
|
commitHash?: string,
|
|
26
31
|
orgName?: string,
|
|
32
|
+
internalVersion?: number,
|
|
27
33
|
): ReleaseEntityMetadata {
|
|
28
34
|
return {
|
|
29
35
|
metadata: {
|
|
@@ -34,6 +40,7 @@ export class SourceMapsApi extends BaseApi {
|
|
|
34
40
|
repoName: repoName || '',
|
|
35
41
|
commitHash: commitHash || '',
|
|
36
42
|
orgName: orgName || '',
|
|
43
|
+
internalVersion: internalVersion ?? 0,
|
|
37
44
|
},
|
|
38
45
|
},
|
|
39
46
|
};
|
|
@@ -45,6 +52,7 @@ export class SourceMapsApi extends BaseApi {
|
|
|
45
52
|
repoName?: string,
|
|
46
53
|
commitHash?: string,
|
|
47
54
|
orgName?: string,
|
|
55
|
+
internalVersion?: number,
|
|
48
56
|
): EntityMetadata {
|
|
49
57
|
return {
|
|
50
58
|
metadata: {
|
|
@@ -55,8 +63,78 @@ export class SourceMapsApi extends BaseApi {
|
|
|
55
63
|
repoName: repoName || '',
|
|
56
64
|
commitHash: commitHash || '',
|
|
57
65
|
orgName: orgName || '',
|
|
66
|
+
internalVersion: internalVersion ?? 0,
|
|
58
67
|
},
|
|
59
68
|
},
|
|
60
69
|
};
|
|
61
70
|
}
|
|
71
|
+
|
|
72
|
+
public async upload(
|
|
73
|
+
request: UploadBlobRequest,
|
|
74
|
+
application: string,
|
|
75
|
+
version: string,
|
|
76
|
+
repoName: string | undefined,
|
|
77
|
+
commitHash: string | undefined,
|
|
78
|
+
orgName: string | undefined,
|
|
79
|
+
env: string,
|
|
80
|
+
privateKey: string,
|
|
81
|
+
override = false,
|
|
82
|
+
): Promise<void> {
|
|
83
|
+
const metadata: Metadata = this.createGrpcMetadata(privateKey);
|
|
84
|
+
const blobSetClient = GrpcClientFactory.getBlobSetGrpcClient(env, this.getMaxCompressedFileSize());
|
|
85
|
+
const rumClient = GrpcClientFactory.getRumSourceMapGrpcClient(env, this.getMaxCompressedFileSize());
|
|
86
|
+
|
|
87
|
+
validateCompressedFilesSize(request.data.length, this.getMaxCompressedFileSize());
|
|
88
|
+
|
|
89
|
+
let internalVersion: number | undefined;
|
|
90
|
+
|
|
91
|
+
if (override) {
|
|
92
|
+
internalVersion = await this.updateInternalVersion(rumClient, application, version, metadata);
|
|
93
|
+
} else {
|
|
94
|
+
const releaseExists = await this.checkEntityReleaseExists(rumClient, application, version, metadata);
|
|
95
|
+
|
|
96
|
+
if (releaseExists) {
|
|
97
|
+
throw new Error(`Entity release already exists for releaseId: ${version} and application: ${application}`);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
const releaseEntityMetadata: ReleaseEntityMetadata = this.buildReleaseEntityMetadata(
|
|
102
|
+
application,
|
|
103
|
+
version,
|
|
104
|
+
repoName,
|
|
105
|
+
commitHash,
|
|
106
|
+
orgName,
|
|
107
|
+
internalVersion,
|
|
108
|
+
);
|
|
109
|
+
|
|
110
|
+
const entityMetadata: EntityMetadata = this.buildEntityMetadata(application, version, repoName, commitHash, orgName, internalVersion);
|
|
111
|
+
|
|
112
|
+
await this.uploadBlob(blobSetClient, request, entityMetadata, metadata);
|
|
113
|
+
await this.createEntityRelease(rumClient, releaseEntityMetadata, metadata);
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
private async updateInternalVersion(
|
|
117
|
+
client: Client<typeof RumSourceMapServiceDefinition>,
|
|
118
|
+
application: string,
|
|
119
|
+
version: string,
|
|
120
|
+
metadata: Metadata,
|
|
121
|
+
): Promise<number> {
|
|
122
|
+
try {
|
|
123
|
+
const { latestVersion } = await client.getLatestInternalVersion(
|
|
124
|
+
{
|
|
125
|
+
application,
|
|
126
|
+
releaseId: version,
|
|
127
|
+
releaseEntityType: this.getReleaseEntityType(),
|
|
128
|
+
},
|
|
129
|
+
{ metadata },
|
|
130
|
+
);
|
|
131
|
+
|
|
132
|
+
return (latestVersion ?? -1) + 1;
|
|
133
|
+
} catch (error) {
|
|
134
|
+
if (error instanceof ClientError && error.code === Status.PERMISSION_DENIED) {
|
|
135
|
+
throw new Error(`Permission denied: Verify private key. Details: ${error.message}`);
|
|
136
|
+
}
|
|
137
|
+
throw error;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
62
140
|
}
|
|
@@ -14,6 +14,7 @@ export const uploadSourceMapsCommand = () => {
|
|
|
14
14
|
.option('-c, --commit-hash <commitHash>', 'GitHub commit hash (optional)')
|
|
15
15
|
.option('-n, --repo-name <repoName>', 'GitHub Repository name (optional)')
|
|
16
16
|
.option('-o, --org-name <orgName>', 'GitHub user name (optional)')
|
|
17
|
+
.option('--override', 'Override existing source maps (optional)')
|
|
17
18
|
.description('Update source maps')
|
|
18
19
|
.action(async (options: UploadSourceMapsCommandOptions) => {
|
|
19
20
|
try {
|
|
@@ -22,13 +23,13 @@ export const uploadSourceMapsCommand = () => {
|
|
|
22
23
|
process.exit(0);
|
|
23
24
|
}
|
|
24
25
|
|
|
25
|
-
const { privateKey, application, version, folderPath, commitHash, repoName, orgName, env } = options;
|
|
26
|
+
const { privateKey, application, version, folderPath, commitHash, repoName, orgName, env, override } = options;
|
|
26
27
|
|
|
27
28
|
checkMissingArguments<UploadSourceMapsCommandOptions>(options, ['privateKey', 'application', 'version', 'folderPath', 'env']);
|
|
28
29
|
|
|
29
30
|
const service: SourceMapsService = new SourceMapsService();
|
|
30
31
|
|
|
31
|
-
await service.upload(application, version, repoName, commitHash, orgName, folderPath, env, privateKey);
|
|
32
|
+
await service.upload(application, version, repoName, commitHash, orgName, folderPath, env, privateKey, override);
|
|
32
33
|
} catch (error) {
|
|
33
34
|
consoleError(error);
|
|
34
35
|
}
|
package/consts/consts.ts
CHANGED
|
@@ -16,4 +16,5 @@ export const envToDomain: Record<string, string> = {
|
|
|
16
16
|
AP1: 'https://ng-api-grpc.app.coralogix.in:443', // ap-south-1 (Mumbai)
|
|
17
17
|
AP2: 'https://ng-api-grpc.coralogixsg.com:443', // ap-southeast-1 (Singapore)
|
|
18
18
|
AP3: 'https://ng-api-grpc.ap3.coralogix.com:443', // ap-southeast-3 (Jakarta)
|
|
19
|
+
STG: 'https://ng-api-grpc.app.staging.coralogix.net:443',
|
|
19
20
|
};
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Client, Metadata } from 'nice-grpc';
|
|
2
|
+
import { BlobSetServiceDefinition, UploadBlobRequest } from '../../proto-models/com/coralogix/blobset/v2/blobset_service';
|
|
3
|
+
import { RumSourceMapServiceDefinition } from '../../proto-models/com/coralogix/rum/v2/rum_source_map_service';
|
|
2
4
|
import { EntityType } from '../../proto-models/com/coralogix/blobset/v2/entity_type';
|
|
3
5
|
import { ReleaseEntityType } from '../../proto-models/com/coralogix/rum/v2/release_entity_type';
|
|
4
6
|
import { EntityMetadata } from '../../proto-models/com/coralogix/blobset/v2/entity_metadata';
|
|
@@ -7,11 +9,11 @@ export declare abstract class BaseApi {
|
|
|
7
9
|
protected abstract getEntityType(): EntityType;
|
|
8
10
|
protected abstract getReleaseEntityType(): ReleaseEntityType;
|
|
9
11
|
protected abstract getMaxCompressedFileSize(): number;
|
|
10
|
-
protected abstract buildReleaseEntityMetadata(application: string, version: string, repoName?: string, commitHash?: string, orgName?: string): ReleaseEntityMetadata;
|
|
11
|
-
protected abstract buildEntityMetadata(application: string, version: string, repoName?: string, commitHash?: string, orgName?: string): EntityMetadata;
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
12
|
+
protected abstract buildReleaseEntityMetadata(application: string, version: string, repoName?: string, commitHash?: string, orgName?: string, internalVersion?: number): ReleaseEntityMetadata;
|
|
13
|
+
protected abstract buildEntityMetadata(application: string, version: string, repoName?: string, commitHash?: string, orgName?: string, internalVersion?: number): EntityMetadata;
|
|
14
|
+
protected uploadBlob(blobSetClient: Client<typeof BlobSetServiceDefinition>, request: UploadBlobRequest, entityMetadata: EntityMetadata | undefined, metadata: Metadata): Promise<void>;
|
|
15
|
+
protected createEntityRelease(rumClient: Client<typeof RumSourceMapServiceDefinition>, releaseEntityMetadata: ReleaseEntityMetadata | undefined, metadata: Metadata): Promise<void>;
|
|
16
|
+
protected createGrpcMetadata(privateKey: string): Metadata;
|
|
17
|
+
protected checkEntityReleaseExists(rumClient: Client<typeof RumSourceMapServiceDefinition>, application: string, version: string, metadata: Metadata): Promise<boolean>;
|
|
16
18
|
upload(request: UploadBlobRequest, application: string, version: string, repoName: string | undefined, commitHash: string | undefined, orgName: string | undefined, env: string, privateKey: string): Promise<void>;
|
|
17
19
|
}
|
|
@@ -22,13 +22,13 @@ class BaseApi {
|
|
|
22
22
|
yield blobSetClient.uploadBlob(iterableRequest, { metadata });
|
|
23
23
|
});
|
|
24
24
|
}
|
|
25
|
-
createEntityRelease(
|
|
25
|
+
createEntityRelease(rumClient, releaseEntityMetadata, metadata) {
|
|
26
26
|
return __awaiter(this, void 0, void 0, function* () {
|
|
27
27
|
const request = {
|
|
28
28
|
releaseEntityType: this.getReleaseEntityType(),
|
|
29
29
|
releaseEntityMetadata,
|
|
30
30
|
};
|
|
31
|
-
yield
|
|
31
|
+
yield rumClient.createEntityRelease(request, { metadata });
|
|
32
32
|
});
|
|
33
33
|
}
|
|
34
34
|
createGrpcMetadata(privateKey) {
|
|
@@ -36,10 +36,10 @@ class BaseApi {
|
|
|
36
36
|
metadata.set('Authorization', `Bearer ${privateKey}`);
|
|
37
37
|
return metadata;
|
|
38
38
|
}
|
|
39
|
-
checkEntityReleaseExists(
|
|
39
|
+
checkEntityReleaseExists(rumClient, application, version, metadata) {
|
|
40
40
|
return __awaiter(this, void 0, void 0, function* () {
|
|
41
41
|
try {
|
|
42
|
-
const { exists } = yield
|
|
42
|
+
const { exists } = yield rumClient.isEntityReleaseExists({ releaseId: version, application, releaseEntityType: this.getReleaseEntityType() }, { metadata });
|
|
43
43
|
return exists;
|
|
44
44
|
}
|
|
45
45
|
catch (error) {
|
|
@@ -54,23 +54,18 @@ class BaseApi {
|
|
|
54
54
|
return __awaiter(this, void 0, void 0, function* () {
|
|
55
55
|
const metadata = this.createGrpcMetadata(privateKey);
|
|
56
56
|
const blobSetClient = grpc_client_factory_1.GrpcClientFactory.getBlobSetGrpcClient(env, this.getMaxCompressedFileSize());
|
|
57
|
-
const
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
throw new Error(`Entity release already exists for releaseId: ${version} and application: ${application}`);
|
|
63
|
-
}
|
|
64
|
-
const releaseEntityMetadata = this.buildReleaseEntityMetadata(application, version, repoName, commitHash, orgName);
|
|
65
|
-
const entityMetadata = this.buildEntityMetadata(application, version, repoName, commitHash, orgName);
|
|
66
|
-
yield this.uploadBlob(blobSetClient, request, entityMetadata, metadata);
|
|
67
|
-
yield this.createEntityRelease(rumSourceMapClient, releaseEntityMetadata, metadata);
|
|
68
|
-
}
|
|
69
|
-
catch (error) {
|
|
70
|
-
throw error;
|
|
57
|
+
const rumClient = grpc_client_factory_1.GrpcClientFactory.getRumSourceMapGrpcClient(env, this.getMaxCompressedFileSize());
|
|
58
|
+
(0, shared_utils_1.validateCompressedFilesSize)(request.data.length, this.getMaxCompressedFileSize());
|
|
59
|
+
const releaseExists = yield this.checkEntityReleaseExists(rumClient, application, version, metadata);
|
|
60
|
+
if (releaseExists) {
|
|
61
|
+
throw new Error(`Entity release already exists for releaseId: ${version} and application: ${application}`);
|
|
71
62
|
}
|
|
63
|
+
const releaseEntityMetadata = this.buildReleaseEntityMetadata(application, version, repoName, commitHash, orgName);
|
|
64
|
+
const entityMetadata = this.buildEntityMetadata(application, version, repoName, commitHash, orgName);
|
|
65
|
+
yield this.uploadBlob(blobSetClient, request, entityMetadata, metadata);
|
|
66
|
+
yield this.createEntityRelease(rumClient, releaseEntityMetadata, metadata);
|
|
72
67
|
});
|
|
73
68
|
}
|
|
74
69
|
}
|
|
75
70
|
exports.BaseApi = BaseApi;
|
|
76
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.api.js","sourceRoot":"","sources":["../../../api/base/base.api.ts"],"names":[],"mappings":"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","sourcesContent":["import { Client, ClientError, Metadata, Status } from 'nice-grpc';\nimport { BlobSetServiceDefinition, UploadBlobRequest } from '../../proto-models/com/coralogix/blobset/v2/blobset_service';\nimport { createUploadBlobRequestChunks, validateCompressedFilesSize } from '../../utils/shared.utils';\nimport { GrpcClientFactory } from '../../grpc-client/grpc-client-factory';\nimport { CreateEntityReleaseRequest, RumSourceMapServiceDefinition } from '../../proto-models/com/coralogix/rum/v2/rum_source_map_service';\nimport { EntityType } from '../../proto-models/com/coralogix/blobset/v2/entity_type';\nimport { ReleaseEntityType } from '../../proto-models/com/coralogix/rum/v2/release_entity_type';\nimport { EntityMetadata } from '../../proto-models/com/coralogix/blobset/v2/entity_metadata';\nimport { ReleaseEntityMetadata } from '../../proto-models/com/coralogix/rum/v2/release_entity_metadata';\n\nexport abstract class BaseApi {\n  protected abstract getEntityType(): EntityType;\n  protected abstract getReleaseEntityType(): ReleaseEntityType;\n  protected abstract getMaxCompressedFileSize(): number;\n  protected abstract buildReleaseEntityMetadata(\n    application: string,\n    version: string,\n    repoName?: string,\n    commitHash?: string,\n    orgName?: string,\n    internalVersion?: number,\n  ): ReleaseEntityMetadata;\n  protected abstract buildEntityMetadata(\n    application: string,\n    version: string,\n    repoName?: string,\n    commitHash?: string,\n    orgName?: string,\n    internalVersion?: number,\n  ): EntityMetadata;\n\n  protected async uploadBlob(\n    blobSetClient: Client<typeof BlobSetServiceDefinition>,\n    request: UploadBlobRequest,\n    entityMetadata: EntityMetadata | undefined,\n    metadata: Metadata,\n  ): Promise<void> {\n    request.entityMetadata = entityMetadata;\n    request.entityType = this.getEntityType();\n\n    const iterableRequest = createUploadBlobRequestChunks(request);\n\n    await blobSetClient.uploadBlob(iterableRequest, { metadata });\n  }\n\n  protected async createEntityRelease(\n    rumClient: Client<typeof RumSourceMapServiceDefinition>,\n    releaseEntityMetadata: ReleaseEntityMetadata | undefined,\n    metadata: Metadata,\n  ): Promise<void> {\n    const request: CreateEntityReleaseRequest = {\n      releaseEntityType: this.getReleaseEntityType(),\n      releaseEntityMetadata,\n    };\n\n    await rumClient.createEntityRelease(request, { metadata });\n  }\n\n  protected createGrpcMetadata(privateKey: string): Metadata {\n    const metadata: Metadata = new Metadata();\n    metadata.set('Authorization', `Bearer ${privateKey}`);\n    return metadata;\n  }\n\n  protected async checkEntityReleaseExists(\n    rumClient: Client<typeof RumSourceMapServiceDefinition>,\n    application: string,\n    version: string,\n    metadata: Metadata,\n  ): Promise<boolean> {\n    try {\n      const { exists } = await rumClient.isEntityReleaseExists(\n        { releaseId: version, application, releaseEntityType: this.getReleaseEntityType() },\n        { metadata },\n      );\n      return exists;\n    } catch (error) {\n      if (error instanceof ClientError && error.code === Status.PERMISSION_DENIED) {\n        throw new Error(\n          `Permission denied while checking entity release. Verify that your private key is correct. Details: ${error.message}`,\n        );\n      }\n      throw error;\n    }\n  }\n\n  public async upload(\n    request: UploadBlobRequest,\n    application: string,\n    version: string,\n    repoName: string | undefined,\n    commitHash: string | undefined,\n    orgName: string | undefined,\n    env: string,\n    privateKey: string,\n  ): Promise<void> {\n    const metadata: Metadata = this.createGrpcMetadata(privateKey);\n    const blobSetClient = GrpcClientFactory.getBlobSetGrpcClient(env, this.getMaxCompressedFileSize());\n    const rumClient = GrpcClientFactory.getRumSourceMapGrpcClient(env, this.getMaxCompressedFileSize());\n\n    validateCompressedFilesSize(request.data.length, this.getMaxCompressedFileSize());\n\n    const releaseExists = await this.checkEntityReleaseExists(rumClient, application, version, metadata);\n\n    if (releaseExists) {\n      throw new Error(`Entity release already exists for releaseId: ${version} and application: ${application}`);\n    }\n\n    const releaseEntityMetadata: ReleaseEntityMetadata = this.buildReleaseEntityMetadata(\n      application,\n      version,\n      repoName,\n      commitHash,\n      orgName,\n    );\n\n    const entityMetadata: EntityMetadata = this.buildEntityMetadata(application, version, repoName, commitHash, orgName);\n\n    await this.uploadBlob(blobSetClient, request, entityMetadata, metadata);\n    await this.createEntityRelease(rumClient, releaseEntityMetadata, metadata);\n  }\n}\n"]}
|
|
@@ -3,10 +3,13 @@ import { ReleaseEntityType } from '../../proto-models/com/coralogix/rum/v2/relea
|
|
|
3
3
|
import { BaseApi } from '../base/base.api';
|
|
4
4
|
import { ReleaseEntityMetadata } from '../../proto-models/com/coralogix/rum/v2/release_entity_metadata';
|
|
5
5
|
import { EntityMetadata } from '../../proto-models/com/coralogix/blobset/v2/entity_metadata';
|
|
6
|
+
import { UploadBlobRequest } from '../../proto-models/com/coralogix/blobset/v2/blobset_service';
|
|
6
7
|
export declare class SourceMapsApi extends BaseApi {
|
|
7
8
|
protected getEntityType(): EntityType;
|
|
8
9
|
protected getReleaseEntityType(): ReleaseEntityType;
|
|
9
10
|
protected getMaxCompressedFileSize(): number;
|
|
10
|
-
protected buildReleaseEntityMetadata(application: string, version: string, repoName?: string, commitHash?: string, orgName?: string): ReleaseEntityMetadata;
|
|
11
|
-
protected buildEntityMetadata(application: string, version: string, repoName?: string, commitHash?: string, orgName?: string): EntityMetadata;
|
|
11
|
+
protected buildReleaseEntityMetadata(application: string, version: string, repoName?: string, commitHash?: string, orgName?: string, internalVersion?: number): ReleaseEntityMetadata;
|
|
12
|
+
protected buildEntityMetadata(application: string, version: string, repoName?: string, commitHash?: string, orgName?: string, internalVersion?: number): EntityMetadata;
|
|
13
|
+
upload(request: UploadBlobRequest, application: string, version: string, repoName: string | undefined, commitHash: string | undefined, orgName: string | undefined, env: string, privateKey: string, override?: boolean): Promise<void>;
|
|
14
|
+
private updateInternalVersion;
|
|
12
15
|
}
|
|
@@ -1,4 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
2
11
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
12
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
13
|
};
|
|
@@ -8,6 +17,9 @@ const entity_type_1 = require("../../proto-models/com/coralogix/blobset/v2/entit
|
|
|
8
17
|
const release_entity_type_1 = require("../../proto-models/com/coralogix/rum/v2/release_entity_type");
|
|
9
18
|
const config_1 = __importDefault(require("../../config/config"));
|
|
10
19
|
const base_api_1 = require("../base/base.api");
|
|
20
|
+
const nice_grpc_1 = require("nice-grpc");
|
|
21
|
+
const grpc_client_factory_1 = require("../../grpc-client/grpc-client-factory");
|
|
22
|
+
const shared_utils_1 = require("../../utils/shared.utils");
|
|
11
23
|
class SourceMapsApi extends base_api_1.BaseApi {
|
|
12
24
|
getEntityType() {
|
|
13
25
|
return entity_type_1.EntityType.ENTITY_TYPE_SOURCE_MAP;
|
|
@@ -18,7 +30,7 @@ class SourceMapsApi extends base_api_1.BaseApi {
|
|
|
18
30
|
getMaxCompressedFileSize() {
|
|
19
31
|
return config_1.default.rumApi.sourceMapsMaxCompressedFilesSize;
|
|
20
32
|
}
|
|
21
|
-
buildReleaseEntityMetadata(application, version, repoName, commitHash, orgName) {
|
|
33
|
+
buildReleaseEntityMetadata(application, version, repoName, commitHash, orgName, internalVersion) {
|
|
22
34
|
return {
|
|
23
35
|
metadata: {
|
|
24
36
|
$case: 'sourceMapMetadata',
|
|
@@ -28,11 +40,12 @@ class SourceMapsApi extends base_api_1.BaseApi {
|
|
|
28
40
|
repoName: repoName || '',
|
|
29
41
|
commitHash: commitHash || '',
|
|
30
42
|
orgName: orgName || '',
|
|
43
|
+
internalVersion: internalVersion !== null && internalVersion !== void 0 ? internalVersion : 0,
|
|
31
44
|
},
|
|
32
45
|
},
|
|
33
46
|
};
|
|
34
47
|
}
|
|
35
|
-
buildEntityMetadata(application, version, repoName, commitHash, orgName) {
|
|
48
|
+
buildEntityMetadata(application, version, repoName, commitHash, orgName, internalVersion) {
|
|
36
49
|
return {
|
|
37
50
|
metadata: {
|
|
38
51
|
$case: 'sourceMapMetadata',
|
|
@@ -42,10 +55,51 @@ class SourceMapsApi extends base_api_1.BaseApi {
|
|
|
42
55
|
repoName: repoName || '',
|
|
43
56
|
commitHash: commitHash || '',
|
|
44
57
|
orgName: orgName || '',
|
|
58
|
+
internalVersion: internalVersion !== null && internalVersion !== void 0 ? internalVersion : 0,
|
|
45
59
|
},
|
|
46
60
|
},
|
|
47
61
|
};
|
|
48
62
|
}
|
|
63
|
+
upload(request, application, version, repoName, commitHash, orgName, env, privateKey, override = false) {
|
|
64
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
65
|
+
const metadata = this.createGrpcMetadata(privateKey);
|
|
66
|
+
const blobSetClient = grpc_client_factory_1.GrpcClientFactory.getBlobSetGrpcClient(env, this.getMaxCompressedFileSize());
|
|
67
|
+
const rumClient = grpc_client_factory_1.GrpcClientFactory.getRumSourceMapGrpcClient(env, this.getMaxCompressedFileSize());
|
|
68
|
+
(0, shared_utils_1.validateCompressedFilesSize)(request.data.length, this.getMaxCompressedFileSize());
|
|
69
|
+
let internalVersion;
|
|
70
|
+
if (override) {
|
|
71
|
+
internalVersion = yield this.updateInternalVersion(rumClient, application, version, metadata);
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
const releaseExists = yield this.checkEntityReleaseExists(rumClient, application, version, metadata);
|
|
75
|
+
if (releaseExists) {
|
|
76
|
+
throw new Error(`Entity release already exists for releaseId: ${version} and application: ${application}`);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
const releaseEntityMetadata = this.buildReleaseEntityMetadata(application, version, repoName, commitHash, orgName, internalVersion);
|
|
80
|
+
const entityMetadata = this.buildEntityMetadata(application, version, repoName, commitHash, orgName, internalVersion);
|
|
81
|
+
yield this.uploadBlob(blobSetClient, request, entityMetadata, metadata);
|
|
82
|
+
yield this.createEntityRelease(rumClient, releaseEntityMetadata, metadata);
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
updateInternalVersion(client, application, version, metadata) {
|
|
86
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
87
|
+
try {
|
|
88
|
+
const { latestVersion } = yield client.getLatestInternalVersion({
|
|
89
|
+
application,
|
|
90
|
+
releaseId: version,
|
|
91
|
+
releaseEntityType: this.getReleaseEntityType(),
|
|
92
|
+
}, { metadata });
|
|
93
|
+
return (latestVersion !== null && latestVersion !== void 0 ? latestVersion : -1) + 1;
|
|
94
|
+
}
|
|
95
|
+
catch (error) {
|
|
96
|
+
if (error instanceof nice_grpc_1.ClientError && error.code === nice_grpc_1.Status.PERMISSION_DENIED) {
|
|
97
|
+
throw new Error(`Permission denied: Verify private key. Details: ${error.message}`);
|
|
98
|
+
}
|
|
99
|
+
throw error;
|
|
100
|
+
}
|
|
101
|
+
});
|
|
102
|
+
}
|
|
49
103
|
}
|
|
50
104
|
exports.SourceMapsApi = SourceMapsApi;
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic291cmNlLW1hcHMuYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vYXBpL3NvdXJjZS1tYXBzL3NvdXJjZS1tYXBzLmFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSx5RkFBcUY7QUFDckYscUdBQWdHO0FBQ2hHLGlFQUF5QztBQUN6QywrQ0FBMkM7QUFJM0MsTUFBYSxhQUFjLFNBQVEsa0JBQU87SUFDOUIsYUFBYTtRQUNyQixPQUFPLHdCQUFVLENBQUMsc0JBQXNCLENBQUM7SUFDM0MsQ0FBQztJQUVTLG9CQUFvQjtRQUM1QixPQUFPLHVDQUFpQixDQUFDLDhCQUE4QixDQUFDO0lBQzFELENBQUM7SUFFUyx3QkFBd0I7UUFDaEMsT0FBTyxnQkFBTSxDQUFDLE1BQU0sQ0FBQyxnQ0FBZ0MsQ0FBQztJQUN4RCxDQUFDO0lBRVMsMEJBQTBCLENBQ2xDLFdBQW1CLEVBQ25CLE9BQWUsRUFDZixRQUFpQixFQUNqQixVQUFtQixFQUNuQixPQUFnQjtRQUVoQixPQUFPO1lBQ0wsUUFBUSxFQUFFO2dCQUNSLEtBQUssRUFBRSxtQkFBbUI7Z0JBQzFCLGlCQUFpQixFQUFFO29CQUNqQixXQUFXO29CQUNYLFNBQVMsRUFBRSxPQUFPO29CQUNsQixRQUFRLEVBQUUsUUFBUSxJQUFJLEVBQUU7b0JBQ3hCLFVBQVUsRUFBRSxVQUFVLElBQUksRUFBRTtvQkFDNUIsT0FBTyxFQUFFLE9BQU8sSUFBSSxFQUFFO2lCQUN2QjthQUNGO1NBQ0YsQ0FBQztJQUNKLENBQUM7SUFFUyxtQkFBbUIsQ0FDM0IsV0FBbUIsRUFDbkIsT0FBZSxFQUNmLFFBQWlCLEVBQ2pCLFVBQW1CLEVBQ25CLE9BQWdCO1FBRWhCLE9BQU87WUFDTCxRQUFRLEVBQUU7Z0JBQ1IsS0FBSyxFQUFFLG1CQUFtQjtnQkFDMUIsaUJBQWlCLEVBQUU7b0JBQ2pCLFdBQVc7b0JBQ1gsU0FBUyxFQUFFLE9BQU87b0JBQ2xCLFFBQVEsRUFBRSxRQUFRLElBQUksRUFBRTtvQkFDeEIsVUFBVSxFQUFFLFVBQVUsSUFBSSxFQUFFO29CQUM1QixPQUFPLEVBQUUsT0FBTyxJQUFJLEVBQUU7aUJBQ3ZCO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQztDQUNGO0FBdERELHNDQXNEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVudGl0eVR5cGUgfSBmcm9tICcuLi8uLi9wcm90by1tb2RlbHMvY29tL2NvcmFsb2dpeC9ibG9ic2V0L3YyL2VudGl0eV90eXBlJztcbmltcG9ydCB7IFJlbGVhc2VFbnRpdHlUeXBlIH0gZnJvbSAnLi4vLi4vcHJvdG8tbW9kZWxzL2NvbS9jb3JhbG9naXgvcnVtL3YyL3JlbGVhc2VfZW50aXR5X3R5cGUnO1xuaW1wb3J0IGNvbmZpZyBmcm9tICcuLi8uLi9jb25maWcvY29uZmlnJztcbmltcG9ydCB7IEJhc2VBcGkgfSBmcm9tICcuLi9iYXNlL2Jhc2UuYXBpJztcbmltcG9ydCB7IFJlbGVhc2VFbnRpdHlNZXRhZGF0YSB9IGZyb20gJy4uLy4uL3Byb3RvLW1vZGVscy9jb20vY29yYWxvZ2l4L3J1bS92Mi9yZWxlYXNlX2VudGl0eV9tZXRhZGF0YSc7XG5pbXBvcnQgeyBFbnRpdHlNZXRhZGF0YSB9IGZyb20gJy4uLy4uL3Byb3RvLW1vZGVscy9jb20vY29yYWxvZ2l4L2Jsb2JzZXQvdjIvZW50aXR5X21ldGFkYXRhJztcblxuZXhwb3J0IGNsYXNzIFNvdXJjZU1hcHNBcGkgZXh0ZW5kcyBCYXNlQXBpIHtcbiAgcHJvdGVjdGVkIGdldEVudGl0eVR5cGUoKTogRW50aXR5VHlwZSB7XG4gICAgcmV0dXJuIEVudGl0eVR5cGUuRU5USVRZX1RZUEVfU09VUkNFX01BUDtcbiAgfVxuXG4gIHByb3RlY3RlZCBnZXRSZWxlYXNlRW50aXR5VHlwZSgpOiBSZWxlYXNlRW50aXR5VHlwZSB7XG4gICAgcmV0dXJuIFJlbGVhc2VFbnRpdHlUeXBlLlJFTEVBU0VfRU5USVRZX1RZUEVfU09VUkNFX01BUDtcbiAgfVxuXG4gIHByb3RlY3RlZCBnZXRNYXhDb21wcmVzc2VkRmlsZVNpemUoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gY29uZmlnLnJ1bUFwaS5zb3VyY2VNYXBzTWF4Q29tcHJlc3NlZEZpbGVzU2l6ZTtcbiAgfVxuXG4gIHByb3RlY3RlZCBidWlsZFJlbGVhc2VFbnRpdHlNZXRhZGF0YShcbiAgICBhcHBsaWNhdGlvbjogc3RyaW5nLFxuICAgIHZlcnNpb246IHN0cmluZyxcbiAgICByZXBvTmFtZT86IHN0cmluZyxcbiAgICBjb21taXRIYXNoPzogc3RyaW5nLFxuICAgIG9yZ05hbWU/OiBzdHJpbmcsXG4gICk6IFJlbGVhc2VFbnRpdHlNZXRhZGF0YSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG1ldGFkYXRhOiB7XG4gICAgICAgICRjYXNlOiAnc291cmNlTWFwTWV0YWRhdGEnLFxuICAgICAgICBzb3VyY2VNYXBNZXRhZGF0YToge1xuICAgICAgICAgIGFwcGxpY2F0aW9uLFxuICAgICAgICAgIHJlbGVhc2VJZDogdmVyc2lvbixcbiAgICAgICAgICByZXBvTmFtZTogcmVwb05hbWUgfHwgJycsXG4gICAgICAgICAgY29tbWl0SGFzaDogY29tbWl0SGFzaCB8fCAnJyxcbiAgICAgICAgICBvcmdOYW1lOiBvcmdOYW1lIHx8ICcnLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9O1xuICB9XG5cbiAgcHJvdGVjdGVkIGJ1aWxkRW50aXR5TWV0YWRhdGEoXG4gICAgYXBwbGljYXRpb246IHN0cmluZyxcbiAgICB2ZXJzaW9uOiBzdHJpbmcsXG4gICAgcmVwb05hbWU/OiBzdHJpbmcsXG4gICAgY29tbWl0SGFzaD86IHN0cmluZyxcbiAgICBvcmdOYW1lPzogc3RyaW5nLFxuICApOiBFbnRpdHlNZXRhZGF0YSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG1ldGFkYXRhOiB7XG4gICAgICAgICRjYXNlOiAnc291cmNlTWFwTWV0YWRhdGEnLFxuICAgICAgICBzb3VyY2VNYXBNZXRhZGF0YToge1xuICAgICAgICAgIGFwcGxpY2F0aW9uLFxuICAgICAgICAgIHJlbGVhc2VJZDogdmVyc2lvbixcbiAgICAgICAgICByZXBvTmFtZTogcmVwb05hbWUgfHwgJycsXG4gICAgICAgICAgY29tbWl0SGFzaDogY29tbWl0SGFzaCB8fCAnJyxcbiAgICAgICAgICBvcmdOYW1lOiBvcmdOYW1lIHx8ICcnLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9O1xuICB9XG59XG4iXX0=
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source-maps.api.js","sourceRoot":"","sources":["../../../api/source-maps/source-maps.api.ts"],"names":[],"mappings":"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","sourcesContent":["import { EntityType } from '../../proto-models/com/coralogix/blobset/v2/entity_type';\nimport { ReleaseEntityType } from '../../proto-models/com/coralogix/rum/v2/release_entity_type';\nimport config from '../../config/config';\nimport { BaseApi } from '../base/base.api';\nimport { ReleaseEntityMetadata } from '../../proto-models/com/coralogix/rum/v2/release_entity_metadata';\nimport { EntityMetadata } from '../../proto-models/com/coralogix/blobset/v2/entity_metadata';\nimport { UploadBlobRequest } from '../../proto-models/com/coralogix/blobset/v2/blobset_service';\nimport { Client, ClientError, Metadata, Status } from 'nice-grpc';\nimport { GrpcClientFactory } from '../../grpc-client/grpc-client-factory';\nimport { validateCompressedFilesSize } from '../../utils/shared.utils';\nimport { RumSourceMapServiceDefinition } from '../../proto-models/com/coralogix/rum/v2/rum_source_map_service';\n\nexport class SourceMapsApi extends BaseApi {\n  protected getEntityType(): EntityType {\n    return EntityType.ENTITY_TYPE_SOURCE_MAP;\n  }\n\n  protected getReleaseEntityType(): ReleaseEntityType {\n    return ReleaseEntityType.RELEASE_ENTITY_TYPE_SOURCE_MAP;\n  }\n\n  protected getMaxCompressedFileSize(): number {\n    return config.rumApi.sourceMapsMaxCompressedFilesSize;\n  }\n\n  protected buildReleaseEntityMetadata(\n    application: string,\n    version: string,\n    repoName?: string,\n    commitHash?: string,\n    orgName?: string,\n    internalVersion?: number,\n  ): ReleaseEntityMetadata {\n    return {\n      metadata: {\n        $case: 'sourceMapMetadata',\n        sourceMapMetadata: {\n          application,\n          releaseId: version,\n          repoName: repoName || '',\n          commitHash: commitHash || '',\n          orgName: orgName || '',\n          internalVersion: internalVersion ?? 0,\n        },\n      },\n    };\n  }\n\n  protected buildEntityMetadata(\n    application: string,\n    version: string,\n    repoName?: string,\n    commitHash?: string,\n    orgName?: string,\n    internalVersion?: number,\n  ): EntityMetadata {\n    return {\n      metadata: {\n        $case: 'sourceMapMetadata',\n        sourceMapMetadata: {\n          application,\n          releaseId: version,\n          repoName: repoName || '',\n          commitHash: commitHash || '',\n          orgName: orgName || '',\n          internalVersion: internalVersion ?? 0,\n        },\n      },\n    };\n  }\n\n  public async upload(\n    request: UploadBlobRequest,\n    application: string,\n    version: string,\n    repoName: string | undefined,\n    commitHash: string | undefined,\n    orgName: string | undefined,\n    env: string,\n    privateKey: string,\n    override = false,\n  ): Promise<void> {\n    const metadata: Metadata = this.createGrpcMetadata(privateKey);\n    const blobSetClient = GrpcClientFactory.getBlobSetGrpcClient(env, this.getMaxCompressedFileSize());\n    const rumClient = GrpcClientFactory.getRumSourceMapGrpcClient(env, this.getMaxCompressedFileSize());\n\n    validateCompressedFilesSize(request.data.length, this.getMaxCompressedFileSize());\n\n    let internalVersion: number | undefined;\n\n    if (override) {\n      internalVersion = await this.updateInternalVersion(rumClient, application, version, metadata);\n    } else {\n      const releaseExists = await this.checkEntityReleaseExists(rumClient, application, version, metadata);\n\n      if (releaseExists) {\n        throw new Error(`Entity release already exists for releaseId: ${version} and application: ${application}`);\n      }\n    }\n\n    const releaseEntityMetadata: ReleaseEntityMetadata = this.buildReleaseEntityMetadata(\n      application,\n      version,\n      repoName,\n      commitHash,\n      orgName,\n      internalVersion,\n    );\n\n    const entityMetadata: EntityMetadata = this.buildEntityMetadata(application, version, repoName, commitHash, orgName, internalVersion);\n\n    await this.uploadBlob(blobSetClient, request, entityMetadata, metadata);\n    await this.createEntityRelease(rumClient, releaseEntityMetadata, metadata);\n  }\n\n  private async updateInternalVersion(\n    client: Client<typeof RumSourceMapServiceDefinition>,\n    application: string,\n    version: string,\n    metadata: Metadata,\n  ): Promise<number> {\n    try {\n      const { latestVersion } = await client.getLatestInternalVersion(\n        {\n          application,\n          releaseId: version,\n          releaseEntityType: this.getReleaseEntityType(),\n        },\n        { metadata },\n      );\n\n      return (latestVersion ?? -1) + 1;\n    } catch (error) {\n      if (error instanceof ClientError && error.code === Status.PERMISSION_DENIED) {\n        throw new Error(`Permission denied: Verify private key. Details: ${error.message}`);\n      }\n      throw error;\n    }\n  }\n}\n"]}
|
|
@@ -24,6 +24,7 @@ const uploadSourceMapsCommand = () => {
|
|
|
24
24
|
.option('-c, --commit-hash <commitHash>', 'GitHub commit hash (optional)')
|
|
25
25
|
.option('-n, --repo-name <repoName>', 'GitHub Repository name (optional)')
|
|
26
26
|
.option('-o, --org-name <orgName>', 'GitHub user name (optional)')
|
|
27
|
+
.option('--override', 'Override existing source maps (optional)')
|
|
27
28
|
.description('Update source maps')
|
|
28
29
|
.action((options) => __awaiter(void 0, void 0, void 0, function* () {
|
|
29
30
|
try {
|
|
@@ -31,10 +32,10 @@ const uploadSourceMapsCommand = () => {
|
|
|
31
32
|
uploadCommand.outputHelp();
|
|
32
33
|
process.exit(0);
|
|
33
34
|
}
|
|
34
|
-
const { privateKey, application, version, folderPath, commitHash, repoName, orgName, env } = options;
|
|
35
|
+
const { privateKey, application, version, folderPath, commitHash, repoName, orgName, env, override } = options;
|
|
35
36
|
(0, shared_utils_1.checkMissingArguments)(options, ['privateKey', 'application', 'version', 'folderPath', 'env']);
|
|
36
37
|
const service = new source_maps_service_1.SourceMapsService();
|
|
37
|
-
yield service.upload(application, version, repoName, commitHash, orgName, folderPath, env, privateKey);
|
|
38
|
+
yield service.upload(application, version, repoName, commitHash, orgName, folderPath, env, privateKey, override);
|
|
38
39
|
}
|
|
39
40
|
catch (error) {
|
|
40
41
|
(0, shared_utils_1.consoleError)(error);
|
|
@@ -43,4 +44,4 @@ const uploadSourceMapsCommand = () => {
|
|
|
43
44
|
return uploadCommand;
|
|
44
45
|
};
|
|
45
46
|
exports.uploadSourceMapsCommand = uploadSourceMapsCommand;
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBsb2FkLXNvdXJjZS1tYXBzLWNvbW1hbmQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9jbGkvY29tbWFuZHMvc291cmNlLW1hcHMvdXBsb2FkLXNvdXJjZS1tYXBzLWNvbW1hbmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEseUNBQW9DO0FBQ3BDLGlEQUF1RDtBQUN2RCwyRkFBc0Y7QUFDdEYsOERBQWtGO0FBRzNFLE1BQU0sdUJBQXVCLEdBQUcsR0FBRyxFQUFFO0lBQzFDLE1BQU0sYUFBYSxHQUFHLElBQUksbUJBQU8sQ0FBQyxvQkFBb0IsQ0FBQztTQUNwRCxNQUFNLENBQUMsZ0NBQWdDLEVBQUUsMENBQTBDLENBQUM7U0FDcEYsTUFBTSxDQUFDLGlDQUFpQyxFQUFFLHlCQUF5QixDQUFDO1NBQ3BFLE1BQU0sQ0FBQyx5QkFBeUIsRUFBRSxrRUFBa0UsQ0FBQztTQUNyRyxNQUFNLENBQUMsZ0NBQWdDLEVBQUUsK0NBQStDLENBQUM7U0FDekYsTUFBTSxDQUFDLGlCQUFpQixFQUFFLGtCQUFrQixFQUFFLGdDQUFtQixDQUFDO1NBQ2xFLE1BQU0sQ0FBQyxnQ0FBZ0MsRUFBRSwrQkFBK0IsQ0FBQztTQUN6RSxNQUFNLENBQUMsNEJBQTRCLEVBQUUsbUNBQW1DLENBQUM7U0FDekUsTUFBTSxDQUFDLDBCQUEwQixFQUFFLDZCQUE2QixDQUFDO1NBQ2pFLE1BQU0sQ0FBQyxZQUFZLEVBQUUsMENBQTBDLENBQUM7U0FDaEUsV0FBVyxDQUFDLG9CQUFvQixDQUFDO1NBQ2pDLE1BQU0sQ0FBQyxDQUFPLE9BQXVDLEVBQUUsRUFBRTtRQUN4RCxJQUFJO1lBQ0YsSUFBSSxPQUFPLENBQUMsSUFBSSxFQUFFO2dCQUNoQixhQUFhLENBQUMsVUFBVSxFQUFFLENBQUM7Z0JBQzNCLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDakI7WUFFRCxNQUFNLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLEdBQUcsRUFBRSxRQUFRLEVBQUUsR0FBRyxPQUFPLENBQUM7WUFFL0csSUFBQSxvQ0FBcUIsRUFBaUMsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUM7WUFFOUgsTUFBTSxPQUFPLEdBQXNCLElBQUksdUNBQWlCLEVBQUUsQ0FBQztZQUUzRCxNQUFNLE9BQU8sQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsR0FBRyxFQUFFLFVBQVUsRUFBRSxRQUFRLENBQUMsQ0FBQztTQUNsSDtRQUFDLE9BQU8sS0FBSyxFQUFFO1lBQ2QsSUFBQSwyQkFBWSxFQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ3JCO0lBQ0gsQ0FBQyxDQUFBLENBQUMsQ0FBQztJQUVMLE9BQU8sYUFBYSxDQUFDO0FBQ3ZCLENBQUMsQ0FBQztBQWhDVyxRQUFBLHVCQUF1QiwyQkFnQ2xDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbWFuZCB9IGZyb20gJ2NvbW1hbmRlcic7XG5pbXBvcnQgeyB2YWxpZGF0ZUVudmlyb25tZW50IH0gZnJvbSAnLi4vLi4vdmFsaWRhdG9ycyc7XG5pbXBvcnQgeyBTb3VyY2VNYXBzU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL3NvdXJjZS1tYXBzL3NvdXJjZS1tYXBzLnNlcnZpY2UnO1xuaW1wb3J0IHsgY2hlY2tNaXNzaW5nQXJndW1lbnRzLCBjb25zb2xlRXJyb3IgfSBmcm9tICcuLi8uLi8uLi91dGlscy9zaGFyZWQudXRpbHMnO1xuaW1wb3J0IHsgVXBsb2FkU291cmNlTWFwc0NvbW1hbmRPcHRpb25zIH0gZnJvbSAnLi4vLi4vLi4vbW9kZWxzL3NvdXJjZS1tYXBzLWNvbW1hbmRzLm1vZGVsJztcblxuZXhwb3J0IGNvbnN0IHVwbG9hZFNvdXJjZU1hcHNDb21tYW5kID0gKCkgPT4ge1xuICBjb25zdCB1cGxvYWRDb21tYW5kID0gbmV3IENvbW1hbmQoJ3VwbG9hZC1zb3VyY2UtbWFwcycpXG4gICAgLm9wdGlvbignLWssIC0tcHJpdmF0ZS1rZXkgPHByaXZhdGVLZXk+JywgJ1ByaXZhdGUga2V5IHRvIGF1dGhlbnRpY2F0ZSB3aXRoIHRoZSBBUEknKVxuICAgIC5vcHRpb24oJy1hLCAtLWFwcGxpY2F0aW9uIDxhcHBsaWNhdGlvbj4nLCAnTmFtZSBvZiB0aGUgYXBwbGljYXRpb24nKVxuICAgIC5vcHRpb24oJy12LCAtLXZlcnNpb24gPHZlcnNpb24+JywgJ1RoZSBhcHBsaWNhdGlvbiB2ZXJzaW9uIC0gbXVzdCBtYXRjaCB0aGUgdmVyc2lvbiB1c2VkIGJ5IFJVTSBzZGsnKVxuICAgIC5vcHRpb24oJy1mLCAtLWZvbGRlci1wYXRoIDxmb2xkZXJQYXRoPicsICdQYXRoIHRvIHRoZSBmb2xkZXIgY29udGFpbmluZyB0aGUgc291cmNlIG1hcHMnKVxuICAgIC5vcHRpb24oJy1lLCAtLWVudiA8ZW52PicsICdZb3VyIGVudmlyb25tZW50JywgdmFsaWRhdGVFbnZpcm9ubWVudClcbiAgICAub3B0aW9uKCctYywgLS1jb21taXQtaGFzaCA8Y29tbWl0SGFzaD4nLCAnR2l0SHViIGNvbW1pdCBoYXNoIChvcHRpb25hbCknKVxuICAgIC5vcHRpb24oJy1uLCAtLXJlcG8tbmFtZSA8cmVwb05hbWU+JywgJ0dpdEh1YiBSZXBvc2l0b3J5IG5hbWUgKG9wdGlvbmFsKScpXG4gICAgLm9wdGlvbignLW8sIC0tb3JnLW5hbWUgPG9yZ05hbWU+JywgJ0dpdEh1YiB1c2VyIG5hbWUgKG9wdGlvbmFsKScpXG4gICAgLm9wdGlvbignLS1vdmVycmlkZScsICdPdmVycmlkZSBleGlzdGluZyBzb3VyY2UgbWFwcyAob3B0aW9uYWwpJylcbiAgICAuZGVzY3JpcHRpb24oJ1VwZGF0ZSBzb3VyY2UgbWFwcycpXG4gICAgLmFjdGlvbihhc3luYyAob3B0aW9uczogVXBsb2FkU291cmNlTWFwc0NvbW1hbmRPcHRpb25zKSA9PiB7XG4gICAgICB0cnkge1xuICAgICAgICBpZiAob3B0aW9ucy5oZWxwKSB7XG4gICAgICAgICAgdXBsb2FkQ29tbWFuZC5vdXRwdXRIZWxwKCk7XG4gICAgICAgICAgcHJvY2Vzcy5leGl0KDApO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgeyBwcml2YXRlS2V5LCBhcHBsaWNhdGlvbiwgdmVyc2lvbiwgZm9sZGVyUGF0aCwgY29tbWl0SGFzaCwgcmVwb05hbWUsIG9yZ05hbWUsIGVudiwgb3ZlcnJpZGUgfSA9IG9wdGlvbnM7XG5cbiAgICAgICAgY2hlY2tNaXNzaW5nQXJndW1lbnRzPFVwbG9hZFNvdXJjZU1hcHNDb21tYW5kT3B0aW9ucz4ob3B0aW9ucywgWydwcml2YXRlS2V5JywgJ2FwcGxpY2F0aW9uJywgJ3ZlcnNpb24nLCAnZm9sZGVyUGF0aCcsICdlbnYnXSk7XG5cbiAgICAgICAgY29uc3Qgc2VydmljZTogU291cmNlTWFwc1NlcnZpY2UgPSBuZXcgU291cmNlTWFwc1NlcnZpY2UoKTtcblxuICAgICAgICBhd2FpdCBzZXJ2aWNlLnVwbG9hZChhcHBsaWNhdGlvbiwgdmVyc2lvbiwgcmVwb05hbWUsIGNvbW1pdEhhc2gsIG9yZ05hbWUsIGZvbGRlclBhdGgsIGVudiwgcHJpdmF0ZUtleSwgb3ZlcnJpZGUpO1xuICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgY29uc29sZUVycm9yKGVycm9yKTtcbiAgICAgIH1cbiAgICB9KTtcblxuICByZXR1cm4gdXBsb2FkQ29tbWFuZDtcbn07XG4iXX0=
|
package/dist/consts/consts.js
CHANGED
|
@@ -13,6 +13,7 @@ exports.envToDomain = {
|
|
|
13
13
|
US2: 'https://ng-api-grpc.cx498.coralogix.com:443',
|
|
14
14
|
AP1: 'https://ng-api-grpc.app.coralogix.in:443',
|
|
15
15
|
AP2: 'https://ng-api-grpc.coralogixsg.com:443',
|
|
16
|
-
AP3: 'https://ng-api-grpc.ap3.coralogix.com:443',
|
|
16
|
+
AP3: 'https://ng-api-grpc.ap3.coralogix.com:443',
|
|
17
|
+
STG: 'https://ng-api-grpc.app.staging.coralogix.net:443',
|
|
17
18
|
};
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vY29uc3RzL2NvbnN0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBYSxRQUFBLEVBQUUsR0FBRyxJQUFJLEdBQUcsSUFBSSxDQUFDO0FBRWpCLFFBQUEsV0FBVyxHQUFHLG1CQUFtQixDQUFDO0FBRWxDLFFBQUEsU0FBUyxHQUFHLG1CQUFtQixDQUFDO0FBRWhDLFFBQUEsVUFBVSxHQUFHLG1CQUFtQixDQUFDO0FBRWpDLFFBQUEsaUJBQWlCLEdBQVcsRUFBRSxHQUFHLElBQUksR0FBRyxJQUFJLENBQUMsQ0FBQyxRQUFRO0FBRXRELFFBQUEsV0FBVyxHQUEyQjtJQUNqRCxHQUFHLEVBQUUsdUNBQXVDO0lBQzVDLEdBQUcsRUFBRSwyQ0FBMkM7SUFDaEQsR0FBRyxFQUFFLHNDQUFzQztJQUMzQyxHQUFHLEVBQUUsNkNBQTZDO0lBQ2xELEdBQUcsRUFBRSwwQ0FBMEM7SUFDL0MsR0FBRyxFQUFFLHlDQUF5QztJQUM5QyxHQUFHLEVBQUUsMkNBQTJDO0lBQ2hELEdBQUcsRUFBRSxtREFBbUQ7Q0FDekQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBNQiA9IDEwMjQgKiAxMDI0O1xuXG5leHBvcnQgY29uc3QgR1JFRU5fQ09MT1IgPSAnXFx4MWJbMzJtJXNcXHgxYlswbSc7XG5cbmV4cG9ydCBjb25zdCBSRURfQ09MT1IgPSAnXFx4MWJbMzFtJXNcXHgxYlswbSc7XG5cbmV4cG9ydCBjb25zdCBHUkFZX0NPTE9SID0gJ1xceDFiWzM3bSVzXFx4MWJbMG0nO1xuXG5leHBvcnQgY29uc3QgU1RSRUFNX0NIVU5LX1NJWkU6IG51bWJlciA9IDEwICogMTAyNCAqIDEwMjQ7IC8vIDEwIE1CXG5cbmV4cG9ydCBjb25zdCBlbnZUb0RvbWFpbjogUmVjb3JkPHN0cmluZywgc3RyaW5nPiA9IHtcbiAgRVUxOiAnaHR0cHM6Ly9uZy1hcGktZ3JwYy5jb3JhbG9naXguY29tOjQ0MycsIC8vIGV1LXdlc3QtMSAoSXJlbGFuZClcbiAgRVUyOiAnaHR0cHM6Ly9uZy1hcGktZ3JwYy5ldTIuY29yYWxvZ2l4LmNvbTo0NDMnLCAvLyBldS1ub3J0aC0xIChTdG9ja2hvbG0pXG4gIFVTMTogJ2h0dHBzOi8vbmctYXBpLWdycGMuY29yYWxvZ2l4LnVzOjQ0MycsIC8vIHVzLWVhc3QtMiAoT2hpbylcbiAgVVMyOiAnaHR0cHM6Ly9uZy1hcGktZ3JwYy5jeDQ5OC5jb3JhbG9naXguY29tOjQ0MycsIC8vIHVzLXdlc3QtMiAoT3JlZ29uKVxuICBBUDE6ICdodHRwczovL25nLWFwaS1ncnBjLmFwcC5jb3JhbG9naXguaW46NDQzJywgLy8gYXAtc291dGgtMSAoTXVtYmFpKVxuICBBUDI6ICdodHRwczovL25nLWFwaS1ncnBjLmNvcmFsb2dpeHNnLmNvbTo0NDMnLCAvLyBhcC1zb3V0aGVhc3QtMSAoU2luZ2Fwb3JlKVxuICBBUDM6ICdodHRwczovL25nLWFwaS1ncnBjLmFwMy5jb3JhbG9naXguY29tOjQ0MycsIC8vIGFwLXNvdXRoZWFzdC0zIChKYWthcnRhKVxuICBTVEc6ICdodHRwczovL25nLWFwaS1ncnBjLmFwcC5zdGFnaW5nLmNvcmFsb2dpeC5uZXQ6NDQzJyxcbn07XG4iXX0=
|