@contrail/flexplm 1.3.0-alpha.5 → 1.3.0-alpha.7cd23d9

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 (87) hide show
  1. package/.github/workflows/flexplm-lib.yml +1 -1
  2. package/.github/workflows/publish-to-npm.yml +118 -0
  3. package/CHANGELOG.md +1 -1
  4. package/lib/entity-processor/base-entity-processor.d.ts +42 -42
  5. package/lib/entity-processor/base-entity-processor.js +385 -385
  6. package/lib/entity-processor/base-entity-processor.spec.d.ts +1 -1
  7. package/lib/entity-processor/base-entity-processor.spec.js +397 -397
  8. package/lib/flexplm-request.d.ts +3 -3
  9. package/lib/flexplm-request.js +34 -34
  10. package/lib/flexplm-utils.d.ts +5 -5
  11. package/lib/flexplm-utils.js +33 -33
  12. package/lib/flexplm-utils.spec.d.ts +1 -1
  13. package/lib/flexplm-utils.spec.js +26 -26
  14. package/lib/index.d.ts +22 -22
  15. package/lib/index.js +38 -38
  16. package/lib/interfaces/interfaces.d.ts +105 -105
  17. package/lib/interfaces/interfaces.js +2 -2
  18. package/lib/interfaces/item-family-changes.d.ts +20 -20
  19. package/lib/interfaces/item-family-changes.js +56 -56
  20. package/lib/interfaces/publish-change-data.d.ts +19 -19
  21. package/lib/interfaces/publish-change-data.js +32 -32
  22. package/lib/publish/base-process-publish-assortment-callback.d.ts +9 -9
  23. package/lib/publish/base-process-publish-assortment-callback.js +38 -38
  24. package/lib/publish/base-process-publish-assortment.d.ts +93 -93
  25. package/lib/publish/base-process-publish-assortment.js +944 -944
  26. package/lib/publish/base-process-publish-assortment.spec.d.ts +1 -1
  27. package/lib/publish/base-process-publish-assortment.spec.js +1670 -1670
  28. package/lib/publish/mockData.d.ts +1389 -1389
  29. package/lib/publish/mockData.js +4519 -4519
  30. package/lib/transform/identifier-conversion-spec-mockData.js +444 -444
  31. package/lib/transform/identifier-conversion.d.ts +15 -15
  32. package/lib/transform/identifier-conversion.js +212 -212
  33. package/lib/transform/identifier-conversion.spec.d.ts +1 -1
  34. package/lib/transform/identifier-conversion.spec.js +339 -339
  35. package/lib/util/config-defaults.d.ts +8 -8
  36. package/lib/util/config-defaults.js +85 -85
  37. package/lib/util/config-defaults.spec.d.ts +1 -1
  38. package/lib/util/config-defaults.spec.js +293 -293
  39. package/lib/util/data-converter-spec-mockData.js +205 -205
  40. package/lib/util/data-converter.d.ts +39 -39
  41. package/lib/util/data-converter.js +592 -592
  42. package/lib/util/data-converter.spec.d.ts +1 -1
  43. package/lib/util/data-converter.spec.js +904 -904
  44. package/lib/util/error-response-object.d.ts +4 -4
  45. package/lib/util/error-response-object.js +47 -47
  46. package/lib/util/error-response-object.spec.d.ts +1 -1
  47. package/lib/util/error-response-object.spec.js +99 -99
  48. package/lib/util/event-short-message-status.d.ts +19 -19
  49. package/lib/util/event-short-message-status.js +23 -23
  50. package/lib/util/federation.d.ts +15 -15
  51. package/lib/util/federation.js +149 -149
  52. package/lib/util/flexplm-connect.d.ts +22 -22
  53. package/lib/util/flexplm-connect.js +176 -176
  54. package/lib/util/flexplm-connect.spec.d.ts +1 -1
  55. package/lib/util/flexplm-connect.spec.js +88 -88
  56. package/lib/util/logger-config.d.ts +1 -1
  57. package/lib/util/logger-config.js +26 -26
  58. package/lib/util/map-util-spec-mockData.js +205 -205
  59. package/lib/util/map-utils.d.ts +6 -6
  60. package/lib/util/map-utils.js +15 -15
  61. package/lib/util/map-utils.spec.d.ts +1 -1
  62. package/lib/util/map-utils.spec.js +89 -89
  63. package/lib/util/mockData.d.ts +80 -80
  64. package/lib/util/mockData.js +103 -103
  65. package/lib/util/thumbnail-util.d.ts +34 -34
  66. package/lib/util/thumbnail-util.js +215 -214
  67. package/lib/util/thumbnail-util.spec.d.ts +1 -1
  68. package/lib/util/thumbnail-util.spec.js +434 -394
  69. package/lib/util/type-conversion-utils-spec-mockData.js +259 -259
  70. package/lib/util/type-conversion-utils.d.ts +23 -23
  71. package/lib/util/type-conversion-utils.js +265 -265
  72. package/lib/util/type-conversion-utils.spec.d.ts +1 -1
  73. package/lib/util/type-conversion-utils.spec.js +868 -868
  74. package/lib/util/type-defaults.d.ts +16 -16
  75. package/lib/util/type-defaults.js +221 -221
  76. package/lib/util/type-defaults.spec.d.ts +1 -1
  77. package/lib/util/type-defaults.spec.js +516 -516
  78. package/lib/util/type-utils.d.ts +13 -13
  79. package/lib/util/type-utils.js +114 -114
  80. package/lib/util/type-utils.spec.d.ts +1 -1
  81. package/lib/util/type-utils.spec.js +190 -190
  82. package/package.json +1 -1
  83. package/publish.sh +0 -0
  84. package/src/util/thumbnail-util.spec.ts +50 -0
  85. package/src/util/thumbnail-util.ts +5 -4
  86. package/tsconfig.json +1 -6
  87. package/.claude/settings.local.json +0 -8
