@coralogix/rum-cli 1.1.37 → 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.
Files changed (86) hide show
  1. package/README.md +1 -1
  2. package/api/base/base.api.ts +27 -30
  3. package/api/source-maps/source-maps.api.ts +78 -0
  4. package/cli/commands/source-maps/upload-source-maps-command.ts +3 -2
  5. package/consts/consts.ts +1 -0
  6. package/dist/api/base/base.api.d.ts +9 -7
  7. package/dist/api/base/base.api.js +14 -19
  8. package/dist/api/source-maps/source-maps.api.d.ts +5 -2
  9. package/dist/api/source-maps/source-maps.api.js +57 -3
  10. package/dist/cli/commands/source-maps/upload-source-maps-command.js +4 -3
  11. package/dist/consts/consts.js +3 -2
  12. package/dist/grpc-client/grpc-client-factory.d.ts +72 -0
  13. package/dist/models/source-maps-commands.model.d.ts +1 -0
  14. package/dist/models/source-maps-commands.model.js +1 -1
  15. package/dist/proto-models/com/coralogix/blobset/v2/blobset_query_service.d.ts +150 -0
  16. package/dist/proto-models/com/coralogix/blobset/v2/blobset_query_service.js +29 -1
  17. package/dist/proto-models/com/coralogix/blobset/v2/case_file.d.ts +36 -0
  18. package/dist/proto-models/com/coralogix/blobset/v2/case_file.js +161 -0
  19. package/dist/proto-models/com/coralogix/blobset/v2/dsym.d.ts +1 -0
  20. package/dist/proto-models/com/coralogix/blobset/v2/dsym.js +33 -3
  21. package/dist/proto-models/com/coralogix/blobset/v2/entity_metadata.d.ts +31 -0
  22. package/dist/proto-models/com/coralogix/blobset/v2/entity_metadata.js +215 -7
  23. package/dist/proto-models/com/coralogix/blobset/v2/entity_type.d.ts +3 -1
  24. package/dist/proto-models/com/coralogix/blobset/v2/entity_type.js +13 -1
  25. package/dist/proto-models/com/coralogix/blobset/v2/investigation_file.d.ts +36 -0
  26. package/dist/proto-models/com/coralogix/blobset/v2/investigation_file.js +161 -0
  27. package/dist/proto-models/com/coralogix/blobset/v2/proguard.d.ts +68 -0
  28. package/dist/proto-models/com/coralogix/blobset/v2/proguard.js +400 -0
  29. package/dist/proto-models/com/coralogix/rum/v2/application_releases.d.ts +38 -0
  30. package/dist/proto-models/com/coralogix/rum/v2/application_releases.js +180 -0
  31. package/dist/proto-models/com/coralogix/rum/v2/merge_error.d.ts +38 -0
  32. package/dist/proto-models/com/coralogix/rum/v2/merge_error.js +171 -0
  33. package/dist/proto-models/com/coralogix/rum/v2/release_entity_metadata.d.ts +4 -0
  34. package/dist/proto-models/com/coralogix/rum/v2/release_entity_metadata.js +93 -9
  35. package/dist/proto-models/com/coralogix/rum/v2/rum_merge_erros_service.d.ts +197 -0
  36. package/dist/proto-models/com/coralogix/rum/v2/rum_merge_erros_service.js +478 -0
  37. package/dist/proto-models/com/coralogix/rum/v2/rum_service.d.ts +107 -0
  38. package/dist/proto-models/com/coralogix/rum/v2/rum_service.js +385 -2
  39. package/dist/proto-models/com/coralogix/rum/v2/rum_source_map_service.d.ts +46 -0
  40. package/dist/proto-models/com/coralogix/rum/v2/rum_source_map_service.js +142 -2
  41. package/dist/proto-models/com/coralogix/rum/v2/saved_filter.d.ts +4 -1
  42. package/dist/proto-models/com/coralogix/rum/v2/saved_filter.js +19 -1
  43. package/dist/proto-models/com/coralogix/rum/v2/template.d.ts +2 -0
  44. package/dist/proto-models/com/coralogix/rum/v2/template.js +31 -3
  45. package/dist/services/base/base.service.js +2 -2
  46. package/dist/services/source-maps/source-maps.service.d.ts +1 -0
  47. package/dist/services/source-maps/source-maps.service.js +23 -1
  48. package/dist/utils/file-processor.utils.js +16 -12
  49. package/models/source-maps-commands.model.ts +1 -0
  50. package/package.json +3 -3
  51. package/proto-models/com/coralogix/blobset/v2/blobset_query_service.ts +28 -0
  52. package/proto-models/com/coralogix/blobset/v2/case_file.ts +188 -0
  53. package/proto-models/com/coralogix/blobset/v2/dsym.ts +35 -1
  54. package/proto-models/com/coralogix/blobset/v2/entity_metadata.ts +243 -1
  55. package/proto-models/com/coralogix/blobset/v2/entity_type.ts +12 -0
  56. package/proto-models/com/coralogix/blobset/v2/investigation_file.ts +188 -0
  57. package/proto-models/com/coralogix/blobset/v2/proguard.ts +466 -0
  58. package/proto-models/com/coralogix/rum/v2/application_releases.ts +213 -0
  59. package/proto-models/com/coralogix/rum/v2/merge_error.ts +201 -0
  60. package/proto-models/com/coralogix/rum/v2/release_entity_metadata.ts +96 -4
  61. package/proto-models/com/coralogix/rum/v2/rum_merge_erros_service.ts +566 -0
  62. package/proto-models/com/coralogix/rum/v2/rum_service.ts +462 -0
  63. package/proto-models/com/coralogix/rum/v2/rum_source_map_service.ts +164 -0
  64. package/proto-models/com/coralogix/rum/v2/saved_filter.ts +18 -0
  65. package/proto-models/com/coralogix/rum/v2/template.ts +33 -1
  66. package/protofetch.lock +4 -4
  67. package/protofetch.toml +2 -2
  68. package/protos/com/coralogix/blobset/v2/blobset_query_service.proto +7 -0
  69. package/protos/com/coralogix/blobset/v2/case_file.proto +12 -0
  70. package/protos/com/coralogix/blobset/v2/dsym.proto +1 -0
  71. package/protos/com/coralogix/blobset/v2/entity_metadata.proto +14 -1
  72. package/protos/com/coralogix/blobset/v2/entity_type.proto +3 -1
  73. package/protos/com/coralogix/blobset/v2/investigation_file.proto +12 -0
  74. package/protos/com/coralogix/blobset/v2/proguard.proto +30 -0
  75. package/protos/com/coralogix/rum/v2/application_releases.proto +14 -0
  76. package/protos/com/coralogix/rum/v2/merge_error.proto +13 -0
  77. package/protos/com/coralogix/rum/v2/release_entity_metadata.proto +7 -0
  78. package/protos/com/coralogix/rum/v2/rum_merge_erros_service.proto +42 -0
  79. package/protos/com/coralogix/rum/v2/rum_service.proto +23 -0
  80. package/protos/com/coralogix/rum/v2/rum_source_map_service.proto +11 -0
  81. package/protos/com/coralogix/rum/v2/saved_filter.proto +3 -0
  82. package/protos/com/coralogix/rum/v2/template.proto +2 -0
  83. package/protoset.bin +0 -0
  84. package/services/base/base.service.ts +1 -2
  85. package/services/source-maps/source-maps.service.ts +26 -0
  86. package/utils/file-processor.utils.ts +14 -12
