@contrail/flexplm 1.3.0 → 1.3.1-alpha.585afc1
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/lib/cli/commands/compile.d.ts +1 -0
- package/lib/cli/commands/compile.js +71 -0
- package/lib/cli/commands/compile.spec.d.ts +1 -0
- package/lib/cli/commands/compile.spec.js +80 -0
- package/lib/cli/commands/create.d.ts +1 -0
- package/lib/cli/commands/create.js +75 -0
- package/lib/cli/commands/create.spec.d.ts +1 -0
- package/lib/cli/commands/create.spec.js +78 -0
- package/lib/cli/commands/upload.d.ts +10 -0
- package/lib/cli/commands/upload.js +219 -0
- package/lib/cli/commands/upload.spec.d.ts +1 -0
- package/lib/cli/commands/upload.spec.js +88 -0
- package/lib/cli/index.d.ts +2 -0
- package/lib/cli/index.js +64 -0
- package/lib/cli/index.spec.d.ts +1 -0
- package/lib/cli/index.spec.js +79 -0
- package/lib/cli/template/mapping-template.ts.template +18 -0
- package/lib/entity-processor/base-entity-processor.d.ts +89 -42
- package/lib/entity-processor/base-entity-processor.js +438 -385
- package/lib/entity-processor/base-entity-processor.spec.d.ts +1 -1
- package/lib/entity-processor/base-entity-processor.spec.js +398 -397
- package/lib/flexplm-request.d.ts +3 -3
- package/lib/flexplm-request.js +34 -34
- package/lib/flexplm-utils.d.ts +5 -5
- package/lib/flexplm-utils.js +33 -33
- package/lib/flexplm-utils.spec.d.ts +1 -1
- package/lib/flexplm-utils.spec.js +26 -26
- package/lib/index.d.ts +23 -22
- package/lib/index.js +39 -38
- package/lib/interfaces/interfaces.d.ts +105 -105
- package/lib/interfaces/interfaces.js +2 -2
- package/lib/interfaces/item-family-changes.d.ts +20 -20
- package/lib/interfaces/item-family-changes.js +56 -56
- package/lib/interfaces/mapping-file.d.ts +429 -0
- package/lib/interfaces/mapping-file.js +2 -0
- package/lib/interfaces/publish-change-data.d.ts +19 -19
- package/lib/interfaces/publish-change-data.js +32 -32
- package/lib/publish/base-process-publish-assortment-callback.d.ts +9 -9
- package/lib/publish/base-process-publish-assortment-callback.js +38 -38
- package/lib/publish/base-process-publish-assortment.d.ts +118 -93
- package/lib/publish/base-process-publish-assortment.js +998 -944
- package/lib/publish/base-process-publish-assortment.spec.d.ts +1 -1
- package/lib/publish/base-process-publish-assortment.spec.js +1688 -1670
- package/lib/publish/mockData.d.ts +1389 -1389
- package/lib/publish/mockData.js +4524 -4519
- package/lib/transform/identifier-conversion-spec-mockData.js +472 -444
- package/lib/transform/identifier-conversion.d.ts +51 -15
- package/lib/transform/identifier-conversion.js +248 -212
- package/lib/transform/identifier-conversion.spec.d.ts +1 -1
- package/lib/transform/identifier-conversion.spec.js +343 -339
- package/lib/util/config-defaults.d.ts +8 -8
- package/lib/util/config-defaults.js +88 -85
- package/lib/util/config-defaults.spec.d.ts +1 -1
- package/lib/util/config-defaults.spec.js +302 -293
- package/lib/util/data-converter-spec-mockData.js +219 -205
- package/lib/util/data-converter.d.ts +136 -39
- package/lib/util/data-converter.js +718 -592
- package/lib/util/data-converter.spec.d.ts +1 -1
- package/lib/util/data-converter.spec.js +906 -904
- package/lib/util/error-response-object.d.ts +9 -4
- package/lib/util/error-response-object.js +54 -47
- package/lib/util/error-response-object.spec.d.ts +1 -1
- package/lib/util/error-response-object.spec.js +99 -99
- package/lib/util/event-short-message-status.d.ts +19 -19
- package/lib/util/event-short-message-status.js +24 -23
- package/lib/util/federation.d.ts +15 -15
- package/lib/util/federation.js +157 -149
- package/lib/util/flexplm-connect.d.ts +29 -22
- package/lib/util/flexplm-connect.js +190 -176
- package/lib/util/flexplm-connect.spec.d.ts +1 -1
- package/lib/util/flexplm-connect.spec.js +88 -88
- package/lib/util/logger-config.d.ts +1 -1
- package/lib/util/logger-config.js +27 -26
- package/lib/util/map-util-spec-mockData.js +219 -205
- package/lib/util/map-utils.d.ts +33 -6
- package/lib/util/map-utils.js +42 -15
- package/lib/util/map-utils.spec.d.ts +1 -1
- package/lib/util/map-utils.spec.js +89 -89
- package/lib/util/mockData.d.ts +80 -80
- package/lib/util/mockData.js +103 -103
- package/lib/util/thumbnail-util.d.ts +55 -34
- package/lib/util/thumbnail-util.js +242 -215
- package/lib/util/thumbnail-util.spec.d.ts +1 -1
- package/lib/util/thumbnail-util.spec.js +440 -434
- package/lib/util/type-conversion-utils-spec-mockData.js +259 -259
- package/lib/util/type-conversion-utils.d.ts +163 -23
- package/lib/util/type-conversion-utils.js +408 -265
- package/lib/util/type-conversion-utils.spec.d.ts +1 -1
- package/lib/util/type-conversion-utils.spec.js +868 -868
- package/lib/util/type-defaults.d.ts +74 -16
- package/lib/util/type-defaults.js +279 -221
- package/lib/util/type-defaults.spec.d.ts +1 -1
- package/lib/util/type-defaults.spec.js +516 -516
- package/lib/util/type-utils.d.ts +34 -13
- package/lib/util/type-utils.js +137 -114
- package/lib/util/type-utils.spec.d.ts +1 -1
- package/lib/util/type-utils.spec.js +192 -190
- package/package.json +21 -6
- package/scripts/copy-template.js +10 -0
- package/.claude/settings.local.json +0 -8
- package/.github/pull_request_template.md +0 -31
- package/.github/workflows/flexplm-lib.yml +0 -27
- package/.github/workflows/publish-to-npm.yml +0 -124
- package/CHANGELOG.md +0 -32
- package/publish.bat +0 -5
- package/publish.sh +0 -5
- package/src/entity-processor/base-entity-processor.spec.ts +0 -460
- package/src/entity-processor/base-entity-processor.ts +0 -515
- package/src/flexplm-request.ts +0 -28
- package/src/flexplm-utils.spec.ts +0 -27
- package/src/flexplm-utils.ts +0 -29
- package/src/index.ts +0 -22
- package/src/interfaces/interfaces.ts +0 -122
- package/src/interfaces/item-family-changes.ts +0 -67
- package/src/interfaces/publish-change-data.ts +0 -43
- package/src/publish/base-process-publish-assortment-callback.ts +0 -50
- package/src/publish/base-process-publish-assortment.spec.ts +0 -1992
- package/src/publish/base-process-publish-assortment.ts +0 -1134
- package/src/publish/mockData.ts +0 -4561
- package/src/transform/identifier-conversion-spec-mockData.ts +0 -496
- package/src/transform/identifier-conversion.spec.ts +0 -354
- package/src/transform/identifier-conversion.ts +0 -282
- package/src/util/config-defaults.spec.ts +0 -350
- package/src/util/config-defaults.ts +0 -93
- package/src/util/data-converter-spec-mockData.ts +0 -231
- package/src/util/data-converter.spec.ts +0 -1041
- package/src/util/data-converter.ts +0 -762
- package/src/util/error-response-object.spec.ts +0 -116
- package/src/util/error-response-object.ts +0 -50
- package/src/util/event-short-message-status.ts +0 -22
- package/src/util/federation.ts +0 -172
- package/src/util/flexplm-connect.spec.ts +0 -132
- package/src/util/flexplm-connect.ts +0 -208
- package/src/util/logger-config.ts +0 -20
- package/src/util/map-util-spec-mockData.ts +0 -231
- package/src/util/map-utils.spec.ts +0 -103
- package/src/util/map-utils.ts +0 -41
- package/src/util/mockData.ts +0 -101
- package/src/util/thumbnail-util.spec.ts +0 -508
- package/src/util/thumbnail-util.ts +0 -272
- package/src/util/type-conversion-utils-spec-mockData.ts +0 -271
- package/src/util/type-conversion-utils.spec.ts +0 -968
- package/src/util/type-conversion-utils.ts +0 -460
- package/src/util/type-defaults.spec.ts +0 -669
- package/src/util/type-defaults.ts +0 -281
- package/src/util/type-utils.spec.ts +0 -227
- package/src/util/type-utils.ts +0 -144
- package/tsconfig.json +0 -29
- package/tslint.json +0 -57
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
export interface FCConfig {
|
|
2
|
-
apiKey?: string;
|
|
3
|
-
orgSlug?: string;
|
|
4
|
-
action?: string;
|
|
5
|
-
configFile? :string;
|
|
6
|
-
eventObjectClassParam?: string;
|
|
7
|
-
eventFlexTypePathParam?: string;
|
|
8
|
-
flexplmConnect?: any;
|
|
9
|
-
taskId?: string;
|
|
10
|
-
apiHost: string;
|
|
11
|
-
userName(): string;
|
|
12
|
-
password(): string;
|
|
13
|
-
plmEnviornment?: string;
|
|
14
|
-
urlContext: string;
|
|
15
|
-
vibeEventEndpoint: string;
|
|
16
|
-
csrfEndpoint: string;
|
|
17
|
-
itemPreDevelopmentLifecycleStages: string[];
|
|
18
|
-
identifierAtts?: {
|
|
19
|
-
[key:string]: string[]
|
|
20
|
-
};
|
|
21
|
-
propertyMapping?: object;
|
|
22
|
-
[key: string]: any;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
export interface ProductFederation {
|
|
26
|
-
entityReference: string;
|
|
27
|
-
objectClass: 'LCSProduct';
|
|
28
|
-
federatedId?: string;
|
|
29
|
-
flexPLMTypePath?: string;
|
|
30
|
-
vibeIQIdentifier?: string
|
|
31
|
-
}
|
|
32
|
-
export interface ProductData extends ProductFederation {
|
|
33
|
-
data: object;
|
|
34
|
-
productSeason: {
|
|
35
|
-
data: object;
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
export interface SeasonFederation {
|
|
40
|
-
entityReference: string;
|
|
41
|
-
objectClass: 'LCSSeason';
|
|
42
|
-
flexPLMSeasonName?: string;
|
|
43
|
-
federationId?: string;
|
|
44
|
-
flexPLMTypePath?: string;
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
export interface SeasonGroupFederation {
|
|
48
|
-
entityReference: string;
|
|
49
|
-
objectClass: 'SeasonGroup';
|
|
50
|
-
seasonGroupName?: string;
|
|
51
|
-
federationId?: string;
|
|
52
|
-
flexPLMTypePath?: string;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
export interface SkuFederation {
|
|
56
|
-
entityReference: string;
|
|
57
|
-
objectClass: 'LCSSKU';
|
|
58
|
-
LCSProduct?: ProductFederation;
|
|
59
|
-
federatedId?: string;
|
|
60
|
-
flexPLMTypePath?: string;
|
|
61
|
-
vibeIQIdentifier?: string;
|
|
62
|
-
}
|
|
63
|
-
export interface SkuData extends SkuFederation{
|
|
64
|
-
data: object;
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
export interface PayloadType {
|
|
68
|
-
eventType: string;
|
|
69
|
-
objectClass: string;
|
|
70
|
-
}
|
|
71
|
-
export interface AsyncPayloadType extends PayloadType {
|
|
72
|
-
taskId: string;
|
|
73
|
-
}
|
|
74
|
-
export interface AsyncEventsPayloadType extends AsyncPayloadType {
|
|
75
|
-
events?: PayloadType[];
|
|
76
|
-
eventsFileId?: string;
|
|
77
|
-
eventsDownloadLink?: string;
|
|
78
|
-
eventsAdminDownloadLink?: string;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
export interface EntityPayloadType extends PayloadType {
|
|
82
|
-
entityReference: string;
|
|
83
|
-
federatedId?: string;
|
|
84
|
-
flexPLMTypePath?: string;
|
|
85
|
-
data: object;
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
export interface ItemPayloadType extends EntityPayloadType {
|
|
89
|
-
LCSProduct?: ProductFederation;
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
/////////////////////////////////////////////////////////////////////////////
|
|
93
|
-
///////// Custom seasonalPayload: start
|
|
94
|
-
/////////////////////////////////////////////////////////////////////////////
|
|
95
|
-
export interface SeasonalPayload extends EntityPayloadType {
|
|
96
|
-
eventType: 'UPSERT_ON_SEASON' | 'UPDATE_ON_SEASON' | 'REMOVE_FROM_SEASON';
|
|
97
|
-
objectClass: 'LCSProductSeasonLink' | 'LCSSKUSeasonLink';
|
|
98
|
-
LCSSeason : SeasonFederation;
|
|
99
|
-
LCSProduct? : ProductFederation;
|
|
100
|
-
LCSSKU? : SkuFederation;
|
|
101
|
-
carriedFromSeason? : object;
|
|
102
|
-
}
|
|
103
|
-
/////////////////////////////////////////////////////////////////////////////
|
|
104
|
-
///////// Custom seasonalPayload: start
|
|
105
|
-
/////////////////////////////////////////////////////////////////////////////
|
|
106
|
-
|
|
107
|
-
export interface ExportPayloadType extends AsyncPayloadType {
|
|
108
|
-
flexPLMTypePath: string;
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
export interface FederationRecord {
|
|
112
|
-
reference: string;
|
|
113
|
-
mappedReference: string
|
|
114
|
-
appIdentifier: string;
|
|
115
|
-
federationSchema: string
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
export interface FlexPLMResponseData {
|
|
119
|
-
status: number;
|
|
120
|
-
data?: object;
|
|
121
|
-
error?: string;
|
|
122
|
-
}
|
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
export class ItemFamilyChanges {
|
|
2
|
-
private _itemFamilyId:string;
|
|
3
|
-
public get itemFamilyId(){ return this._itemFamilyId; }
|
|
4
|
-
private _sinceDate:Date;
|
|
5
|
-
public get sinceDate(){ return this._sinceDate; }
|
|
6
|
-
|
|
7
|
-
familyAdd = false;
|
|
8
|
-
familyDelete = false;
|
|
9
|
-
familyUpdate = false;
|
|
10
|
-
familyItemRemoved = false;
|
|
11
|
-
itemFamilyObject = undefined;
|
|
12
|
-
|
|
13
|
-
colorAdds: string[] = [];
|
|
14
|
-
colorDeletes: string[] = [];
|
|
15
|
-
colorUpdates: string[] = [];
|
|
16
|
-
colorUnchanged: string[] = [];
|
|
17
|
-
|
|
18
|
-
assortmentItemFullChangeMap = new Map<string, any>();
|
|
19
|
-
assortmentItemDeleteMap = new Map<string, any>();
|
|
20
|
-
itemToFederatedIdMapping = new Map<string, string>();
|
|
21
|
-
constructor(itemFamilyId: string, sinceDate: Date){
|
|
22
|
-
this._itemFamilyId = itemFamilyId;
|
|
23
|
-
this._sinceDate = sinceDate;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
public toString(): string{
|
|
27
|
-
let s = 'ItemFamilyChanges\n'
|
|
28
|
-
+ ' itemFamilyId: ' + this._itemFamilyId + '\n'
|
|
29
|
-
+ ' sinceDate: ' + this._sinceDate + '\n'
|
|
30
|
-
+ ' familyAdd: ' + this.familyAdd + '\n'
|
|
31
|
-
+ ' familyDelete: ' + this.familyDelete + '\n'
|
|
32
|
-
+ ' familyUpdate: ' + this.familyUpdate + '\n'
|
|
33
|
-
+ ' familyItemRemoved: ' + this.familyItemRemoved + '\n'
|
|
34
|
-
;
|
|
35
|
-
|
|
36
|
-
s += ' colorAdds: ['+ this.colorAdds + ']\n';
|
|
37
|
-
|
|
38
|
-
s += ' colorDeletes: ['+ this.colorDeletes + ']\n';
|
|
39
|
-
|
|
40
|
-
s += ' colorUpdates: ['+ this.colorUpdates + ']\n';
|
|
41
|
-
|
|
42
|
-
s += ' colorUnchanged: ['+ this.colorUnchanged + ']\n';
|
|
43
|
-
|
|
44
|
-
s += 'assortmentItemFullChangeMap:\n';
|
|
45
|
-
s += 'size: ' + this.assortmentItemFullChangeMap.size +'\n[';
|
|
46
|
-
for(const key of this.assortmentItemFullChangeMap.keys()){
|
|
47
|
-
s += key + ', ';
|
|
48
|
-
}
|
|
49
|
-
s += ']\n';
|
|
50
|
-
|
|
51
|
-
s += 'assortmentItemDeleteMap:\n';
|
|
52
|
-
s += 'size: ' + this.assortmentItemDeleteMap.size +'\n[';
|
|
53
|
-
for(const key of this.assortmentItemDeleteMap.keys()){
|
|
54
|
-
s += key + ', ';
|
|
55
|
-
}
|
|
56
|
-
s += ']\n';
|
|
57
|
-
|
|
58
|
-
s += 'itemToFederatedIdMapping:\n';
|
|
59
|
-
s += 'size: ' + this.itemToFederatedIdMapping.size +'\n[';
|
|
60
|
-
for(const key of this.itemToFederatedIdMapping.keys()){
|
|
61
|
-
s += key + ', ';
|
|
62
|
-
}
|
|
63
|
-
s += ']\n';
|
|
64
|
-
|
|
65
|
-
return s;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
import { SeasonFederation } from './interfaces';
|
|
2
|
-
import { ItemFamilyChanges } from './item-family-changes';
|
|
3
|
-
|
|
4
|
-
export class PublishChangeData {
|
|
5
|
-
|
|
6
|
-
private _assortmentId: string;
|
|
7
|
-
public get assortmentId(){ return this._assortmentId; }
|
|
8
|
-
private _seasonFed: SeasonFederation;
|
|
9
|
-
public get seasonFed() { return Object.assign({}, this._seasonFed); }
|
|
10
|
-
private _assortmentPublishChangeId: string;
|
|
11
|
-
public get assortmentPublishChangeId() { return this._assortmentPublishChangeId; }
|
|
12
|
-
private _sinceDate: Date;
|
|
13
|
-
public get sinceDate(){ return this._sinceDate; }
|
|
14
|
-
private _publisher: object;
|
|
15
|
-
public get publisher(){ return this._publisher; }
|
|
16
|
-
|
|
17
|
-
itemToFederatedIdMapping: Map<string, string>;
|
|
18
|
-
releasedForDevelopmentItemIds: string[] = [];
|
|
19
|
-
itemFamilyChanges = new Map<string, ItemFamilyChanges>();
|
|
20
|
-
constructor(_assortmentId: string, _seasonFed: SeasonFederation, _assortmentPublishChangeId: string, _sinceDate: Date, _publisher = {}) {
|
|
21
|
-
this._assortmentId = _assortmentId;
|
|
22
|
-
this._seasonFed = _seasonFed;
|
|
23
|
-
this._assortmentPublishChangeId = _assortmentPublishChangeId;
|
|
24
|
-
this._sinceDate = _sinceDate;
|
|
25
|
-
this._publisher = _publisher;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
toString(){
|
|
29
|
-
let s = 'PublishChangeData\n'
|
|
30
|
-
+ 'assortmentId: ' + this._assortmentId + '\n'
|
|
31
|
-
+ 'seasonFed: ' + JSON.stringify(this._seasonFed) + '\n'
|
|
32
|
-
+ 'assortmentPublishChangeId: ' + this._assortmentPublishChangeId + '\n'
|
|
33
|
-
;
|
|
34
|
-
|
|
35
|
-
s += ' itemToFederatedIdMapping: ' + JSON.stringify(Object.fromEntries(this.itemToFederatedIdMapping)) + '\n';
|
|
36
|
-
s += 'itemFamilyChanges:\n';
|
|
37
|
-
for(const [key, value] of this.itemFamilyChanges){
|
|
38
|
-
s += ' ' + key + ' => ' + value.toString();
|
|
39
|
-
}
|
|
40
|
-
return s;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
}
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
import { LogLevel, Notification } from "@contrail/sdk";
|
|
2
|
-
import { FCConfig } from "../interfaces/interfaces";
|
|
3
|
-
|
|
4
|
-
export class BaseProcessPublishAssortmentCallback {
|
|
5
|
-
private config: FCConfig;
|
|
6
|
-
|
|
7
|
-
constructor(_config: FCConfig) {
|
|
8
|
-
this.config = _config;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
public async process(event) {
|
|
12
|
-
console.log("ProcessPublishAssortmentCallback-process()");
|
|
13
|
-
|
|
14
|
-
console.log(
|
|
15
|
-
"ProcessPublishAssortmentCallback-event: " + JSON.stringify(event)
|
|
16
|
-
);
|
|
17
|
-
console.log(
|
|
18
|
-
"ProcessPublishAssortmentCallback-config: " + JSON.stringify(this.config)
|
|
19
|
-
);
|
|
20
|
-
|
|
21
|
-
const statusCounts = this.config["statusCounts"];
|
|
22
|
-
console.log("statusCounts: " + JSON.stringify(statusCounts));
|
|
23
|
-
|
|
24
|
-
const statMessage =(statusCounts && 'undefined' !== statusCounts)
|
|
25
|
-
?await this.checkFailuresAndSendNotification(event)
|
|
26
|
-
:'no statusCount';
|
|
27
|
-
|
|
28
|
-
return {
|
|
29
|
-
message: "Done ProcessPublishAssortmentCallback-process(): " + statMessage,
|
|
30
|
-
};
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
private async checkFailuresAndSendNotification(event): Promise<string> {
|
|
34
|
-
const statusCounts = JSON.parse(this.config["statusCounts"]);
|
|
35
|
-
|
|
36
|
-
if (statusCounts["INVALID"] > 0 || statusCounts["FAILURE"] > 0) {
|
|
37
|
-
await new Notification().Dispatch({
|
|
38
|
-
message: `There were errors when publishing the season data. Please review the event and config information from context.`,
|
|
39
|
-
level: LogLevel.WARN,
|
|
40
|
-
context: {
|
|
41
|
-
event,
|
|
42
|
-
config: this.config,
|
|
43
|
-
},
|
|
44
|
-
});
|
|
45
|
-
return 'sent notification';
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
return 'no notification needed';
|
|
49
|
-
}
|
|
50
|
-
}
|