@@ -389,6 +389,56 @@ describe('ThumbnailUtil Tests', () =>{
389
389
  );
390
390
  });
391
391
 
392
+ it('encodes URL path segments with special characters', async () => {
393
+ const mockResponse = {
394
+ arrayBuffer: jest.fn().mockResolvedValue(new ArrayBuffer(8)),
395
+ headers: { get: jest.fn().mockReturnValue('image/png') },
396
+ };
397
+ mockGetRequest.mockResolvedValue(mockResponse);
398
+ mockContentCreate.mockResolvedValue({
399
+ id: 'c1', contentType: 'image/png', fileName: 'my image.png',
400
+ primaryFileUrl: 'https://files/primary.png', largeViewableUrl: null,
401
+ mediumLargeViewableUrl: null, mediumViewableUrl: null, smallViewableUrl: null, tinyViewableUrl: null,
402
+ });
403
+
404
+ const event = { data: { [ThumbnailUtil.NEW_THUMBNAIL_ID]: '/rest/thumbnail/my image.png' } };
405
+ await tu.syncThumbnailToVibeIQ({ entityId: 'entity1', event, entityName: 'color' });
406
+
407
+ expect(mockGetRequest).toHaveBeenCalledWith({
408
+ urlPath: '/rest/thumbnail/my%20image.png',
409
+ includeUrlContext: false,
410
+ returnFullResponse: true,
411
+ });
412
+ expect(mockContentCreate).toHaveBeenCalledWith(
413
+ expect.objectContaining({ fileName: 'my image.png' }),
414
+ );
415
+ });
416
+
417
+ it('encodes URL path segments with unicode characters', async () => {
418
+ const mockResponse = {
419
+ arrayBuffer: jest.fn().mockResolvedValue(new ArrayBuffer(8)),
420
+ headers: { get: jest.fn().mockReturnValue('image/jpeg') },
421
+ };
422
+ mockGetRequest.mockResolvedValue(mockResponse);
423
+ mockContentCreate.mockResolvedValue({
424
+ id: 'c2', contentType: 'image/jpeg', fileName: 'café-logo.jpg',
425
+ primaryFileUrl: 'https://files/primary.jpg', largeViewableUrl: null,
426
+ mediumLargeViewableUrl: null, mediumViewableUrl: null, smallViewableUrl: null, tinyViewableUrl: null,
427
+ });
428
+
429
+ const event = { data: { [ThumbnailUtil.NEW_THUMBNAIL_ID]: '/rest/thumbnail/café-logo.jpg' } };
430
+ await tu.syncThumbnailToVibeIQ({ entityId: 'entity1', event, entityName: 'item' });
431
+
432
+ expect(mockGetRequest).toHaveBeenCalledWith({
433
+ urlPath: '/rest/thumbnail/caf%C3%A9-logo.jpg',
434
+ includeUrlContext: false,
435
+ returnFullResponse: true,
436
+ });
437
+ expect(mockContentCreate).toHaveBeenCalledWith(
438
+ expect.objectContaining({ fileName: 'café-logo.jpg' }),
439
+ );
440
+ });
441
+
392
442
  it('replaces content when primaryViewable.flexplmThumbnailUrl differs and updates entity', async () => {
393
443
  mockEntitiesGet.mockImplementation((opts) => {
394
444
  if (opts.entityName === 'content-custom-size') return Promise.resolve([]);
@@ -201,9 +201,13 @@ export class ThumbnailUtil {
201
201
  }
202
202
 
203
203
  private async createContentFromFlexPLM(thumbnailUrl: string, entityId: string, entityName: string): Promise<any> {
204
+ const urlParts = thumbnailUrl.split('/');
205
+ const fileName = urlParts[urlParts.length - 1] || 'thumbnail';
206
+
207
+ const encodedUrl = urlParts.map(part => encodeURIComponent(part)).join('/');
204
208
  const flexPLMConnect = new FlexPLMConnect(this.config);
205
209
  const response = await flexPLMConnect.getRequest({
206
- urlPath: thumbnailUrl,
210
+ urlPath: encodedUrl,
207
211
  includeUrlContext: false,
208
212
  returnFullResponse: true,
209
213
  }) as Response;
@@ -213,9 +217,6 @@ export class ThumbnailUtil {
213
217
  const contentTypeHeader = response.headers.get('content-type');
214
218
  const contentType = contentTypeHeader ? contentTypeHeader.split(';')[0] : 'application/octet-stream';
215
219
 
216
- const urlParts = thumbnailUrl.split('/');
217
- const fileName = urlParts[urlParts.length - 1] || 'thumbnail';
218
-
219
220
  const contentHolderReference = `${entityName}:${entityId}`;
220
221
  const content = await new Content().create({
221
222
  fileBuffer: buffer,
package/tsconfig.json CHANGED
@@ -15,14 +15,9 @@
15
15
  "removeComments": true,
16
16
  "skipLibCheck": true,
17
17
  "lib": [
18
- "es5",
19
- "ES2015",
20
- "ES2016",
21
- "ES2017",
22
18
  "ES2020",
23
19
  "dom",
24
- "esnext.asynciterable"
25
- ],
20
+ ],
26
21
  },
27
22
  "include": ["src"],
28
23
  "exclude": ["node_modules", "**/__tests__/*"]
@@ -1,8 +0,0 @@
1
- {
2
- "permissions": {
3
- "allow": [
4
- "Bash(npx jest:*)",
5
- "Bash(npx tsc:*)"
6
- ]
7
- }
8
- }