@contrail/flexplm 1.3.0-alpha.0 → 1.3.0-alpha.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/settings.local.json +2 -1
- package/.github/pull_request_template.md +31 -31
- package/.github/workflows/flexplm-lib.yml +27 -27
- package/CHANGELOG.md +1 -1
- package/lib/entity-processor/base-entity-processor.d.ts +42 -0
- package/lib/entity-processor/base-entity-processor.js +377 -0
- package/lib/entity-processor/base-entity-processor.spec.d.ts +1 -0
- package/lib/entity-processor/base-entity-processor.spec.js +426 -0
- package/lib/flexplm-request.d.ts +3 -0
- package/lib/flexplm-request.js +34 -0
- package/lib/flexplm-utils.d.ts +5 -0
- package/lib/flexplm-utils.js +33 -0
- package/lib/flexplm-utils.spec.d.ts +1 -0
- package/lib/flexplm-utils.spec.js +26 -0
- package/lib/index.d.ts +22 -0
- package/lib/index.js +38 -0
- package/lib/interfaces/interfaces.d.ts +105 -0
- package/lib/interfaces/interfaces.js +2 -0
- package/lib/interfaces/item-family-changes.d.ts +20 -0
- package/lib/interfaces/item-family-changes.js +56 -0
- package/lib/interfaces/publish-change-data.d.ts +19 -0
- package/lib/interfaces/publish-change-data.js +32 -0
- package/lib/publish/base-process-publish-assortment-callback.d.ts +9 -0
- package/lib/publish/base-process-publish-assortment-callback.js +38 -0
- package/lib/publish/base-process-publish-assortment.d.ts +93 -0
- package/lib/publish/base-process-publish-assortment.js +944 -0
- package/lib/publish/base-process-publish-assortment.spec.d.ts +1 -0
- package/lib/publish/base-process-publish-assortment.spec.js +1670 -0
- package/lib/publish/mockData.d.ts +1389 -0
- package/lib/publish/mockData.js +4519 -0
- package/lib/transform/identifier-conversion-spec-mockData.d.ts +0 -0
- package/lib/transform/identifier-conversion-spec-mockData.js +444 -0
- package/lib/transform/identifier-conversion.d.ts +15 -0
- package/lib/transform/identifier-conversion.js +212 -0
- package/lib/transform/identifier-conversion.spec.d.ts +1 -0
- package/lib/transform/identifier-conversion.spec.js +339 -0
- package/lib/util/config-defaults.d.ts +8 -0
- package/lib/util/config-defaults.js +85 -0
- package/lib/util/config-defaults.spec.d.ts +1 -0
- package/lib/util/config-defaults.spec.js +293 -0
- package/lib/util/data-converter-spec-mockData.d.ts +0 -0
- package/lib/util/data-converter-spec-mockData.js +205 -0
- package/lib/util/data-converter.d.ts +39 -0
- package/lib/util/data-converter.js +592 -0
- package/lib/util/data-converter.spec.d.ts +1 -0
- package/lib/util/data-converter.spec.js +904 -0
- package/lib/util/error-response-object.d.ts +4 -0
- package/lib/util/error-response-object.js +47 -0
- package/lib/util/error-response-object.spec.d.ts +1 -0
- package/lib/util/error-response-object.spec.js +99 -0
- package/lib/util/event-short-message-status.d.ts +18 -0
- package/lib/util/event-short-message-status.js +22 -0
- package/lib/util/federation.d.ts +15 -0
- package/lib/util/federation.js +149 -0
- package/lib/util/flexplm-connect.d.ts +22 -0
- package/lib/util/flexplm-connect.js +176 -0
- package/lib/util/flexplm-connect.spec.d.ts +1 -0
- package/lib/util/flexplm-connect.spec.js +88 -0
- package/lib/util/logger-config.d.ts +1 -0
- package/lib/util/logger-config.js +26 -0
- package/lib/util/map-util-spec-mockData.d.ts +0 -0
- package/lib/util/map-util-spec-mockData.js +205 -0
- package/lib/util/map-utils.d.ts +6 -0
- package/lib/util/map-utils.js +15 -0
- package/lib/util/map-utils.spec.d.ts +1 -0
- package/lib/util/map-utils.spec.js +89 -0
- package/lib/util/mockData.d.ts +80 -0
- package/lib/util/mockData.js +103 -0
- package/lib/util/thumbnail-util.d.ts +34 -0
- package/lib/util/thumbnail-util.js +211 -0
- package/lib/util/thumbnail-util.spec.d.ts +1 -0
- package/lib/util/thumbnail-util.spec.js +398 -0
- package/lib/util/type-conversion-utils-spec-mockData.d.ts +0 -0
- package/lib/util/type-conversion-utils-spec-mockData.js +259 -0
- package/lib/util/type-conversion-utils.d.ts +23 -0
- package/lib/util/type-conversion-utils.js +266 -0
- package/lib/util/type-conversion-utils.spec.d.ts +1 -0
- package/lib/util/type-conversion-utils.spec.js +868 -0
- package/lib/util/type-defaults.d.ts +16 -0
- package/lib/util/type-defaults.js +221 -0
- package/lib/util/type-defaults.spec.d.ts +1 -0
- package/lib/util/type-defaults.spec.js +516 -0
- package/lib/util/type-utils.d.ts +13 -0
- package/lib/util/type-utils.js +114 -0
- package/lib/util/type-utils.spec.d.ts +1 -0
- package/lib/util/type-utils.spec.js +190 -0
- package/package.json +1 -1
- package/publish.bat +4 -4
- package/publish.sh +4 -4
- package/src/entity-processor/base-entity-processor.spec.ts +157 -0
- package/src/entity-processor/base-entity-processor.ts +21 -2
- package/src/flexplm-request.ts +28 -28
- package/src/flexplm-utils.spec.ts +27 -27
- package/src/flexplm-utils.ts +29 -29
- package/src/index.ts +21 -21
- package/src/interfaces/item-family-changes.ts +66 -66
- package/src/interfaces/publish-change-data.ts +42 -42
- package/src/publish/base-process-publish-assortment-callback.ts +50 -50
- package/src/transform/identifier-conversion-spec-mockData.ts +495 -495
- package/src/transform/identifier-conversion.spec.ts +353 -353
- package/src/transform/identifier-conversion.ts +281 -281
- package/src/util/config-defaults.spec.ts +350 -350
- package/src/util/config-defaults.ts +92 -92
- package/src/util/data-converter-spec-mockData.ts +230 -230
- package/src/util/error-response-object.spec.ts +115 -115
- package/src/util/error-response-object.ts +49 -49
- package/src/util/federation.ts +172 -172
- package/src/util/logger-config.ts +19 -19
- package/src/util/map-util-spec-mockData.ts +230 -230
- package/src/util/map-utils.spec.ts +102 -102
- package/src/util/map-utils.ts +40 -40
- package/src/util/mockData.ts +101 -97
- package/src/util/thumbnail-util.spec.ts +190 -0
- package/src/util/thumbnail-util.ts +126 -5
- package/src/util/type-conversion-utils.spec.ts +25 -25
- package/src/util/type-conversion-utils.ts +10 -9
- package/src/util/type-defaults.spec.ts +668 -668
- package/src/util/type-defaults.ts +280 -280
- package/src/util/type-utils.spec.ts +227 -227
- package/src/util/type-utils.ts +144 -144
- package/tsconfig.json +28 -26
- package/tslint.json +57 -57
- package/scripts/output.png +0 -0
- package/scripts/test-get-request.ts +0 -35
package/src/util/type-utils.ts
CHANGED
|
@@ -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
|
-
"
|
|
7
|
-
"
|
|
8
|
-
"
|
|
9
|
-
"
|
|
10
|
-
"
|
|
11
|
-
"
|
|
12
|
-
"
|
|
13
|
-
"
|
|
14
|
-
"
|
|
15
|
-
"
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
"
|
|
19
|
-
"
|
|
20
|
-
"
|
|
21
|
-
"
|
|
22
|
-
"
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
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
|
+
}
|
package/scripts/output.png
DELETED
|
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
|
-
});
|