@contrail/flexplm 1.2.1 → 1.3.0-alpha.3

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 (57) hide show
  1. package/.claude/settings.local.json +1 -2
  2. package/.github/pull_request_template.md +31 -31
  3. package/.github/workflows/flexplm-lib.yml +27 -27
  4. package/lib/entity-processor/base-entity-processor.js +16 -2
  5. package/lib/entity-processor/base-entity-processor.spec.js +124 -0
  6. package/lib/util/flexplm-connect.d.ts +5 -1
  7. package/lib/util/flexplm-connect.js +8 -3
  8. package/lib/util/flexplm-connect.spec.d.ts +1 -0
  9. package/lib/util/flexplm-connect.spec.js +88 -0
  10. package/lib/util/thumbnail-util.d.ts +9 -0
  11. package/lib/util/thumbnail-util.js +88 -0
  12. package/lib/util/thumbnail-util.spec.js +156 -0
  13. package/lib/util/type-conversion-utils-spec-mockData.js +18 -0
  14. package/lib/util/type-conversion-utils.d.ts +2 -0
  15. package/lib/util/type-conversion-utils.js +43 -0
  16. package/lib/util/type-conversion-utils.spec.js +160 -0
  17. package/package.json +1 -1
  18. package/publish.bat +4 -4
  19. package/publish.sh +4 -4
  20. package/src/entity-processor/base-entity-processor.spec.ts +157 -0
  21. package/src/entity-processor/base-entity-processor.ts +21 -2
  22. package/src/flexplm-request.ts +28 -28
  23. package/src/flexplm-utils.spec.ts +27 -27
  24. package/src/flexplm-utils.ts +29 -29
  25. package/src/index.ts +21 -21
  26. package/src/interfaces/item-family-changes.ts +66 -66
  27. package/src/interfaces/publish-change-data.ts +42 -42
  28. package/src/publish/base-process-publish-assortment-callback.ts +50 -50
  29. package/src/transform/identifier-conversion-spec-mockData.ts +495 -495
  30. package/src/transform/identifier-conversion.spec.ts +353 -353
  31. package/src/transform/identifier-conversion.ts +281 -281
  32. package/src/util/config-defaults.spec.ts +350 -350
  33. package/src/util/config-defaults.ts +92 -92
  34. package/src/util/data-converter-spec-mockData.ts +230 -230
  35. package/src/util/error-response-object.spec.ts +115 -115
  36. package/src/util/error-response-object.ts +49 -49
  37. package/src/util/federation.ts +172 -172
  38. package/src/util/flexplm-connect.spec.ts +132 -0
  39. package/src/util/flexplm-connect.ts +14 -5
  40. package/src/util/logger-config.ts +19 -19
  41. package/src/util/map-util-spec-mockData.ts +230 -230
  42. package/src/util/map-utils.spec.ts +102 -102
  43. package/src/util/map-utils.ts +40 -40
  44. package/src/util/mockData.ts +97 -97
  45. package/src/util/thumbnail-util.spec.ts +190 -0
  46. package/src/util/thumbnail-util.ts +109 -1
  47. package/src/util/type-conversion-utils-spec-mockData.ts +18 -0
  48. package/src/util/type-conversion-utils.spec.ts +184 -0
  49. package/src/util/type-conversion-utils.ts +75 -0
  50. package/src/util/type-defaults.spec.ts +668 -668
  51. package/src/util/type-defaults.ts +280 -280
  52. package/src/util/type-utils.spec.ts +227 -227
  53. package/src/util/type-utils.ts +144 -144
  54. package/tsconfig.json +28 -26
  55. package/tslint.json +57 -57
  56. package/scripts/output.png +0 -0
  57. package/scripts/test-get-request.ts +0 -35
