@things-factory/integration-fulfillment 4.3.671 → 4.3.673
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/dist-server/controllers/fulfillment-api/decorators.js +32 -0
- package/dist-server/controllers/fulfillment-api/decorators.js.map +1 -0
- package/dist-server/controllers/fulfillment-api/index.js +121 -0
- package/dist-server/controllers/fulfillment-api/index.js.map +1 -0
- package/dist-server/controllers/fulfillment-api/types.js +1 -0
- package/dist-server/controllers/fulfillment-api/types.js.map +1 -0
- package/dist-server/controllers/index.js +18 -0
- package/dist-server/controllers/index.js.map +1 -0
- package/dist-server/controllers/operato/cancel-release-order.js +22 -0
- package/dist-server/controllers/operato/cancel-release-order.js.map +1 -0
- package/dist-server/controllers/operato/create-inbound-order.js +36 -0
- package/dist-server/controllers/operato/create-inbound-order.js.map +1 -0
- package/dist-server/controllers/operato/create-outbound-order.js +24 -0
- package/dist-server/controllers/operato/create-outbound-order.js.map +1 -0
- package/dist-server/controllers/operato/create-sales-invoice.js +24 -0
- package/dist-server/controllers/operato/create-sales-invoice.js.map +1 -0
- package/dist-server/controllers/operato/echo.js +19 -0
- package/dist-server/controllers/operato/echo.js.map +1 -0
- package/dist-server/controllers/operato/get-center-products.js +23 -0
- package/dist-server/controllers/operato/get-center-products.js.map +1 -0
- package/dist-server/controllers/operato/get-inbound-order.js +27 -0
- package/dist-server/controllers/operato/get-inbound-order.js.map +1 -0
- package/dist-server/controllers/operato/get-inventory-product-group-open-api.js +22 -0
- package/dist-server/controllers/operato/get-inventory-product-group-open-api.js.map +1 -0
- package/dist-server/controllers/operato/get-inventory-product-group.js +22 -0
- package/dist-server/controllers/operato/get-inventory-product-group.js.map +1 -0
- package/dist-server/controllers/operato/get-outbound-order.js +27 -0
- package/dist-server/controllers/operato/get-outbound-order.js.map +1 -0
- package/dist-server/controllers/operato/get-outbound-orders.js +25 -0
- package/dist-server/controllers/operato/get-outbound-orders.js.map +1 -0
- package/dist-server/controllers/operato/index.js +46 -0
- package/dist-server/controllers/operato/index.js.map +1 -0
- package/dist-server/controllers/operato/operato.js +95 -0
- package/dist-server/controllers/operato/operato.js.map +1 -0
- package/dist-server/controllers/operato/platform-action.js +49 -0
- package/dist-server/controllers/operato/platform-action.js.map +1 -0
- package/dist-server/controllers/operato/update-release-order-details.js +21 -0
- package/dist-server/controllers/operato/update-release-order-details.js.map +1 -0
- package/dist-server/entities/fulfillment-center.js +106 -0
- package/dist-server/entities/fulfillment-center.js.map +1 -0
- package/dist-server/entities/index.js +7 -0
- package/dist-server/entities/index.js.map +1 -0
- package/dist-server/graphql/index.js +33 -0
- package/dist-server/graphql/index.js.map +1 -0
- package/dist-server/graphql/resolvers/fulfillment-center/create-fulfillment-center.js +11 -0
- package/dist-server/graphql/resolvers/fulfillment-center/create-fulfillment-center.js.map +1 -0
- package/dist-server/graphql/resolvers/fulfillment-center/delete-fulfillment-center.js +12 -0
- package/dist-server/graphql/resolvers/fulfillment-center/delete-fulfillment-center.js.map +1 -0
- package/dist-server/graphql/resolvers/fulfillment-center/delete-fulfillment-centers.js +15 -0
- package/dist-server/graphql/resolvers/fulfillment-center/delete-fulfillment-centers.js.map +1 -0
- package/dist-server/graphql/resolvers/fulfillment-center/fulfillment-center.js +15 -0
- package/dist-server/graphql/resolvers/fulfillment-center/fulfillment-center.js.map +1 -0
- package/dist-server/graphql/resolvers/fulfillment-center/fulfillment-centers.js +19 -0
- package/dist-server/graphql/resolvers/fulfillment-center/fulfillment-centers.js.map +1 -0
- package/dist-server/graphql/resolvers/fulfillment-center/having-fulfillment-center.js +19 -0
- package/dist-server/graphql/resolvers/fulfillment-center/having-fulfillment-center.js.map +1 -0
- package/dist-server/graphql/resolvers/fulfillment-center/index.js +38 -0
- package/dist-server/graphql/resolvers/fulfillment-center/index.js.map +1 -0
- package/dist-server/graphql/resolvers/fulfillment-center/operato/deactivate-operato-center.js +48 -0
- package/dist-server/graphql/resolvers/fulfillment-center/operato/deactivate-operato-center.js.map +1 -0
- package/dist-server/graphql/resolvers/fulfillment-center/operato/generate-operato-access-token.js +53 -0
- package/dist-server/graphql/resolvers/fulfillment-center/operato/generate-operato-access-token.js.map +1 -0
- package/dist-server/graphql/resolvers/fulfillment-center/operato/get-operato-auth-url.js +14 -0
- package/dist-server/graphql/resolvers/fulfillment-center/operato/get-operato-auth-url.js.map +1 -0
- package/dist-server/graphql/resolvers/fulfillment-center/operato/index.js +10 -0
- package/dist-server/graphql/resolvers/fulfillment-center/operato/index.js.map +1 -0
- package/dist-server/graphql/resolvers/fulfillment-center/operato/refresh-operato-access-token.js +48 -0
- package/dist-server/graphql/resolvers/fulfillment-center/operato/refresh-operato-access-token.js.map +1 -0
- package/dist-server/graphql/resolvers/fulfillment-center/update-fulfillment-center.js +15 -0
- package/dist-server/graphql/resolvers/fulfillment-center/update-fulfillment-center.js.map +1 -0
- package/dist-server/graphql/resolvers/fulfillment-center/update-multiple-fulfillment-center.js +30 -0
- package/dist-server/graphql/resolvers/fulfillment-center/update-multiple-fulfillment-center.js.map +1 -0
- package/dist-server/graphql/resolvers/index.js +30 -0
- package/dist-server/graphql/resolvers/index.js.map +1 -0
- package/dist-server/graphql/types/fulfillment-center/fulfillment-center-list.js +14 -0
- package/dist-server/graphql/types/fulfillment-center/fulfillment-center-list.js.map +1 -0
- package/dist-server/graphql/types/fulfillment-center/fulfillment-center-patch.js +19 -0
- package/dist-server/graphql/types/fulfillment-center/fulfillment-center-patch.js.map +1 -0
- package/dist-server/graphql/types/fulfillment-center/fulfillment-center.js +25 -0
- package/dist-server/graphql/types/fulfillment-center/fulfillment-center.js.map +1 -0
- package/dist-server/graphql/types/fulfillment-center/index.js +53 -0
- package/dist-server/graphql/types/fulfillment-center/index.js.map +1 -0
- package/dist-server/graphql/types/fulfillment-center/new-fulfillment-center.js +17 -0
- package/dist-server/graphql/types/fulfillment-center/new-fulfillment-center.js.map +1 -0
- package/dist-server/graphql/types/index.js +32 -0
- package/dist-server/graphql/types/index.js.map +1 -0
- package/dist-server/index.js +22 -0
- package/dist-server/index.js.map +1 -0
- package/dist-server/migrations/index.js +12 -0
- package/dist-server/migrations/index.js.map +1 -0
- package/dist-server/routes.js +19 -0
- package/dist-server/routes.js.map +1 -0
- package/package.json +13 -13
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.Operato = void 0;
|
|
7
|
+
const debug_1 = __importDefault(require("debug"));
|
|
8
|
+
const node_fetch_1 = __importDefault(require("node-fetch"));
|
|
9
|
+
const env_1 = require("@things-factory/env");
|
|
10
|
+
const utils_1 = require("@things-factory/utils");
|
|
11
|
+
const typeorm_1 = require("typeorm");
|
|
12
|
+
const entities_1 = require("../../entities");
|
|
13
|
+
const { protocol = 'https', host, callback } = env_1.config.get('fulfillmentIntegrationOperato', {});
|
|
14
|
+
const debug = (0, debug_1.default)('things-factory:integration-fulfillment:operato');
|
|
15
|
+
class Operato {
|
|
16
|
+
constructor(config) {
|
|
17
|
+
this.config = Object.assign({}, config);
|
|
18
|
+
}
|
|
19
|
+
buildAuthURL(state) {
|
|
20
|
+
// TODO make scopes properly
|
|
21
|
+
const { appKey, redirectUrl } = this.config;
|
|
22
|
+
// return `http://${center}.${host}/oauth/authorize?response_type=code&client_id=${appKey}&scope=${scopes}&redirect_uri=${redirectUrl}&state=${state}`
|
|
23
|
+
return `${protocol}://${host}/oauth/authorize?response_type=code&client_id=${appKey}&scope=warehouse&redirect_uri=${redirectUrl}&state=${state}`;
|
|
24
|
+
}
|
|
25
|
+
async get(center, path, data) {
|
|
26
|
+
const qs = Object.entries(data)
|
|
27
|
+
.map(([k, v]) => `${k}=${encodeURIComponent(String(v))}`)
|
|
28
|
+
.join('&');
|
|
29
|
+
const endpoint = `${protocol}://${host}/api${path}${qs ? '?' + qs : ''}`;
|
|
30
|
+
debug('endpoint', endpoint);
|
|
31
|
+
const response = await (0, node_fetch_1.default)(endpoint, {
|
|
32
|
+
headers: {
|
|
33
|
+
'Content-Type': 'application/json',
|
|
34
|
+
'x-access-token': center.accessToken,
|
|
35
|
+
'x-things-factory-domain': center.centerId
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
const result = await response.json();
|
|
39
|
+
debug('response result', result);
|
|
40
|
+
return result;
|
|
41
|
+
}
|
|
42
|
+
async post(center, path, data = {}) {
|
|
43
|
+
debug('data', data);
|
|
44
|
+
const jsondata = JSON.stringify(data);
|
|
45
|
+
const endpoint = `${protocol}://${host}/api${path}`;
|
|
46
|
+
const response = await (0, node_fetch_1.default)(endpoint, {
|
|
47
|
+
method: 'post',
|
|
48
|
+
headers: {
|
|
49
|
+
'Content-Type': 'application/json',
|
|
50
|
+
'x-access-token': center.accessToken,
|
|
51
|
+
'x-things-factory-domain': center.centerId
|
|
52
|
+
},
|
|
53
|
+
body: jsondata
|
|
54
|
+
});
|
|
55
|
+
if (response.ok) {
|
|
56
|
+
return await response.json();
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
const text = await response.text();
|
|
60
|
+
debug('response result', text);
|
|
61
|
+
throw response;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
static async refreshAccessToken(fulfillmentCenter) {
|
|
65
|
+
const requestBody = {
|
|
66
|
+
refreshToken: fulfillmentCenter.refreshToken
|
|
67
|
+
};
|
|
68
|
+
const refreshResponse = await (0, node_fetch_1.default)(`${protocol}://${host}/oauth/refresh-token`, {
|
|
69
|
+
method: 'post',
|
|
70
|
+
headers: {
|
|
71
|
+
'Content-Type': 'application/json'
|
|
72
|
+
},
|
|
73
|
+
body: JSON.stringify(requestBody)
|
|
74
|
+
});
|
|
75
|
+
if (!refreshResponse.ok) {
|
|
76
|
+
throw new Error(`get operato information failed: ${await refreshResponse.text()}`);
|
|
77
|
+
}
|
|
78
|
+
const body = await refreshResponse.json();
|
|
79
|
+
const { accessToken /* token used to call the API */, id_token /* token containing user identity details (only returned if OpenID Connect scopes are requested) */, expires_in /* amount of seconds until the access token expires */, token_type: tokenType /* must be Bearer */, refreshToken
|
|
80
|
+
/* token used to refresh the access token once it has expired (only returned if the offline_access scope is requested).
|
|
81
|
+
*/
|
|
82
|
+
} = body;
|
|
83
|
+
const { exp } = (0, utils_1.parseJwt)(accessToken);
|
|
84
|
+
var patch = {
|
|
85
|
+
accessToken,
|
|
86
|
+
refreshToken,
|
|
87
|
+
tokenType,
|
|
88
|
+
expiresIn: new Date(exp * 1000)
|
|
89
|
+
};
|
|
90
|
+
const repository = (0, typeorm_1.getRepository)(entities_1.FulfillmentCenter);
|
|
91
|
+
return await repository.save(Object.assign(Object.assign({}, fulfillmentCenter), patch));
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
exports.Operato = Operato;
|
|
95
|
+
//# sourceMappingURL=operato.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"operato.js","sourceRoot":"","sources":["../../../server/controllers/operato/operato.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.action = exports._action = void 0;
|
|
4
|
+
const operato_1 = require("./operato");
|
|
5
|
+
const env_1 = require("@things-factory/env");
|
|
6
|
+
const operatoConfig = env_1.config.get('fulfillmentIntegrationOperato', {});
|
|
7
|
+
const { appKey, appSecret } = operatoConfig;
|
|
8
|
+
function substitute(path, obj) {
|
|
9
|
+
var props = [];
|
|
10
|
+
var re = /{([^}]+)}/g;
|
|
11
|
+
var text;
|
|
12
|
+
while ((text = re.exec(path))) {
|
|
13
|
+
props.push(text[1]);
|
|
14
|
+
}
|
|
15
|
+
var result = path;
|
|
16
|
+
props.forEach(prop => {
|
|
17
|
+
let value = obj[prop.trim()];
|
|
18
|
+
result = result.replace(`{${prop}}`, value === undefined ? '' : value);
|
|
19
|
+
});
|
|
20
|
+
return result;
|
|
21
|
+
}
|
|
22
|
+
const _action = async ({ center, method = 'get', path, request }) => {
|
|
23
|
+
const client = new operato_1.Operato({
|
|
24
|
+
center: center.centerId,
|
|
25
|
+
appKey,
|
|
26
|
+
appSecret,
|
|
27
|
+
accessToken: center.accessToken
|
|
28
|
+
});
|
|
29
|
+
const { resource = {}, payload = {} } = request;
|
|
30
|
+
path = substitute(path, resource);
|
|
31
|
+
return await client[method](center, path, payload);
|
|
32
|
+
};
|
|
33
|
+
exports._action = _action;
|
|
34
|
+
const action = async ({ center, method = 'get', path, request }) => {
|
|
35
|
+
try {
|
|
36
|
+
return await (0, exports._action)({ center, method, path, request });
|
|
37
|
+
}
|
|
38
|
+
catch (ex) {
|
|
39
|
+
if (ex.status === 401) {
|
|
40
|
+
var refreshed = await operato_1.Operato.refreshAccessToken(center);
|
|
41
|
+
return await (0, exports._action)({ center: refreshed, method, path, request });
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
throw ex;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
exports.action = action;
|
|
49
|
+
//# sourceMappingURL=platform-action.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-action.js","sourceRoot":"","sources":["../../../server/controllers/operato/platform-action.ts"],"names":[],"mappings":";;;AAAA,uCAAmC;AAEnC,6CAA4C;AAC5C,MAAM,aAAa,GAAG,YAAM,CAAC,GAAG,CAAC,+BAA+B,EAAE,EAAE,CAAC,CAAA;AACrE,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,aAAa,CAAA;AAE3C,SAAS,UAAU,CAAC,IAAI,EAAE,GAAG;IAC3B,IAAI,KAAK,GAAG,EAAE,CAAA;IACd,IAAI,EAAE,GAAG,YAAY,CAAA;IACrB,IAAI,IAAI,CAAA;IAER,OAAO,CAAC,IAAI,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,EAAE;QAC7B,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAA;KACpB;IAED,IAAI,MAAM,GAAG,IAAI,CAAA;IACjB,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;QACnB,IAAI,KAAK,GAAG,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAA;QAC5B,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,IAAI,GAAG,EAAE,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAA;IACxE,CAAC,CAAC,CAAA;IAEF,OAAO,MAAM,CAAA;AACf,CAAC;AAEM,MAAM,OAAO,GAAG,KAAK,EAAE,EAAE,MAAM,EAAE,MAAM,GAAG,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE;IACzE,MAAM,MAAM,GAAG,IAAI,iBAAO,CAAC;QACzB,MAAM,EAAE,MAAM,CAAC,QAAQ;QACvB,MAAM;QACN,SAAS;QACT,WAAW,EAAE,MAAM,CAAC,WAAW;KAChC,CAAC,CAAA;IAEF,MAAM,EAAE,QAAQ,GAAG,EAAE,EAAE,OAAO,GAAG,EAAE,EAAE,GAAG,OAAO,CAAA;IAE/C,IAAI,GAAG,UAAU,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAA;IAEjC,OAAO,MAAM,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,IAAI,EAAE,OAAO,CAAC,CAAA;AACpD,CAAC,CAAA;AAbY,QAAA,OAAO,WAanB;AAEM,MAAM,MAAM,GAAG,KAAK,EAAE,EAAE,MAAM,EAAE,MAAM,GAAG,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE;IACxE,IAAI;QACF,OAAO,MAAM,IAAA,eAAO,EAAC,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAA;KACxD;IAAC,OAAO,EAAE,EAAE;QACX,IAAI,EAAE,CAAC,MAAM,KAAK,GAAG,EAAE;YACrB,IAAI,SAAS,GAAG,MAAM,iBAAO,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAA;YACxD,OAAO,MAAM,IAAA,eAAO,EAAC,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAA;SACnE;aAAM;YACL,MAAM,EAAE,CAAA;SACT;KACF;AACH,CAAC,CAAA;AAXY,QAAA,MAAM,UAWlB"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.updateReleaseGoodDetails = void 0;
|
|
4
|
+
function updateReleaseGoodDetails() {
|
|
5
|
+
return {
|
|
6
|
+
method: 'post',
|
|
7
|
+
path: '/unstable/warehouse/{warehouseId}/update-release-order-details',
|
|
8
|
+
denormalize(req) {
|
|
9
|
+
var { customerBizplaceId, releaseOrder, shippingOrder } = req;
|
|
10
|
+
return {
|
|
11
|
+
payload: { releaseOrder, shippingOrder },
|
|
12
|
+
resource: { warehouseId: customerBizplaceId }
|
|
13
|
+
};
|
|
14
|
+
},
|
|
15
|
+
normalize(res) {
|
|
16
|
+
return res;
|
|
17
|
+
}
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
exports.updateReleaseGoodDetails = updateReleaseGoodDetails;
|
|
21
|
+
//# sourceMappingURL=update-release-order-details.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update-release-order-details.js","sourceRoot":"","sources":["../../../server/controllers/operato/update-release-order-details.ts"],"names":[],"mappings":";;;AAAA,SAAgB,wBAAwB;IACtC,OAAO;QACL,MAAM,EAAE,MAAM;QACd,IAAI,EAAE,gEAAgE;QACtE,WAAW,CAAC,GAAG;YACb,IAAI,EAAE,kBAAkB,EAAE,YAAY,EAAE,aAAa,EAAE,GAAG,GAAG,CAAA;YAE7D,OAAO;gBACL,OAAO,EAAE,EAAE,YAAY,EAAE,aAAa,EAAE;gBACxC,QAAQ,EAAE,EAAE,WAAW,EAAE,kBAAkB,EAAE;aAC9C,CAAA;QACH,CAAC;QACD,SAAS,CAAC,GAAG;YACX,OAAO,GAAG,CAAA;QACZ,CAAC;KACF,CAAA;AACH,CAAC;AAhBD,4DAgBC"}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var _a, _b, _c;
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.FulfillmentCenter = void 0;
|
|
14
|
+
const auth_base_1 = require("@things-factory/auth-base");
|
|
15
|
+
const shell_1 = require("@things-factory/shell");
|
|
16
|
+
const typeorm_1 = require("typeorm");
|
|
17
|
+
let FulfillmentCenter = class FulfillmentCenter {
|
|
18
|
+
};
|
|
19
|
+
__decorate([
|
|
20
|
+
(0, typeorm_1.PrimaryGeneratedColumn)('uuid'),
|
|
21
|
+
__metadata("design:type", String)
|
|
22
|
+
], FulfillmentCenter.prototype, "id", void 0);
|
|
23
|
+
__decorate([
|
|
24
|
+
(0, typeorm_1.ManyToOne)(type => shell_1.Domain),
|
|
25
|
+
__metadata("design:type", typeof (_a = typeof shell_1.Domain !== "undefined" && shell_1.Domain) === "function" ? _a : Object)
|
|
26
|
+
], FulfillmentCenter.prototype, "domain", void 0);
|
|
27
|
+
__decorate([
|
|
28
|
+
(0, typeorm_1.Column)(),
|
|
29
|
+
__metadata("design:type", String)
|
|
30
|
+
], FulfillmentCenter.prototype, "platform", void 0);
|
|
31
|
+
__decorate([
|
|
32
|
+
(0, typeorm_1.Column)({
|
|
33
|
+
nullable: true
|
|
34
|
+
}),
|
|
35
|
+
__metadata("design:type", String)
|
|
36
|
+
], FulfillmentCenter.prototype, "centerId", void 0);
|
|
37
|
+
__decorate([
|
|
38
|
+
(0, typeorm_1.Column)(),
|
|
39
|
+
__metadata("design:type", String)
|
|
40
|
+
], FulfillmentCenter.prototype, "countryCode", void 0);
|
|
41
|
+
__decorate([
|
|
42
|
+
(0, typeorm_1.Column)({
|
|
43
|
+
nullable: true
|
|
44
|
+
}),
|
|
45
|
+
__metadata("design:type", String)
|
|
46
|
+
], FulfillmentCenter.prototype, "status", void 0);
|
|
47
|
+
__decorate([
|
|
48
|
+
(0, typeorm_1.Column)(),
|
|
49
|
+
__metadata("design:type", String)
|
|
50
|
+
], FulfillmentCenter.prototype, "name", void 0);
|
|
51
|
+
__decorate([
|
|
52
|
+
(0, typeorm_1.Column)({
|
|
53
|
+
nullable: true
|
|
54
|
+
}),
|
|
55
|
+
__metadata("design:type", String)
|
|
56
|
+
], FulfillmentCenter.prototype, "accessInfo", void 0);
|
|
57
|
+
__decorate([
|
|
58
|
+
(0, typeorm_1.Column)({
|
|
59
|
+
nullable: true
|
|
60
|
+
}),
|
|
61
|
+
__metadata("design:type", String)
|
|
62
|
+
], FulfillmentCenter.prototype, "accessToken", void 0);
|
|
63
|
+
__decorate([
|
|
64
|
+
(0, typeorm_1.Column)({
|
|
65
|
+
nullable: true
|
|
66
|
+
}),
|
|
67
|
+
__metadata("design:type", String)
|
|
68
|
+
], FulfillmentCenter.prototype, "refreshToken", void 0);
|
|
69
|
+
__decorate([
|
|
70
|
+
(0, typeorm_1.Column)({
|
|
71
|
+
nullable: true
|
|
72
|
+
}),
|
|
73
|
+
__metadata("design:type", String)
|
|
74
|
+
], FulfillmentCenter.prototype, "account", void 0);
|
|
75
|
+
__decorate([
|
|
76
|
+
(0, typeorm_1.Column)({
|
|
77
|
+
nullable: true
|
|
78
|
+
}),
|
|
79
|
+
__metadata("design:type", String)
|
|
80
|
+
], FulfillmentCenter.prototype, "description", void 0);
|
|
81
|
+
__decorate([
|
|
82
|
+
(0, typeorm_1.CreateDateColumn)(),
|
|
83
|
+
__metadata("design:type", Date)
|
|
84
|
+
], FulfillmentCenter.prototype, "createdAt", void 0);
|
|
85
|
+
__decorate([
|
|
86
|
+
(0, typeorm_1.UpdateDateColumn)(),
|
|
87
|
+
__metadata("design:type", Date)
|
|
88
|
+
], FulfillmentCenter.prototype, "updatedAt", void 0);
|
|
89
|
+
__decorate([
|
|
90
|
+
(0, typeorm_1.ManyToOne)(type => auth_base_1.User, {
|
|
91
|
+
nullable: true
|
|
92
|
+
}),
|
|
93
|
+
__metadata("design:type", typeof (_b = typeof auth_base_1.User !== "undefined" && auth_base_1.User) === "function" ? _b : Object)
|
|
94
|
+
], FulfillmentCenter.prototype, "creator", void 0);
|
|
95
|
+
__decorate([
|
|
96
|
+
(0, typeorm_1.ManyToOne)(type => auth_base_1.User, {
|
|
97
|
+
nullable: true
|
|
98
|
+
}),
|
|
99
|
+
__metadata("design:type", typeof (_c = typeof auth_base_1.User !== "undefined" && auth_base_1.User) === "function" ? _c : Object)
|
|
100
|
+
], FulfillmentCenter.prototype, "updater", void 0);
|
|
101
|
+
FulfillmentCenter = __decorate([
|
|
102
|
+
(0, typeorm_1.Entity)(),
|
|
103
|
+
(0, typeorm_1.Index)('ix_fulfillment-center_0', (fulfillmentCenter) => [fulfillmentCenter.domain, fulfillmentCenter.name], { unique: true })
|
|
104
|
+
], FulfillmentCenter);
|
|
105
|
+
exports.FulfillmentCenter = FulfillmentCenter;
|
|
106
|
+
//# sourceMappingURL=fulfillment-center.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fulfillment-center.js","sourceRoot":"","sources":["../../server/entities/fulfillment-center.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,yDAAgD;AAChD,iDAA8C;AAC9C,qCAAsH;AAa/G,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;CAkE7B,CAAA;AAjEC;IAAC,IAAA,gCAAsB,EAAC,MAAM,CAAC;;6CACrB;AAEV;IAAC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,CAAC;kDAClB,cAAM,oBAAN,cAAM;iDAAA;AAEd;IAAC,IAAA,gBAAM,GAAE;;mDACO;AAEhB;IAAC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;;mDACc;AAEhB;IAAC,IAAA,gBAAM,GAAE;;sDACU;AAEnB;IAAC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;;iDACY;AAEd;IAAC,IAAA,gBAAM,GAAE;;+CACG;AAEZ;IAAC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;;qDACgB;AAElB;IAAC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;;sDACiB;AAEnB;IAAC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;;uDACkB;AAEpB;IAAC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;;kDACa;AAEf;IAAC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;;sDACiB;AAEnB;IAAC,IAAA,0BAAgB,GAAE;8BACR,IAAI;oDAAA;AAEf;IAAC,IAAA,0BAAgB,GAAE;8BACR,IAAI;oDAAA;AAEf;IAAC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,gBAAI,EAAE;QACvB,QAAQ,EAAE,IAAI;KACf,CAAC;kDACO,gBAAI,oBAAJ,gBAAI;kDAAA;AAEb;IAAC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,gBAAI,EAAE;QACvB,QAAQ,EAAE,IAAI;KACf,CAAC;kDACO,gBAAI,oBAAJ,gBAAI;kDAAA;AAjEF,iBAAiB;IAN7B,IAAA,gBAAM,GAAE;IACR,IAAA,eAAK,EACJ,yBAAyB,EACzB,CAAC,iBAAoC,EAAE,EAAE,CAAC,CAAC,iBAAiB,CAAC,MAAM,EAAE,iBAAiB,CAAC,IAAI,CAAC,EAC5F,EAAE,MAAM,EAAE,IAAI,EAAE,CACjB;GACY,iBAAiB,CAkE7B;AAlEY,8CAAiB"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FulfillmentCenter = exports.entities = void 0;
|
|
4
|
+
const fulfillment_center_1 = require("./fulfillment-center");
|
|
5
|
+
Object.defineProperty(exports, "FulfillmentCenter", { enumerable: true, get: function () { return fulfillment_center_1.FulfillmentCenter; } });
|
|
6
|
+
exports.entities = [fulfillment_center_1.FulfillmentCenter];
|
|
7
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../server/entities/index.ts"],"names":[],"mappings":";;;AAAA,6DAAiF;AAIxE,kGAJA,sCAAiB,OAIA;AAFb,QAAA,QAAQ,GAAG,CAAC,sCAAiB,CAAC,CAAA"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.schema = void 0;
|
|
27
|
+
const typeDefs = __importStar(require("./types"));
|
|
28
|
+
const resolvers = __importStar(require("./resolvers"));
|
|
29
|
+
exports.schema = {
|
|
30
|
+
typeDefs,
|
|
31
|
+
resolvers
|
|
32
|
+
};
|
|
33
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../server/graphql/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,kDAAmC;AACnC,uDAAwC;AAE3B,QAAA,MAAM,GAAG;IACpB,QAAQ;IACR,SAAS;CACV,CAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createFulfillmentCenter = void 0;
|
|
4
|
+
const typeorm_1 = require("typeorm");
|
|
5
|
+
const entities_1 = require("../../../entities");
|
|
6
|
+
exports.createFulfillmentCenter = {
|
|
7
|
+
async createFulfillmentCenter(_, { fulfillmentCenter }, context) {
|
|
8
|
+
return await (0, typeorm_1.getRepository)(entities_1.FulfillmentCenter).save(Object.assign(Object.assign({}, fulfillmentCenter), { domain: context.state.domain, creator: context.state.user, updater: context.state.user }));
|
|
9
|
+
}
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=create-fulfillment-center.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-fulfillment-center.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/fulfillment-center/create-fulfillment-center.ts"],"names":[],"mappings":";;;AAAA,qCAAuC;AACvC,gDAAqD;AAExC,QAAA,uBAAuB,GAAG;IACrC,KAAK,CAAC,uBAAuB,CAAC,CAAM,EAAE,EAAE,iBAAiB,EAAE,EAAE,OAAY;QACvE,OAAO,MAAM,IAAA,uBAAa,EAAC,4BAAiB,CAAC,CAAC,IAAI,iCAC7C,iBAAiB,KACpB,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM,EAC5B,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,EAC3B,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,IAC3B,CAAA;IACJ,CAAC;CACF,CAAA"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.deleteFulfillmentCenter = void 0;
|
|
4
|
+
const typeorm_1 = require("typeorm");
|
|
5
|
+
const entities_1 = require("../../../entities");
|
|
6
|
+
exports.deleteFulfillmentCenter = {
|
|
7
|
+
async deleteFulfillmentCenter(_, { name }, context) {
|
|
8
|
+
await (0, typeorm_1.getRepository)(entities_1.FulfillmentCenter).delete({ domain: context.state.domain, name });
|
|
9
|
+
return true;
|
|
10
|
+
}
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=delete-fulfillment-center.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete-fulfillment-center.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/fulfillment-center/delete-fulfillment-center.ts"],"names":[],"mappings":";;;AAAA,qCAAuC;AACvC,gDAAqD;AAExC,QAAA,uBAAuB,GAAG;IACrC,KAAK,CAAC,uBAAuB,CAAC,CAAM,EAAE,EAAE,IAAI,EAAE,EAAE,OAAY;QAC1D,MAAM,IAAA,uBAAa,EAAC,4BAAiB,CAAC,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAA;QACrF,OAAO,IAAI,CAAA;IACb,CAAC;CACF,CAAA"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.deleteFulfillmentCenters = void 0;
|
|
4
|
+
const typeorm_1 = require("typeorm");
|
|
5
|
+
const entities_1 = require("../../../entities");
|
|
6
|
+
exports.deleteFulfillmentCenters = {
|
|
7
|
+
async deleteFulfillmentCenters(_, { ids }, context) {
|
|
8
|
+
await (0, typeorm_1.getRepository)(entities_1.FulfillmentCenter).delete({
|
|
9
|
+
domain: context.state.domain,
|
|
10
|
+
id: (0, typeorm_1.In)(ids)
|
|
11
|
+
});
|
|
12
|
+
return true;
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=delete-fulfillment-centers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete-fulfillment-centers.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/fulfillment-center/delete-fulfillment-centers.ts"],"names":[],"mappings":";;;AAAA,qCAA2C;AAC3C,gDAAqD;AAExC,QAAA,wBAAwB,GAAG;IACtC,KAAK,CAAC,wBAAwB,CAAC,CAAM,EAAE,EAAE,GAAG,EAAE,EAAE,OAAY;QAC1D,MAAM,IAAA,uBAAa,EAAC,4BAAiB,CAAC,CAAC,MAAM,CAAC;YAC5C,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM;YAC5B,EAAE,EAAE,IAAA,YAAE,EAAC,GAAG,CAAC;SACZ,CAAC,CAAA;QACF,OAAO,IAAI,CAAA;IACb,CAAC;CACF,CAAA"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.fulfillmentCenterResolver = void 0;
|
|
4
|
+
const typeorm_1 = require("typeorm");
|
|
5
|
+
const entities_1 = require("../../../entities");
|
|
6
|
+
exports.fulfillmentCenterResolver = {
|
|
7
|
+
async fulfillmentCenter(_, { id }, context) {
|
|
8
|
+
const repository = (0, typeorm_1.getRepository)(entities_1.FulfillmentCenter);
|
|
9
|
+
return await (0, typeorm_1.getRepository)(entities_1.FulfillmentCenter).findOne({
|
|
10
|
+
where: { domain: context.state.domain, id },
|
|
11
|
+
relations: ['domain', 'creator', 'updater']
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=fulfillment-center.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fulfillment-center.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/fulfillment-center/fulfillment-center.ts"],"names":[],"mappings":";;;AAAA,qCAAuC;AACvC,gDAAqD;AAExC,QAAA,yBAAyB,GAAG;IACvC,KAAK,CAAC,iBAAiB,CAAC,CAAM,EAAE,EAAE,EAAE,EAAE,EAAE,OAAY;QAClD,MAAM,UAAU,GAAG,IAAA,uBAAa,EAAC,4BAAiB,CAAC,CAAA;QAEnD,OAAO,MAAM,IAAA,uBAAa,EAAC,4BAAiB,CAAC,CAAC,OAAO,CAAC;YACpD,KAAK,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,EAAE,EAAE;YAC3C,SAAS,EAAE,CAAC,QAAQ,EAAE,SAAS,EAAE,SAAS,CAAC;SAC5C,CAAC,CAAA;IACJ,CAAC;CACF,CAAA"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.fulfillmentCentersResolver = void 0;
|
|
4
|
+
const shell_1 = require("@things-factory/shell");
|
|
5
|
+
const typeorm_1 = require("typeorm");
|
|
6
|
+
const entities_1 = require("../../../entities");
|
|
7
|
+
exports.fulfillmentCentersResolver = {
|
|
8
|
+
async fulfillmentCenters(_, params, context) {
|
|
9
|
+
const queryBuilder = (0, typeorm_1.getRepository)(entities_1.FulfillmentCenter).createQueryBuilder('FC');
|
|
10
|
+
(0, shell_1.buildQuery)(queryBuilder, params, context);
|
|
11
|
+
const [items, total] = await queryBuilder
|
|
12
|
+
.leftJoinAndSelect('FC.domain', 'DOMAIN')
|
|
13
|
+
.leftJoinAndSelect('FC.creator', 'CREATOR')
|
|
14
|
+
.leftJoinAndSelect('FC.updater', 'UPDATER')
|
|
15
|
+
.getManyAndCount();
|
|
16
|
+
return { items, total };
|
|
17
|
+
}
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=fulfillment-centers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fulfillment-centers.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/fulfillment-center/fulfillment-centers.ts"],"names":[],"mappings":";;;AAAA,iDAA6D;AAC7D,qCAAuC;AACvC,gDAAqD;AAExC,QAAA,0BAA0B,GAAG;IACxC,KAAK,CAAC,kBAAkB,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAY;QAC9D,MAAM,YAAY,GAAG,IAAA,uBAAa,EAAC,4BAAiB,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAA;QAC9E,IAAA,kBAAU,EAAC,YAAY,EAAE,MAAM,EAAE,OAAO,CAAC,CAAA;QACzC,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,MAAM,YAAY;aACtC,iBAAiB,CAAC,WAAW,EAAE,QAAQ,CAAC;aACxC,iBAAiB,CAAC,YAAY,EAAE,SAAS,CAAC;aAC1C,iBAAiB,CAAC,YAAY,EAAE,SAAS,CAAC;aAC1C,eAAe,EAAE,CAAA;QACpB,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAA;IACzB,CAAC;CACF,CAAA"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.havingFulfillmentCenterResolver = void 0;
|
|
4
|
+
const typeorm_1 = require("typeorm");
|
|
5
|
+
const entities_1 = require("../../../entities");
|
|
6
|
+
const debug = require('debug')('things-factory:integration-fulfillment:having-fulfillment-center');
|
|
7
|
+
exports.havingFulfillmentCenterResolver = {
|
|
8
|
+
async havingFulfillmentCenter(_, {}, context) {
|
|
9
|
+
const { user } = context.state;
|
|
10
|
+
const userCompanyDomain = user.domains.filter(domain => domain.extType === 'company');
|
|
11
|
+
const fulfillmentCenters = await (0, typeorm_1.getRepository)(entities_1.FulfillmentCenter).find({
|
|
12
|
+
where: {
|
|
13
|
+
domain: userCompanyDomain[0]
|
|
14
|
+
}
|
|
15
|
+
});
|
|
16
|
+
return fulfillmentCenters;
|
|
17
|
+
}
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=having-fulfillment-center.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"having-fulfillment-center.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/fulfillment-center/having-fulfillment-center.ts"],"names":[],"mappings":";;;AACA,qCAAuC;AACvC,gDAAqD;AAErD,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC,kEAAkE,CAAC,CAAA;AAErF,QAAA,+BAA+B,GAAG;IAC7C,KAAK,CAAC,uBAAuB,CAAC,CAAM,EAAE,EAAE,EAAE,OAAY;QACpD,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAC9B,MAAM,iBAAiB,GAAW,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,KAAK,SAAS,CAAC,CAAA;QAC7F,MAAM,kBAAkB,GAAwB,MAAM,IAAA,uBAAa,EAAC,4BAAiB,CAAC,CAAC,IAAI,CAAC;YAC1F,KAAK,EAAE;gBACL,MAAM,EAAE,iBAAiB,CAAC,CAAC,CAAC;aAC7B;SACF,CAAC,CAAA;QAEF,OAAO,kBAAkB,CAAA;IAC3B,CAAC;CACF,CAAA"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.Mutation = exports.Query = void 0;
|
|
27
|
+
const fulfillment_center_1 = require("./fulfillment-center");
|
|
28
|
+
const fulfillment_centers_1 = require("./fulfillment-centers");
|
|
29
|
+
const having_fulfillment_center_1 = require("./having-fulfillment-center");
|
|
30
|
+
const update_multiple_fulfillment_center_1 = require("./update-multiple-fulfillment-center");
|
|
31
|
+
const update_fulfillment_center_1 = require("./update-fulfillment-center");
|
|
32
|
+
const create_fulfillment_center_1 = require("./create-fulfillment-center");
|
|
33
|
+
const delete_fulfillment_center_1 = require("./delete-fulfillment-center");
|
|
34
|
+
const delete_fulfillment_centers_1 = require("./delete-fulfillment-centers");
|
|
35
|
+
const Operato = __importStar(require("./operato"));
|
|
36
|
+
exports.Query = Object.assign(Object.assign(Object.assign(Object.assign({}, fulfillment_centers_1.fulfillmentCentersResolver), fulfillment_center_1.fulfillmentCenterResolver), having_fulfillment_center_1.havingFulfillmentCenterResolver), Operato.Query);
|
|
37
|
+
exports.Mutation = Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({}, update_fulfillment_center_1.updateFulfillmentCenter), update_multiple_fulfillment_center_1.updateMultipleFulfillmentCenter), create_fulfillment_center_1.createFulfillmentCenter), delete_fulfillment_center_1.deleteFulfillmentCenter), delete_fulfillment_centers_1.deleteFulfillmentCenters), Operato.Mutation);
|
|
38
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/fulfillment-center/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,6DAAgE;AAChE,+DAAkE;AAClE,2EAA6E;AAE7E,6FAAsF;AACtF,2EAAqE;AACrE,2EAAqE;AACrE,2EAAqE;AACrE,6EAAuE;AAEvE,mDAAoC;AAEvB,QAAA,KAAK,+DACb,gDAA0B,GAC1B,8CAAyB,GACzB,2DAA+B,GAC/B,OAAO,CAAC,KAAK,EACjB;AAEY,QAAA,QAAQ,2FAChB,mDAAuB,GACvB,oEAA+B,GAC/B,mDAAuB,GACvB,mDAAuB,GACvB,qDAAwB,GACxB,OAAO,CAAC,QAAQ,EACpB"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.deactivateOperatoCenter = void 0;
|
|
7
|
+
const env_1 = require("@things-factory/env");
|
|
8
|
+
const node_fetch_1 = __importDefault(require("node-fetch"));
|
|
9
|
+
const entities_1 = require("../../../../entities");
|
|
10
|
+
const debug = require('debug')('things-factory:integration-fulfillment:deactivate-operato-center');
|
|
11
|
+
const { protocol = 'https', host } = env_1.config.get('fulfillmentIntegrationOperato', {});
|
|
12
|
+
exports.deactivateOperatoCenter = {
|
|
13
|
+
async deactivateOperatoCenter(_, { name }, context) {
|
|
14
|
+
try {
|
|
15
|
+
const { tx, user } = context.state;
|
|
16
|
+
const repository = tx.getRepository(entities_1.FulfillmentCenter);
|
|
17
|
+
const fulfillmentCenter = await repository.findOne({
|
|
18
|
+
where: { domain: context.state.domain, name }
|
|
19
|
+
});
|
|
20
|
+
const disconnectURL = `${protocol}://${host}/oauth/disconnect`;
|
|
21
|
+
const response = await (0, node_fetch_1.default)(disconnectURL, {
|
|
22
|
+
method: 'post',
|
|
23
|
+
headers: {
|
|
24
|
+
'Content-Type': 'application/json',
|
|
25
|
+
'x-access-token': fulfillmentCenter.accessToken
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
if (!response.ok) {
|
|
29
|
+
debug('error', await response.text());
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
Object.assign(fulfillmentCenter, {
|
|
33
|
+
centerId: '',
|
|
34
|
+
accessToken: '',
|
|
35
|
+
refreshToken: '',
|
|
36
|
+
accessInfo: '',
|
|
37
|
+
countryCode: '',
|
|
38
|
+
status: "active" /* FulfillmentCenterStatus.Active */,
|
|
39
|
+
updater: user
|
|
40
|
+
});
|
|
41
|
+
return await repository.save(fulfillmentCenter);
|
|
42
|
+
}
|
|
43
|
+
catch (e) {
|
|
44
|
+
throw e.message;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
//# sourceMappingURL=deactivate-operato-center.js.map
|
package/dist-server/graphql/resolvers/fulfillment-center/operato/deactivate-operato-center.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deactivate-operato-center.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/fulfillment-center/operato/deactivate-operato-center.ts"],"names":[],"mappings":";;;;;;AACA,6CAA4C;AAC5C,4DAA4C;AAE5C,mDAAiF;AAEjF,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC,kEAAkE,CAAC,CAAA;AAElG,MAAM,EAAE,QAAQ,GAAG,OAAO,EAAE,IAAI,EAAE,GAAG,YAAM,CAAC,GAAG,CAAC,+BAA+B,EAAE,EAAE,CAAC,CAAA;AAEvE,QAAA,uBAAuB,GAAG;IACrC,KAAK,CAAC,uBAAuB,CAAC,CAAM,EAAE,EAAE,IAAI,EAAE,EAAE,OAAY;QAC1D,IAAI;YACF,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,GAAsC,OAAO,CAAC,KAAK,CAAA;YACrE,MAAM,UAAU,GAAG,EAAE,CAAC,aAAa,CAAC,4BAAiB,CAAC,CAAA;YACtD,MAAM,iBAAiB,GAAQ,MAAM,UAAU,CAAC,OAAO,CAAC;gBACtD,KAAK,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,IAAI,EAAE;aAC9C,CAAC,CAAA;YAEF,MAAM,aAAa,GAAW,GAAG,QAAQ,MAAM,IAAI,mBAAmB,CAAA;YACtE,MAAM,QAAQ,GAAa,MAAM,IAAA,oBAAK,EAAC,aAAa,EAAE;gBACpD,MAAM,EAAE,MAAM;gBACd,OAAO,EAAE;oBACP,cAAc,EAAE,kBAAkB;oBAClC,gBAAgB,EAAE,iBAAiB,CAAC,WAAW;iBAChD;aACF,CAAC,CAAA;YAEF,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE;gBAChB,KAAK,CAAC,OAAO,EAAE,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAA;gBACrC,OAAM;aACP;YAED,MAAM,CAAC,MAAM,CAAC,iBAAiB,EAAE;gBAC/B,QAAQ,EAAE,EAAE;gBACZ,WAAW,EAAE,EAAE;gBACf,YAAY,EAAE,EAAE;gBAChB,UAAU,EAAE,EAAE;gBACd,WAAW,EAAE,EAAE;gBACf,MAAM,+CAAgC;gBACtC,OAAO,EAAE,IAAI;aACd,CAAC,CAAA;YAEF,OAAO,MAAM,UAAU,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAA;SAChD;QAAC,OAAO,CAAC,EAAE;YACV,MAAM,CAAC,CAAC,OAAO,CAAA;SAChB;IACH,CAAC;CACF,CAAA"}
|
package/dist-server/graphql/resolvers/fulfillment-center/operato/generate-operato-access-token.js
ADDED
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.generateOperatoAccessToken = void 0;
|
|
7
|
+
const env_1 = require("@things-factory/env");
|
|
8
|
+
const node_fetch_1 = __importDefault(require("node-fetch"));
|
|
9
|
+
const typeorm_1 = require("typeorm");
|
|
10
|
+
const entities_1 = require("../../../../entities");
|
|
11
|
+
const { protocol = 'https', host, appKey, appSecret } = env_1.config.get('fulfillmentIntegrationOperato', {});
|
|
12
|
+
const debug = require('debug')('things-factory:integration-fulfillment:generate-operato-access-token');
|
|
13
|
+
exports.generateOperatoAccessToken = {
|
|
14
|
+
async generateOperatoAccessToken(_, { id, code }, context) {
|
|
15
|
+
const repository = (0, typeorm_1.getRepository)(entities_1.FulfillmentCenter);
|
|
16
|
+
const fulfillmentCenter = await repository.findOne({
|
|
17
|
+
where: { domain: context.state.domain, id }
|
|
18
|
+
});
|
|
19
|
+
const requestBody = {
|
|
20
|
+
grant_type: 'authorization_code',
|
|
21
|
+
client_id: appKey,
|
|
22
|
+
client_secret: appSecret,
|
|
23
|
+
redirect_uri: fulfillmentCenter.redirectUrl,
|
|
24
|
+
code
|
|
25
|
+
};
|
|
26
|
+
debug('request body', requestBody);
|
|
27
|
+
const response = await (0, node_fetch_1.default)(`${protocol}://${host}/oauth/access-token`, {
|
|
28
|
+
method: 'post',
|
|
29
|
+
headers: {
|
|
30
|
+
'Content-Type': 'application/json'
|
|
31
|
+
},
|
|
32
|
+
body: JSON.stringify(requestBody)
|
|
33
|
+
});
|
|
34
|
+
if (!response.ok) {
|
|
35
|
+
debug('error', await response.text());
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
const body = await response.json();
|
|
39
|
+
const { access_token, refresh_token, centerId } = body;
|
|
40
|
+
if (!access_token) {
|
|
41
|
+
throw new Error(`get fulfillment center information failed: ${body}`);
|
|
42
|
+
}
|
|
43
|
+
var patch = {
|
|
44
|
+
accessToken: access_token,
|
|
45
|
+
refreshToken: refresh_token,
|
|
46
|
+
accessInfo: JSON.stringify(body, null, 2),
|
|
47
|
+
centerId,
|
|
48
|
+
status: "active" /* FulfillmentCenterStatus.Active */
|
|
49
|
+
};
|
|
50
|
+
return await repository.save(Object.assign(Object.assign(Object.assign({}, fulfillmentCenter), patch), { updater: context.state.user }));
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
//# sourceMappingURL=generate-operato-access-token.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate-operato-access-token.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/fulfillment-center/operato/generate-operato-access-token.ts"],"names":[],"mappings":";;;;;;AAAA,6CAA4C;AAC5C,4DAA8B;AAC9B,qCAAuC;AACvC,mDAAiF;AAEjF,MAAM,EAAE,QAAQ,GAAG,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,YAAM,CAAC,GAAG,CAAC,+BAA+B,EAAE,EAAE,CAAC,CAAA;AAEvG,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC,sEAAsE,CAAC,CAAA;AAEzF,QAAA,0BAA0B,GAAG;IACxC,KAAK,CAAC,0BAA0B,CAAC,CAAM,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,OAAY;QACjE,MAAM,UAAU,GAAG,IAAA,uBAAa,EAAC,4BAAiB,CAAC,CAAA;QACnD,MAAM,iBAAiB,GAAQ,MAAM,UAAU,CAAC,OAAO,CAAC;YACtD,KAAK,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,EAAE,EAAE;SAC5C,CAAC,CAAA;QAEF,MAAM,WAAW,GAAG;YAClB,UAAU,EAAE,oBAAoB;YAChC,SAAS,EAAE,MAAM;YACjB,aAAa,EAAE,SAAS;YACxB,YAAY,EAAE,iBAAiB,CAAC,WAAW;YAC3C,IAAI;SACL,CAAA;QAED,KAAK,CAAC,cAAc,EAAE,WAAW,CAAC,CAAA;QAElC,MAAM,QAAQ,GAAG,MAAM,IAAA,oBAAK,EAAC,GAAG,QAAQ,MAAM,IAAI,qBAAqB,EAAE;YACvE,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;aACnC;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC;SAClC,CAAC,CAAA;QAEF,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE;YAChB,KAAK,CAAC,OAAO,EAAE,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAA;YACrC,OAAM;SACP;QAED,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAA;QAClC,MAAM,EAAE,YAAY,EAAE,aAAa,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAA;QAEtD,IAAI,CAAC,YAAY,EAAE;YACjB,MAAM,IAAI,KAAK,CAAC,8CAA8C,IAAI,EAAE,CAAC,CAAA;SACtE;QAED,IAAI,KAAK,GAAG;YACV,WAAW,EAAE,YAAY;YACzB,YAAY,EAAE,aAAa;YAC3B,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;YACzC,QAAQ;YACR,MAAM,+CAAgC;SACvC,CAAA;QAED,OAAO,MAAM,UAAU,CAAC,IAAI,+CACvB,iBAAiB,GACjB,KAAK,KACR,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,IAC3B,CAAA;IACJ,CAAC;CACF,CAAA"}
|