package/README.md CHANGED
@@ -68,7 +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
- - `-g, --generate`: Update existing release or create a new one if not found (optional).
71
+ - `--override`: Override existing source maps (optional).
72
72
  - `-h, --help`: Display help.
73
73
 
74
74
  ## Environments
@@ -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 { consoleError, createUploadBlobRequestChunks, validateCompressedFilesSize } from '../../utils/shared.utils';
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
- private async uploadBlob(
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
- private async createEntityRelease(
45
- rumSourceMapClient: Client<typeof RumSourceMapServiceDefinition>,
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 rumSourceMapClient.createEntityRelease(request, { metadata });
56
+ await rumClient.createEntityRelease(request, { metadata });
55
57
  }
56
58
 
57
- private createGrpcMetadata(privateKey: string): Metadata {
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
- private async checkEntityReleaseExists(
64
- rumSourceMapClient: Client<typeof RumSourceMapServiceDefinition>,
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 rumSourceMapClient.isEntityReleaseExists(
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 rumSourceMapClient = GrpcClientFactory.getRumSourceMapGrpcClient(env, this.getMaxCompressedFileSize());
99
+ const rumClient = GrpcClientFactory.getRumSourceMapGrpcClient(env, this.getMaxCompressedFileSize());
98
100
 
99
- try {
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
- if (releaseExists) {
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
- const releaseEntityMetadata: ReleaseEntityMetadata = this.buildReleaseEntityMetadata(
109
- application,
110
- version,
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
- const entityMetadata: EntityMetadata = this.buildEntityMetadata(application, version, repoName, commitHash, orgName);
109
+ const releaseEntityMetadata: ReleaseEntityMetadata = this.buildReleaseEntityMetadata(
110
+ application,
111
+ version,
112
+ repoName,
113
+ commitHash,
114
+ orgName,
115
+ );
117
116
 
118
- await this.uploadBlob(blobSetClient, request, entityMetadata, metadata);
117
+ const entityMetadata: EntityMetadata = this.buildEntityMetadata(application, version, repoName, commitHash, orgName);
119
118
 
120
- await this.createEntityRelease(rumSourceMapClient, releaseEntityMetadata, metadata);
121
- } catch (error) {
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 { UploadBlobRequest } from '../../proto-models/com/coralogix/blobset/v2/blobset_service';
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
- private uploadBlob;
13
- private createEntityRelease;
14
- private createGrpcMetadata;
15
- private checkEntityReleaseExists;
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(rumSourceMapClient, releaseEntityMetadata, metadata) {
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 rumSourceMapClient.createEntityRelease(request, { metadata });
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(rumSourceMapClient, application, version, metadata) {
39
+ checkEntityReleaseExists(rumClient, application, version, metadata) {
40
40
  return __awaiter(this, void 0, void 0, function* () {
41
41
  try {
42
- const { exists } = yield rumSourceMapClient.isEntityReleaseExists({ releaseId: version, application, releaseEntityType: this.getReleaseEntityType() }, { metadata });
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 rumSourceMapClient = grpc_client_factory_1.GrpcClientFactory.getRumSourceMapGrpcClient(env, this.getMaxCompressedFileSize());
58
- try {
59
- (0, shared_utils_1.validateCompressedFilesSize)(request.data.length, this.getMaxCompressedFileSize());
60
- const releaseExists = yield this.checkEntityReleaseExists(rumSourceMapClient, application, version, metadata);
61
- if (releaseExists) {
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,{"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 { consoleError, 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  ): ReleaseEntityMetadata;\n  protected abstract buildEntityMetadata(\n    application: string,\n    version: string,\n    repoName?: string,\n    commitHash?: string,\n    orgName?: string,\n  ): EntityMetadata;\n\n  private 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  private async createEntityRelease(\n    rumSourceMapClient: 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 rumSourceMapClient.createEntityRelease(request, { metadata });\n  }\n\n  private createGrpcMetadata(privateKey: string): Metadata {\n    const metadata: Metadata = new Metadata();\n    metadata.set('Authorization', `Bearer ${privateKey}`);\n    return metadata;\n  }\n\n  private async checkEntityReleaseExists(\n    rumSourceMapClient: Client<typeof RumSourceMapServiceDefinition>,\n    application: string,\n    version: string,\n    metadata: Metadata,\n  ): Promise<boolean> {\n    try {\n      const { exists } = await rumSourceMapClient.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 rumSourceMapClient = GrpcClientFactory.getRumSourceMapGrpcClient(env, this.getMaxCompressedFileSize());\n\n    try {\n      validateCompressedFilesSize(request.data.length, this.getMaxCompressedFileSize());\n\n      const releaseExists: boolean = await this.checkEntityReleaseExists(rumSourceMapClient, 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\n      await this.createEntityRelease(rumSourceMapClient, releaseEntityMetadata, metadata);\n    } catch (error) {\n      throw error;\n    }\n  }\n}\n"]}
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBsb2FkLXNvdXJjZS1tYXBzLWNvbW1hbmQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9jbGkvY29tbWFuZHMvc291cmNlLW1hcHMvdXBsb2FkLXNvdXJjZS1tYXBzLWNvbW1hbmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEseUNBQW9DO0FBQ3BDLGlEQUF1RDtBQUN2RCwyRkFBc0Y7QUFDdEYsOERBQWtGO0FBRzNFLE1BQU0sdUJBQXVCLEdBQUcsR0FBRyxFQUFFO0lBQzFDLE1BQU0sYUFBYSxHQUFHLElBQUksbUJBQU8sQ0FBQyxvQkFBb0IsQ0FBQztTQUNwRCxNQUFNLENBQUMsZ0NBQWdDLEVBQUUsMENBQTBDLENBQUM7U0FDcEYsTUFBTSxDQUFDLGlDQUFpQyxFQUFFLHlCQUF5QixDQUFDO1NBQ3BFLE1BQU0sQ0FBQyx5QkFBeUIsRUFBRSxrRUFBa0UsQ0FBQztTQUNyRyxNQUFNLENBQUMsZ0NBQWdDLEVBQUUsK0NBQStDLENBQUM7U0FDekYsTUFBTSxDQUFDLGlCQUFpQixFQUFFLGtCQUFrQixFQUFFLGdDQUFtQixDQUFDO1NBQ2xFLE1BQU0sQ0FBQyxnQ0FBZ0MsRUFBRSwrQkFBK0IsQ0FBQztTQUN6RSxNQUFNLENBQUMsNEJBQTRCLEVBQUUsbUNBQW1DLENBQUM7U0FDekUsTUFBTSxDQUFDLDBCQUEwQixFQUFFLDZCQUE2QixDQUFDO1NBQ2pFLFdBQVcsQ0FBQyxvQkFBb0IsQ0FBQztTQUNqQyxNQUFNLENBQUMsQ0FBTyxPQUF1QyxFQUFFLEVBQUU7UUFDeEQsSUFBSTtZQUNGLElBQUksT0FBTyxDQUFDLElBQUksRUFBRTtnQkFDaEIsYUFBYSxDQUFDLFVBQVUsRUFBRSxDQUFDO2dCQUMzQixPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQ2pCO1lBRUQsTUFBTSxFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsR0FBRyxPQUFPLENBQUM7WUFFckcsSUFBQSxvQ0FBcUIsRUFBaUMsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUM7WUFFOUgsTUFBTSxPQUFPLEdBQXNCLElBQUksdUNBQWlCLEVBQUUsQ0FBQztZQUUzRCxNQUFNLE9BQU8sQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsR0FBRyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1NBQ3hHO1FBQUMsT0FBTyxLQUFLLEVBQUU7WUFDZCxJQUFBLDJCQUFZLEVBQUMsS0FBSyxDQUFDLENBQUM7U0FDckI7SUFDSCxDQUFDLENBQUEsQ0FBQyxDQUFDO0lBRUwsT0FBTyxhQUFhLENBQUM7QUFDdkIsQ0FBQyxDQUFDO0FBL0JXLFFBQUEsdUJBQXVCLDJCQStCbEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tYW5kIH0gZnJvbSAnY29tbWFuZGVyJztcbmltcG9ydCB7IHZhbGlkYXRlRW52aXJvbm1lbnQgfSBmcm9tICcuLi8uLi92YWxpZGF0b3JzJztcbmltcG9ydCB7IFNvdXJjZU1hcHNTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vc2VydmljZXMvc291cmNlLW1hcHMvc291cmNlLW1hcHMuc2VydmljZSc7XG5pbXBvcnQgeyBjaGVja01pc3NpbmdBcmd1bWVudHMsIGNvbnNvbGVFcnJvciB9IGZyb20gJy4uLy4uLy4uL3V0aWxzL3NoYXJlZC51dGlscyc7XG5pbXBvcnQgeyBVcGxvYWRTb3VyY2VNYXBzQ29tbWFuZE9wdGlvbnMgfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMvc291cmNlLW1hcHMtY29tbWFuZHMubW9kZWwnO1xuXG5leHBvcnQgY29uc3QgdXBsb2FkU291cmNlTWFwc0NvbW1hbmQgPSAoKSA9PiB7XG4gIGNvbnN0IHVwbG9hZENvbW1hbmQgPSBuZXcgQ29tbWFuZCgndXBsb2FkLXNvdXJjZS1tYXBzJylcbiAgICAub3B0aW9uKCctaywgLS1wcml2YXRlLWtleSA8cHJpdmF0ZUtleT4nLCAnUHJpdmF0ZSBrZXkgdG8gYXV0aGVudGljYXRlIHdpdGggdGhlIEFQSScpXG4gICAgLm9wdGlvbignLWEsIC0tYXBwbGljYXRpb24gPGFwcGxpY2F0aW9uPicsICdOYW1lIG9mIHRoZSBhcHBsaWNhdGlvbicpXG4gICAgLm9wdGlvbignLXYsIC0tdmVyc2lvbiA8dmVyc2lvbj4nLCAnVGhlIGFwcGxpY2F0aW9uIHZlcnNpb24gLSBtdXN0IG1hdGNoIHRoZSB2ZXJzaW9uIHVzZWQgYnkgUlVNIHNkaycpXG4gICAgLm9wdGlvbignLWYsIC0tZm9sZGVyLXBhdGggPGZvbGRlclBhdGg+JywgJ1BhdGggdG8gdGhlIGZvbGRlciBjb250YWluaW5nIHRoZSBzb3VyY2UgbWFwcycpXG4gICAgLm9wdGlvbignLWUsIC0tZW52IDxlbnY+JywgJ1lvdXIgZW52aXJvbm1lbnQnLCB2YWxpZGF0ZUVudmlyb25tZW50KVxuICAgIC5vcHRpb24oJy1jLCAtLWNvbW1pdC1oYXNoIDxjb21taXRIYXNoPicsICdHaXRIdWIgY29tbWl0IGhhc2ggKG9wdGlvbmFsKScpXG4gICAgLm9wdGlvbignLW4sIC0tcmVwby1uYW1lIDxyZXBvTmFtZT4nLCAnR2l0SHViIFJlcG9zaXRvcnkgbmFtZSAob3B0aW9uYWwpJylcbiAgICAub3B0aW9uKCctbywgLS1vcmctbmFtZSA8b3JnTmFtZT4nLCAnR2l0SHViIHVzZXIgbmFtZSAob3B0aW9uYWwpJylcbiAgICAuZGVzY3JpcHRpb24oJ1VwZGF0ZSBzb3VyY2UgbWFwcycpXG4gICAgLmFjdGlvbihhc3luYyAob3B0aW9uczogVXBsb2FkU291cmNlTWFwc0NvbW1hbmRPcHRpb25zKSA9PiB7XG4gICAgICB0cnkge1xuICAgICAgICBpZiAob3B0aW9ucy5oZWxwKSB7XG4gICAgICAgICAgdXBsb2FkQ29tbWFuZC5vdXRwdXRIZWxwKCk7XG4gICAgICAgICAgcHJvY2Vzcy5leGl0KDApO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgeyBwcml2YXRlS2V5LCBhcHBsaWNhdGlvbiwgdmVyc2lvbiwgZm9sZGVyUGF0aCwgY29tbWl0SGFzaCwgcmVwb05hbWUsIG9yZ05hbWUsIGVudiB9ID0gb3B0aW9ucztcblxuICAgICAgICBjaGVja01pc3NpbmdBcmd1bWVudHM8VXBsb2FkU291cmNlTWFwc0NvbW1hbmRPcHRpb25zPihvcHRpb25zLCBbJ3ByaXZhdGVLZXknLCAnYXBwbGljYXRpb24nLCAndmVyc2lvbicsICdmb2xkZXJQYXRoJywgJ2VudiddKTtcblxuICAgICAgICBjb25zdCBzZXJ2aWNlOiBTb3VyY2VNYXBzU2VydmljZSA9IG5ldyBTb3VyY2VNYXBzU2VydmljZSgpO1xuXG4gICAgICAgIGF3YWl0IHNlcnZpY2UudXBsb2FkKGFwcGxpY2F0aW9uLCB2ZXJzaW9uLCByZXBvTmFtZSwgY29tbWl0SGFzaCwgb3JnTmFtZSwgZm9sZGVyUGF0aCwgZW52LCBwcml2YXRlS2V5KTtcbiAgICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgIGNvbnNvbGVFcnJvcihlcnJvcik7XG4gICAgICB9XG4gICAgfSk7XG5cbiAgcmV0dXJuIHVwbG9hZENvbW1hbmQ7XG59O1xuIl19
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBsb2FkLXNvdXJjZS1tYXBzLWNvbW1hbmQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9jbGkvY29tbWFuZHMvc291cmNlLW1hcHMvdXBsb2FkLXNvdXJjZS1tYXBzLWNvbW1hbmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEseUNBQW9DO0FBQ3BDLGlEQUF1RDtBQUN2RCwyRkFBc0Y7QUFDdEYsOERBQWtGO0FBRzNFLE1BQU0sdUJBQXVCLEdBQUcsR0FBRyxFQUFFO0lBQzFDLE1BQU0sYUFBYSxHQUFHLElBQUksbUJBQU8sQ0FBQyxvQkFBb0IsQ0FBQztTQUNwRCxNQUFNLENBQUMsZ0NBQWdDLEVBQUUsMENBQTBDLENBQUM7U0FDcEYsTUFBTSxDQUFDLGlDQUFpQyxFQUFFLHlCQUF5QixDQUFDO1NBQ3BFLE1BQU0sQ0FBQyx5QkFBeUIsRUFBRSxrRUFBa0UsQ0FBQztTQUNyRyxNQUFNLENBQUMsZ0NBQWdDLEVBQUUsK0NBQStDLENBQUM7U0FDekYsTUFBTSxDQUFDLGlCQUFpQixFQUFFLGtCQUFrQixFQUFFLGdDQUFtQixDQUFDO1NBQ2xFLE1BQU0sQ0FBQyxnQ0FBZ0MsRUFBRSwrQkFBK0IsQ0FBQztTQUN6RSxNQUFNLENBQUMsNEJBQTRCLEVBQUUsbUNBQW1DLENBQUM7U0FDekUsTUFBTSxDQUFDLDBCQUEwQixFQUFFLDZCQUE2QixDQUFDO1NBQ2pFLE1BQU0sQ0FBQyxZQUFZLEVBQUUsMENBQTBDLENBQUM7U0FDaEUsV0FBVyxDQUFDLG9CQUFvQixDQUFDO1NBQ2pDLE1BQU0sQ0FBQyxDQUFPLE9BQXVDLEVBQUUsRUFBRTtRQUN4RCxJQUFJO1lBQ0YsSUFBSSxPQUFPLENBQUMsSUFBSSxFQUFFO2dCQUNoQixhQUFhLENBQUMsVUFBVSxFQUFFLENBQUM7Z0JBQzNCLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDakI7WUFFRCxNQUFNLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLEdBQUcsRUFBRSxRQUFRLEVBQUUsR0FBRyxPQUFPLENBQUM7WUFFL0csSUFBQSxvQ0FBcUIsRUFBaUMsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUM7WUFFOUgsTUFBTSxPQUFPLEdBQXNCLElBQUksdUNBQWlCLEVBQUUsQ0FBQztZQUUzRCxNQUFNLE9BQU8sQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsR0FBRyxFQUFFLFVBQVUsRUFBRSxRQUFRLENBQUMsQ0FBQztTQUNsSDtRQUFDLE9BQU8sS0FBSyxFQUFFO1lBQ2QsSUFBQSwyQkFBWSxFQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ3JCO0lBQ0gsQ0FBQyxDQUFBLENBQUMsQ0FBQztJQUVMLE9BQU8sYUFBYSxDQUFDO0FBQ3ZCLENBQUMsQ0FBQztBQWhDVyxRQUFBLHVCQUF1QiwyQkFnQ2xDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbWFuZCB9IGZyb20gJ2NvbW1hbmRlcic7XG5pbXBvcnQgeyB2YWxpZGF0ZUVudmlyb25tZW50IH0gZnJvbSAnLi4vLi4vdmFsaWRhdG9ycyc7XG5pbXBvcnQgeyBTb3VyY2VNYXBzU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL3NvdXJjZS1tYXBzL3NvdXJjZS1tYXBzLnNlcnZpY2UnO1xuaW1wb3J0IHsgY2hlY2tNaXNzaW5nQXJndW1lbnRzLCBjb25zb2xlRXJyb3IgfSBmcm9tICcuLi8uLi8uLi91dGlscy9zaGFyZWQudXRpbHMnO1xuaW1wb3J0IHsgVXBsb2FkU291cmNlTWFwc0NvbW1hbmRPcHRpb25zIH0gZnJvbSAnLi4vLi4vLi4vbW9kZWxzL3NvdXJjZS1tYXBzLWNvbW1hbmRzLm1vZGVsJztcblxuZXhwb3J0IGNvbnN0IHVwbG9hZFNvdXJjZU1hcHNDb21tYW5kID0gKCkgPT4ge1xuICBjb25zdCB1cGxvYWRDb21tYW5kID0gbmV3IENvbW1hbmQoJ3VwbG9hZC1zb3VyY2UtbWFwcycpXG4gICAgLm9wdGlvbignLWssIC0tcHJpdmF0ZS1rZXkgPHByaXZhdGVLZXk+JywgJ1ByaXZhdGUga2V5IHRvIGF1dGhlbnRpY2F0ZSB3aXRoIHRoZSBBUEknKVxuICAgIC5vcHRpb24oJy1hLCAtLWFwcGxpY2F0aW9uIDxhcHBsaWNhdGlvbj4nLCAnTmFtZSBvZiB0aGUgYXBwbGljYXRpb24nKVxuICAgIC5vcHRpb24oJy12LCAtLXZlcnNpb24gPHZlcnNpb24+JywgJ1RoZSBhcHBsaWNhdGlvbiB2ZXJzaW9uIC0gbXVzdCBtYXRjaCB0aGUgdmVyc2lvbiB1c2VkIGJ5IFJVTSBzZGsnKVxuICAgIC5vcHRpb24oJy1mLCAtLWZvbGRlci1wYXRoIDxmb2xkZXJQYXRoPicsICdQYXRoIHRvIHRoZSBmb2xkZXIgY29udGFpbmluZyB0aGUgc291cmNlIG1hcHMnKVxuICAgIC5vcHRpb24oJy1lLCAtLWVudiA8ZW52PicsICdZb3VyIGVudmlyb25tZW50JywgdmFsaWRhdGVFbnZpcm9ubWVudClcbiAgICAub3B0aW9uKCctYywgLS1jb21taXQtaGFzaCA8Y29tbWl0SGFzaD4nLCAnR2l0SHViIGNvbW1pdCBoYXNoIChvcHRpb25hbCknKVxuICAgIC5vcHRpb24oJy1uLCAtLXJlcG8tbmFtZSA8cmVwb05hbWU+JywgJ0dpdEh1YiBSZXBvc2l0b3J5IG5hbWUgKG9wdGlvbmFsKScpXG4gICAgLm9wdGlvbignLW8sIC0tb3JnLW5hbWUgPG9yZ05hbWU+JywgJ0dpdEh1YiB1c2VyIG5hbWUgKG9wdGlvbmFsKScpXG4gICAgLm9wdGlvbignLS1vdmVycmlkZScsICdPdmVycmlkZSBleGlzdGluZyBzb3VyY2UgbWFwcyAob3B0aW9uYWwpJylcbiAgICAuZGVzY3JpcHRpb24oJ1VwZGF0ZSBzb3VyY2UgbWFwcycpXG4gICAgLmFjdGlvbihhc3luYyAob3B0aW9uczogVXBsb2FkU291cmNlTWFwc0NvbW1hbmRPcHRpb25zKSA9PiB7XG4gICAgICB0cnkge1xuICAgICAgICBpZiAob3B0aW9ucy5oZWxwKSB7XG4gICAgICAgICAgdXBsb2FkQ29tbWFuZC5vdXRwdXRIZWxwKCk7XG4gICAgICAgICAgcHJvY2Vzcy5leGl0KDApO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgeyBwcml2YXRlS2V5LCBhcHBsaWNhdGlvbiwgdmVyc2lvbiwgZm9sZGVyUGF0aCwgY29tbWl0SGFzaCwgcmVwb05hbWUsIG9yZ05hbWUsIGVudiwgb3ZlcnJpZGUgfSA9IG9wdGlvbnM7XG5cbiAgICAgICAgY2hlY2tNaXNzaW5nQXJndW1lbnRzPFVwbG9hZFNvdXJjZU1hcHNDb21tYW5kT3B0aW9ucz4ob3B0aW9ucywgWydwcml2YXRlS2V5JywgJ2FwcGxpY2F0aW9uJywgJ3ZlcnNpb24nLCAnZm9sZGVyUGF0aCcsICdlbnYnXSk7XG5cbiAgICAgICAgY29uc3Qgc2VydmljZTogU291cmNlTWFwc1NlcnZpY2UgPSBuZXcgU291cmNlTWFwc1NlcnZpY2UoKTtcblxuICAgICAgICBhd2FpdCBzZXJ2aWNlLnVwbG9hZChhcHBsaWNhdGlvbiwgdmVyc2lvbiwgcmVwb05hbWUsIGNvbW1pdEhhc2gsIG9yZ05hbWUsIGZvbGRlclBhdGgsIGVudiwgcHJpdmF0ZUtleSwgb3ZlcnJpZGUpO1xuICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgY29uc29sZUVycm9yKGVycm9yKTtcbiAgICAgIH1cbiAgICB9KTtcblxuICByZXR1cm4gdXBsb2FkQ29tbWFuZDtcbn07XG4iXX0=
@@ -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', // ap-southeast-3 (Jakarta)
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vY29uc3RzL2NvbnN0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBYSxRQUFBLEVBQUUsR0FBRyxJQUFJLEdBQUcsSUFBSSxDQUFDO0FBRWpCLFFBQUEsV0FBVyxHQUFHLG1CQUFtQixDQUFDO0FBRWxDLFFBQUEsU0FBUyxHQUFHLG1CQUFtQixDQUFDO0FBRWhDLFFBQUEsVUFBVSxHQUFHLG1CQUFtQixDQUFDO0FBRWpDLFFBQUEsaUJBQWlCLEdBQVcsRUFBRSxHQUFHLElBQUksR0FBRyxJQUFJLENBQUMsQ0FBQyxRQUFRO0FBRXRELFFBQUEsV0FBVyxHQUEyQjtJQUNqRCxHQUFHLEVBQUUsdUNBQXVDO0lBQzVDLEdBQUcsRUFBRSwyQ0FBMkM7SUFDaEQsR0FBRyxFQUFFLHNDQUFzQztJQUMzQyxHQUFHLEVBQUUsNkNBQTZDO0lBQ2xELEdBQUcsRUFBRSwwQ0FBMEM7SUFDL0MsR0FBRyxFQUFFLHlDQUF5QztJQUM5QyxHQUFHLEVBQUUsMkNBQTJDLEVBQUUsMkJBQTJCO0NBQzlFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgTUIgPSAxMDI0ICogMTAyNDtcblxuZXhwb3J0IGNvbnN0IEdSRUVOX0NPTE9SID0gJ1xceDFiWzMybSVzXFx4MWJbMG0nO1xuXG5leHBvcnQgY29uc3QgUkVEX0NPTE9SID0gJ1xceDFiWzMxbSVzXFx4MWJbMG0nO1xuXG5leHBvcnQgY29uc3QgR1JBWV9DT0xPUiA9ICdcXHgxYlszN20lc1xceDFiWzBtJztcblxuZXhwb3J0IGNvbnN0IFNUUkVBTV9DSFVOS19TSVpFOiBudW1iZXIgPSAxMCAqIDEwMjQgKiAxMDI0OyAvLyAxMCBNQlxuXG5leHBvcnQgY29uc3QgZW52VG9Eb21haW46IFJlY29yZDxzdHJpbmcsIHN0cmluZz4gPSB7XG4gIEVVMTogJ2h0dHBzOi8vbmctYXBpLWdycGMuY29yYWxvZ2l4LmNvbTo0NDMnLCAvLyBldS13ZXN0LTEgKElyZWxhbmQpXG4gIEVVMjogJ2h0dHBzOi8vbmctYXBpLWdycGMuZXUyLmNvcmFsb2dpeC5jb206NDQzJywgLy8gZXUtbm9ydGgtMSAoU3RvY2tob2xtKVxuICBVUzE6ICdodHRwczovL25nLWFwaS1ncnBjLmNvcmFsb2dpeC51czo0NDMnLCAvLyB1cy1lYXN0LTIgKE9oaW8pXG4gIFVTMjogJ2h0dHBzOi8vbmctYXBpLWdycGMuY3g0OTguY29yYWxvZ2l4LmNvbTo0NDMnLCAvLyB1cy13ZXN0LTIgKE9yZWdvbilcbiAgQVAxOiAnaHR0cHM6Ly9uZy1hcGktZ3JwYy5hcHAuY29yYWxvZ2l4LmluOjQ0MycsIC8vIGFwLXNvdXRoLTEgKE11bWJhaSlcbiAgQVAyOiAnaHR0cHM6Ly9uZy1hcGktZ3JwYy5jb3JhbG9naXhzZy5jb206NDQzJywgLy8gYXAtc291dGhlYXN0LTEgKFNpbmdhcG9yZSlcbiAgQVAzOiAnaHR0cHM6Ly9uZy1hcGktZ3JwYy5hcDMuY29yYWxvZ2l4LmNvbTo0NDMnLCAvLyBhcC1zb3V0aGVhc3QtMyAoSmFrYXJ0YSlcbn07XG4iXX0=
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vY29uc3RzL2NvbnN0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBYSxRQUFBLEVBQUUsR0FBRyxJQUFJLEdBQUcsSUFBSSxDQUFDO0FBRWpCLFFBQUEsV0FBVyxHQUFHLG1CQUFtQixDQUFDO0FBRWxDLFFBQUEsU0FBUyxHQUFHLG1CQUFtQixDQUFDO0FBRWhDLFFBQUEsVUFBVSxHQUFHLG1CQUFtQixDQUFDO0FBRWpDLFFBQUEsaUJBQWlCLEdBQVcsRUFBRSxHQUFHLElBQUksR0FBRyxJQUFJLENBQUMsQ0FBQyxRQUFRO0FBRXRELFFBQUEsV0FBVyxHQUEyQjtJQUNqRCxHQUFHLEVBQUUsdUNBQXVDO0lBQzVDLEdBQUcsRUFBRSwyQ0FBMkM7SUFDaEQsR0FBRyxFQUFFLHNDQUFzQztJQUMzQyxHQUFHLEVBQUUsNkNBQTZDO0lBQ2xELEdBQUcsRUFBRSwwQ0FBMEM7SUFDL0MsR0FBRyxFQUFFLHlDQUF5QztJQUM5QyxHQUFHLEVBQUUsMkNBQTJDO0lBQ2hELEdBQUcsRUFBRSxtREFBbUQ7Q0FDekQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBNQiA9IDEwMjQgKiAxMDI0O1xuXG5leHBvcnQgY29uc3QgR1JFRU5fQ09MT1IgPSAnXFx4MWJbMzJtJXNcXHgxYlswbSc7XG5cbmV4cG9ydCBjb25zdCBSRURfQ09MT1IgPSAnXFx4MWJbMzFtJXNcXHgxYlswbSc7XG5cbmV4cG9ydCBjb25zdCBHUkFZX0NPTE9SID0gJ1xceDFiWzM3bSVzXFx4MWJbMG0nO1xuXG5leHBvcnQgY29uc3QgU1RSRUFNX0NIVU5LX1NJWkU6IG51bWJlciA9IDEwICogMTAyNCAqIDEwMjQ7IC8vIDEwIE1CXG5cbmV4cG9ydCBjb25zdCBlbnZUb0RvbWFpbjogUmVjb3JkPHN0cmluZywgc3RyaW5nPiA9IHtcbiAgRVUxOiAnaHR0cHM6Ly9uZy1hcGktZ3JwYy5jb3JhbG9naXguY29tOjQ0MycsIC8vIGV1LXdlc3QtMSAoSXJlbGFuZClcbiAgRVUyOiAnaHR0cHM6Ly9uZy1hcGktZ3JwYy5ldTIuY29yYWxvZ2l4LmNvbTo0NDMnLCAvLyBldS1ub3J0aC0xIChTdG9ja2hvbG0pXG4gIFVTMTogJ2h0dHBzOi8vbmctYXBpLWdycGMuY29yYWxvZ2l4LnVzOjQ0MycsIC8vIHVzLWVhc3QtMiAoT2hpbylcbiAgVVMyOiAnaHR0cHM6Ly9uZy1hcGktZ3JwYy5jeDQ5OC5jb3JhbG9naXguY29tOjQ0MycsIC8vIHVzLXdlc3QtMiAoT3JlZ29uKVxuICBBUDE6ICdodHRwczovL25nLWFwaS1ncnBjLmFwcC5jb3JhbG9naXguaW46NDQzJywgLy8gYXAtc291dGgtMSAoTXVtYmFpKVxuICBBUDI6ICdodHRwczovL25nLWFwaS1ncnBjLmNvcmFsb2dpeHNnLmNvbTo0NDMnLCAvLyBhcC1zb3V0aGVhc3QtMSAoU2luZ2Fwb3JlKVxuICBBUDM6ICdodHRwczovL25nLWFwaS1ncnBjLmFwMy5jb3JhbG9naXguY29tOjQ0MycsIC8vIGFwLXNvdXRoZWFzdC0zIChKYWthcnRhKVxuICBTVEc6ICdodHRwczovL25nLWFwaS1ncnBjLmFwcC5zdGFnaW5nLmNvcmFsb2dpeC5uZXQ6NDQzJyxcbn07XG4iXX0=