@@ -1,144 +1,144 @@
1
- import { Logger } from '@contrail/app-framework';
2
- import { TypeClientOptions, Types } from '@contrail/sdk';
3
- import { TypeProperty } from '@contrail/types';
4
- import { TypeConversionUtils } from './type-conversion-utils';
5
-
6
- export class TypeUtils {
7
- private typesObj: Types;
8
- constructor() {
9
- this.typesObj = new Types();
10
- }
11
-
12
- async getTypeById(id) {
13
- // this.logger.log('!-getTypeById: ' + id);
14
- const type = await this.typesObj.getType({
15
- id,
16
- relations: ['typeProperties', 'typeInterfaces']
17
- });
18
- return type;
19
- }
20
-
21
- async getByRootAndPath(options: TypeClientOptions) {
22
- const type = await this.typesObj.getByRootAndPath(options);
23
- return type;
24
- }
25
-
26
- /** Deprecated: use TypeConversionUtils.getObjectTypePath() */
27
- static getFlexPLMTypePath(entity) {
28
- return entity['flexPLMTypePath'] || entity['flexTypePath'] || '';
29
- }
30
-
31
- /** Deprecated: use TypeConversionUtils.getObjectClass()
32
- *
33
- * @param entityType
34
- * @param newData
35
- * @returns
36
- */
37
- getEventObjectClass(entityType: string, newData): string {
38
- let objectClass = '';
39
- if ('item' === entityType) {
40
- if (newData.roles.includes('family')) {
41
- objectClass = 'LCSProduct';
42
- } else if (newData.roles.includes('color')) {
43
- objectClass = 'LCSSKU';
44
- }
45
- } else if ('project-item' === entityType) {
46
- if (newData.roles.includes('family')) {
47
- objectClass = 'LCSProductSeasonLink';
48
- } else if (newData.roles.includes('color')) {
49
- objectClass = 'LCSSKUSeasonLink';
50
- }
51
- } else if ('color' === entityType) {
52
- objectClass = 'LCSColor';
53
- } else if ('custom-entity' === entityType) {
54
- objectClass = 'LCSRevisableEntity';
55
-
56
- }
57
- return objectClass;
58
- }
59
-
60
- /** Gets the VibeIQ entity type for the object data
61
- * @param data: object data
62
- */
63
- async getEntityTypeClientOptionsUsingMapping(transformMapFile, mapFileUtil, data): Promise<TypeClientOptions> {
64
- const root = await TypeConversionUtils.getEntityClassFromObject(transformMapFile, mapFileUtil, data);
65
- const path = await TypeConversionUtils.getEntityTypePathFromOjbect(transformMapFile, mapFileUtil, data);
66
-
67
- let tco: TypeClientOptions = {
68
- root,
69
- path
70
- };
71
-
72
-
73
-
74
- return tco;
75
- }
76
-
77
- /** Gets the VibeIQ entity type for the object data
78
- * @param objectClass: string object class
79
- * @param data: object data
80
- */
81
- getEntityTypeClientOptions(objectClass: string, data): TypeClientOptions {
82
- let tco: TypeClientOptions;
83
- if (['LCSProduct', 'LCSSKU'].includes(objectClass)) {
84
- tco = {
85
- root: 'item'
86
- };
87
- } else if ('LCSSeason' === objectClass) {
88
- tco = {
89
- root: 'assortment'
90
- };
91
- } else if ('LCSColor' === objectClass) {
92
- tco = {
93
- root: 'color'
94
- };
95
- } else if (['LCSBusinessObject', 'LCSRevisableEntity', 'LCSLast'].includes(objectClass)) {
96
- //TODO need to write logic using mapping file
97
- tco = {
98
- root: 'custom-entity'
99
- };
100
- console.log('data: ' + data);
101
- }
102
-
103
- return tco;
104
- }
105
- /** This will filter the properties based the newData entity.
106
- * It is assumed the type is correct for the entity
107
- *
108
- * @param type entire type object
109
- * @param newData the entity being processed
110
- * @returns TypeProperty[] of applicable properties
111
- */
112
- filterTypeProperties(type, newData): TypeProperty[] {
113
- let filteredProps: TypeProperty[] = type['typeProperties'];
114
- const typePath = type['typePath'];
115
- const roles = newData['roles'];
116
- if (typePath && (typePath.startsWith('item') || typePath.startsWith('project-item'))) {
117
- if (Logger.isDebugOn()) {
118
- console.debug('filterTypeProperties():id: ' +newData?.id
119
- + ', typePath: ' + typePath
120
- + ', newData.roles: ' + newData?.roles);
121
- }
122
- if (roles) {
123
- const isFamily = roles.includes('family');
124
- if (Logger.isDebugOn()) {
125
- console.debug('isFamily: ' + isFamily);
126
- }
127
-
128
- filteredProps = filteredProps.filter(prop => {
129
- const propertyLevel = prop.propertyLevel;
130
- const applies =
131
- (isFamily && 'option' != propertyLevel) ||
132
- (!isFamily && 'family' != propertyLevel);
133
- return applies;
134
- });
135
-
136
- } else {
137
- console.error('filterTypeProperties():Entity missing role-id: ' + newData['id']);
138
- }
139
- }
140
-
141
- return filteredProps;
142
- }
143
-
144
- }
1
+ import { Logger } from '@contrail/app-framework';
2
+ import { TypeClientOptions, Types } from '@contrail/sdk';
3
+ import { TypeProperty } from '@contrail/types';
4
+ import { TypeConversionUtils } from './type-conversion-utils';
5
+
6
+ export class TypeUtils {
7
+ private typesObj: Types;
8
+ constructor() {
9
+ this.typesObj = new Types();
10
+ }
11
+
12
+ async getTypeById(id) {
13
+ // this.logger.log('!-getTypeById: ' + id);
14
+ const type = await this.typesObj.getType({
15
+ id,
16
+ relations: ['typeProperties', 'typeInterfaces']
17
+ });
18
+ return type;
19
+ }
20
+
21
+ async getByRootAndPath(options: TypeClientOptions) {
22
+ const type = await this.typesObj.getByRootAndPath(options);
23
+ return type;
24
+ }
25
+
26
+ /** Deprecated: use TypeConversionUtils.getObjectTypePath() */
27
+ static getFlexPLMTypePath(entity) {
28
+ return entity['flexPLMTypePath'] || entity['flexTypePath'] || '';
29
+ }
30
+
31
+ /** Deprecated: use TypeConversionUtils.getObjectClass()
32
+ *
33
+ * @param entityType
34
+ * @param newData
35
+ * @returns
36
+ */
37
+ getEventObjectClass(entityType: string, newData): string {
38
+ let objectClass = '';
39
+ if ('item' === entityType) {
40
+ if (newData.roles.includes('family')) {
41
+ objectClass = 'LCSProduct';
42
+ } else if (newData.roles.includes('color')) {
43
+ objectClass = 'LCSSKU';
44
+ }
45
+ } else if ('project-item' === entityType) {
46
+ if (newData.roles.includes('family')) {
47
+ objectClass = 'LCSProductSeasonLink';
48
+ } else if (newData.roles.includes('color')) {
49
+ objectClass = 'LCSSKUSeasonLink';
50
+ }
51
+ } else if ('color' === entityType) {
52
+ objectClass = 'LCSColor';
53
+ } else if ('custom-entity' === entityType) {
54
+ objectClass = 'LCSRevisableEntity';
55
+
56
+ }
57
+ return objectClass;
58
+ }
59
+
60
+ /** Gets the VibeIQ entity type for the object data
61
+ * @param data: object data
62
+ */
63
+ async getEntityTypeClientOptionsUsingMapping(transformMapFile, mapFileUtil, data): Promise<TypeClientOptions> {
64
+ const root = await TypeConversionUtils.getEntityClassFromObject(transformMapFile, mapFileUtil, data);
65
+ const path = await TypeConversionUtils.getEntityTypePathFromOjbect(transformMapFile, mapFileUtil, data);
66
+
67
+ let tco: TypeClientOptions = {
68
+ root,
69
+ path
70
+ };
71
+
72
+
73
+
74
+ return tco;
75
+ }
76
+
77
+ /** Gets the VibeIQ entity type for the object data
78
+ * @param objectClass: string object class
79
+ * @param data: object data
80
+ */
81
+ getEntityTypeClientOptions(objectClass: string, data): TypeClientOptions {
82
+ let tco: TypeClientOptions;
83
+ if (['LCSProduct', 'LCSSKU'].includes(objectClass)) {
84
+ tco = {
85
+ root: 'item'
86
+ };
87
+ } else if ('LCSSeason' === objectClass) {
88
+ tco = {
89
+ root: 'assortment'
90
+ };
91
+ } else if ('LCSColor' === objectClass) {
92
+ tco = {
93
+ root: 'color'
94
+ };
95
+ } else if (['LCSBusinessObject', 'LCSRevisableEntity', 'LCSLast'].includes(objectClass)) {
96
+ //TODO need to write logic using mapping file
97
+ tco = {
98
+ root: 'custom-entity'
99
+ };
100
+ console.log('data: ' + data);
101
+ }
102
+
103
+ return tco;
104
+ }
105
+ /** This will filter the properties based the newData entity.
106
+ * It is assumed the type is correct for the entity
107
+ *
108
+ * @param type entire type object
109
+ * @param newData the entity being processed
110
+ * @returns TypeProperty[] of applicable properties
111
+ */
112
+ filterTypeProperties(type, newData): TypeProperty[] {
113
+ let filteredProps: TypeProperty[] = type['typeProperties'];
114
+ const typePath = type['typePath'];
115
+ const roles = newData['roles'];
116
+ if (typePath && (typePath.startsWith('item') || typePath.startsWith('project-item'))) {
117
+ if (Logger.isDebugOn()) {
118
+ console.debug('filterTypeProperties():id: ' +newData?.id
119
+ + ', typePath: ' + typePath
120
+ + ', newData.roles: ' + newData?.roles);
121
+ }
122
+ if (roles) {
123
+ const isFamily = roles.includes('family');
124
+ if (Logger.isDebugOn()) {
125
+ console.debug('isFamily: ' + isFamily);
126
+ }
127
+
128
+ filteredProps = filteredProps.filter(prop => {
129
+ const propertyLevel = prop.propertyLevel;
130
+ const applies =
131
+ (isFamily && 'option' != propertyLevel) ||
132
+ (!isFamily && 'family' != propertyLevel);
133
+ return applies;
134
+ });
135
+
136
+ } else {
137
+ console.error('filterTypeProperties():Entity missing role-id: ' + newData['id']);
138
+ }
139
+ }
140
+
141
+ return filteredProps;
142
+ }
143
+
144
+ }
package/tsconfig.json CHANGED
@@ -1,27 +1,29 @@
1
- {
2
- "compilerOptions": {
3
- "target": "es2020",
4
- "module": "commonjs",
5
- "declaration": true,
6
- "outDir": "./lib",
7
- "experimentalDecorators": true,
8
- "esModuleInterop": true,
9
- "strictPropertyInitialization": false,
10
- "noImplicitAny": false,
11
- "allowSyntheticDefaultImports": true,
12
- "emitDecoratorMetadata": true,
13
- "removeComments": true,
14
- "skipLibCheck": true,
15
- "lib": [
16
- "es5",
17
- "ES2015",
18
- "ES2016",
19
- "ES2017",
20
- "ES2020",
21
- "dom",
22
- "esnext.asynciterable"
23
- ],
24
- },
25
- "include": ["src"],
26
- "exclude": ["node_modules", "**/__tests__/*"]
1
+ {
2
+ "compilerOptions": {
3
+ "target": "es2020",
4
+ "module": "commonjs",
5
+ "declaration": true,
6
+ "rootDir": "./src",
7
+ "outDir": "./lib",
8
+ "types": ["jest", "node"],
9
+ "experimentalDecorators": true,
10
+ "esModuleInterop": true,
11
+ "strictPropertyInitialization": false,
12
+ "noImplicitAny": false,
13
+ "allowSyntheticDefaultImports": true,
14
+ "emitDecoratorMetadata": true,
15
+ "removeComments": true,
16
+ "skipLibCheck": true,
17
+ "lib": [
18
+ "es5",
19
+ "ES2015",
20
+ "ES2016",
21
+ "ES2017",
22
+ "ES2020",
23
+ "dom",
24
+ "esnext.asynciterable"
25
+ ],
26
+ },
27
+ "include": ["src"],
28
+ "exclude": ["node_modules", "**/__tests__/*"]
27
29
  }
package/tslint.json CHANGED
@@ -1,57 +1,57 @@
1
- {
2
- "defaultSeverity": "error",
3
- "extends": [
4
- "tslint:recommended"
5
- ],
6
- "jsRules": {
7
- "no-unused-expression": true
8
- },
9
- "rules": {
10
- "eofline": false,
11
- "quotemark": [
12
- true,
13
- "single"
14
- ],
15
- "no-shadowed-variable": false,
16
- "indent": false,
17
- "member-access": [
18
- false
19
- ],
20
- "no-string-literal": false,
21
- "ordered-imports": [
22
- false
23
- ],
24
- "max-line-length": [
25
- false,
26
- 150
27
- ],
28
- "member-ordering": [
29
- false
30
- ],
31
- "curly": false,
32
- "interface-name": [
33
- false
34
- ],
35
- "array-type": [
36
- false
37
- ],
38
- "no-empty-interface": false,
39
- "no-empty": false,
40
- "arrow-parens": false,
41
- "object-literal-sort-keys": false,
42
- "no-unused-expression": false,
43
- "max-classes-per-file": [
44
- false
45
- ],
46
- "variable-name": [
47
- false
48
- ],
49
- "one-line": [
50
- false
51
- ],
52
- "one-variable-per-declaration": [
53
- false
54
- ]
55
- },
56
- "rulesDirectory": []
57
- }
1
+ {
2
+ "defaultSeverity": "error",
3
+ "extends": [
4
+ "tslint:recommended"
5
+ ],
6
+ "jsRules": {
7
+ "no-unused-expression": true
8
+ },
9
+ "rules": {
10
+ "eofline": false,
11
+ "quotemark": [
12
+ true,
13
+ "single"
14
+ ],
15
+ "no-shadowed-variable": false,
16
+ "indent": false,
17
+ "member-access": [
18
+ false
19
+ ],
20
+ "no-string-literal": false,
21
+ "ordered-imports": [
22
+ false
23
+ ],
24
+ "max-line-length": [
25
+ false,
26
+ 150
27
+ ],
28
+ "member-ordering": [
29
+ false
30
+ ],
31
+ "curly": false,
32
+ "interface-name": [
33
+ false
34
+ ],
35
+ "array-type": [
36
+ false
37
+ ],
38
+ "no-empty-interface": false,
39
+ "no-empty": false,
40
+ "arrow-parens": false,
41
+ "object-literal-sort-keys": false,
42
+ "no-unused-expression": false,
43
+ "max-classes-per-file": [
44
+ false
45
+ ],
46
+ "variable-name": [
47
+ false
48
+ ],
49
+ "one-line": [
50
+ false
51
+ ],
52
+ "one-variable-per-declaration": [
53
+ false
54
+ ]
55
+ },
56
+ "rulesDirectory": []
57
+ }
Binary file
@@ -1,35 +0,0 @@
1
- import * as fs from 'fs';
2
- import * as path from 'path';
3
- import { FlexPLMConnect } from '../src/util/flexplm-connect';
4
- import { FCConfig } from '../src/interfaces/interfaces';
5
-
6
- const config: FCConfig = {
7
- apiHost: 'http://windchill.archergrey.com',
8
- urlContext: '',
9
- vibeEventEndpoint: '',
10
- csrfEndpoint: '',
11
- plmEnviornment: '',
12
- userName: () => '', // fill in manually
13
- password: () => '', // fill in manually
14
- itemPreDevelopmentLifecycleStages: [],
15
- payloadDefaultAsArray: true,
16
- };
17
-
18
- async function main() {
19
- const connect = new FlexPLMConnect(config);
20
- const response = await connect.getRequest({
21
- urlPath: '/Windchill/images/000001/000001/000001/cavkingcharlessmalldogs_medium_large-.-2965893984400.png',
22
- includeUrlContext: false,
23
- returnFullResponse: true,
24
- }) as Response;
25
-
26
- const buffer = Buffer.from(await response.arrayBuffer());
27
- const outputPath = path.resolve(__dirname, 'output.png');
28
- fs.writeFileSync(outputPath, buffer);
29
- console.log(`Saved response to ${outputPath}`);
30
- }
31
-
32
- main().catch((err) => {
33
- console.error('Error:', err.message);
34
- process.exit(1);
35
- });