@commercetools-frontend/mc-scripts 23.2.1 → 23.2.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.
- package/cli/dist/commercetools-frontend-mc-scripts-cli.cjs.dev.js +11 -9
- package/cli/dist/commercetools-frontend-mc-scripts-cli.cjs.prod.js +11 -9
- package/cli/dist/commercetools-frontend-mc-scripts-cli.esm.js +11 -9
- package/dist/{build-6bd0ac22.cjs.prod.js → build-38b63c1d.cjs.prod.js} +3 -3
- package/dist/{build-360f081d.cjs.dev.js → build-766e8b1f.cjs.dev.js} +3 -3
- package/dist/{build-d10bc41b.esm.js → build-7cf1c59d.esm.js} +3 -3
- package/dist/commercetools-frontend-mc-scripts.cjs.dev.js +1 -1
- package/dist/commercetools-frontend-mc-scripts.cjs.prod.js +1 -1
- package/dist/commercetools-frontend-mc-scripts.esm.js +1 -1
- package/dist/{config-sync-1b8ae40b.esm.js → config-sync-b938b2bd.esm.js} +3 -3
- package/dist/{config-sync-482a69fe.cjs.dev.js → config-sync-da0f180c.cjs.dev.js} +3 -3
- package/dist/{config-sync-d53518fd.cjs.prod.js → config-sync-dce56250.cjs.prod.js} +3 -3
- package/dist/{create-postcss-config-c5cf6d30.esm.js → create-postcss-config-451f01ac.esm.js} +1 -1
- package/dist/{create-postcss-config-fe0eda38.cjs.dev.js → create-postcss-config-556e8979.cjs.dev.js} +1 -1
- package/dist/{create-postcss-config-5e470fa7.cjs.prod.js → create-postcss-config-a45dc69a.cjs.prod.js} +1 -1
- package/dist/{create-webpack-config-for-development-bde94f6a.esm.js → create-webpack-config-for-development-12f499e6.esm.js} +1 -1
- package/dist/{create-webpack-config-for-development-48c400cd.cjs.prod.js → create-webpack-config-for-development-b6fd96b4.cjs.prod.js} +1 -1
- package/dist/{create-webpack-config-for-development-ea1e020f.cjs.dev.js → create-webpack-config-for-development-c2ee14e5.cjs.dev.js} +1 -1
- package/dist/{create-webpack-config-for-production-c5364376.cjs.dev.js → create-webpack-config-for-production-c0d65bed.cjs.dev.js} +1 -1
- package/dist/{create-webpack-config-for-production-03fb373c.cjs.prod.js → create-webpack-config-for-production-ce997721.cjs.prod.js} +1 -1
- package/dist/{create-webpack-config-for-production-98949ba8.esm.js → create-webpack-config-for-production-d1cab2fd.esm.js} +1 -1
- package/dist/{credentials-storage-8cf72194.cjs.prod.js → credentials-storage-52529612.cjs.prod.js} +1 -1
- package/dist/{credentials-storage-8246aab4.cjs.dev.js → credentials-storage-6d91b6da.cjs.dev.js} +1 -1
- package/dist/{credentials-storage-caf1c2ad.esm.js → credentials-storage-e094db15.esm.js} +1 -1
- package/dist/declarations/src/utils/auth-callback.d.ts +11 -0
- package/dist/declarations/src/vite-plugins/vite-plugin-merchant-center-customization.d.ts +1 -0
- package/dist/{deployment-previews-set-b2dc5c83.cjs.prod.js → deployment-previews-set-213d2aba.cjs.prod.js} +3 -3
- package/dist/{deployment-previews-set-b6c92418.esm.js → deployment-previews-set-2fd24531.esm.js} +3 -3
- package/dist/{deployment-previews-set-14da3831.cjs.dev.js → deployment-previews-set-626ac65e.cjs.dev.js} +3 -3
- package/dist/{graphql-requests-02024fb9.cjs.dev.js → graphql-requests-28c9c031.cjs.prod.js} +8 -4
- package/dist/{graphql-requests-9b0cf79b.esm.js → graphql-requests-5b3a9ffc.esm.js} +9 -5
- package/dist/{graphql-requests-a42d578d.cjs.prod.js → graphql-requests-8b3897b7.cjs.dev.js} +8 -4
- package/dist/login-05350511.cjs.prod.js +217 -0
- package/dist/login-77a5805e.cjs.dev.js +217 -0
- package/dist/login-c5a096cb.esm.js +176 -0
- package/dist/{package-fdee3971.esm.js → package-12437f2f.esm.js} +10 -8
- package/dist/{package-68bccd43.cjs.dev.js → package-325393f8.cjs.prod.js} +10 -8
- package/dist/{package-9161a458.cjs.prod.js → package-da809c85.cjs.dev.js} +10 -8
- package/dist/{start-13e3a0ba.esm.js → start-7052aaaa.esm.js} +3 -3
- package/dist/{start-be2ffdfc.cjs.dev.js → start-a35affd1.cjs.dev.js} +3 -3
- package/dist/{start-5dc189f3.cjs.prod.js → start-cb3a361d.cjs.prod.js} +3 -3
- package/package.json +10 -8
- package/postcss/dist/commercetools-frontend-mc-scripts-postcss.cjs.dev.js +2 -2
- package/postcss/dist/commercetools-frontend-mc-scripts-postcss.cjs.prod.js +2 -2
- package/postcss/dist/commercetools-frontend-mc-scripts-postcss.esm.js +2 -2
- package/webpack/dist/commercetools-frontend-mc-scripts-webpack.cjs.dev.js +4 -4
- package/webpack/dist/commercetools-frontend-mc-scripts-webpack.cjs.prod.js +4 -4
- package/webpack/dist/commercetools-frontend-mc-scripts-webpack.esm.js +4 -4
- package/dist/login-35a7c23c.esm.js +0 -85
- package/dist/login-ecf933dc.cjs.dev.js +0 -102
- package/dist/login-f13ca0a8.cjs.prod.js +0 -102
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
import _Promise from '@babel/runtime-corejs3/core-js-stable/promise';
|
|
2
|
+
import _URL from '@babel/runtime-corejs3/core-js-stable/url';
|
|
3
|
+
import crypto from 'node:crypto';
|
|
4
|
+
import process from 'node:process';
|
|
5
|
+
import chalk from 'chalk';
|
|
6
|
+
import prompts from 'prompts';
|
|
7
|
+
import { processConfig } from '@commercetools-frontend/application-config';
|
|
8
|
+
import { p as pkgJson } from './package-12437f2f.esm.js';
|
|
9
|
+
import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
|
|
10
|
+
import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
|
|
11
|
+
import _filterInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/filter';
|
|
12
|
+
import _Object$getOwnPropertyDescriptor from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor';
|
|
13
|
+
import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/for-each';
|
|
14
|
+
import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
|
|
15
|
+
import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
|
|
16
|
+
import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
|
|
17
|
+
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
18
|
+
import _JSON$stringify from '@babel/runtime-corejs3/core-js-stable/json/stringify';
|
|
19
|
+
import fetch from 'node-fetch';
|
|
20
|
+
import { u as userAgent, C as CredentialsStorage } from './credentials-storage-e094db15.esm.js';
|
|
21
|
+
import http from 'node:http';
|
|
22
|
+
import jwtDecode from 'jwt-decode';
|
|
23
|
+
import '@commercetools/http-user-agent';
|
|
24
|
+
import '@babel/runtime-corejs3/helpers/classCallCheck';
|
|
25
|
+
import '@babel/runtime-corejs3/helpers/createClass';
|
|
26
|
+
import '@babel/runtime-corejs3/core-js-stable/date/now';
|
|
27
|
+
import 'node:fs';
|
|
28
|
+
import 'node:os';
|
|
29
|
+
import 'node:path';
|
|
30
|
+
import './does-file-exist-32618334.esm.js';
|
|
31
|
+
|
|
32
|
+
function ownKeys(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
33
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
34
|
+
const getAuthToken = async (mcApiUrl, payload, headers) => {
|
|
35
|
+
const response = await fetch(`${mcApiUrl}/tokens/cli`, {
|
|
36
|
+
method: 'POST',
|
|
37
|
+
headers: _objectSpread({
|
|
38
|
+
Accept: 'application/json',
|
|
39
|
+
'Content-Type': 'application/json',
|
|
40
|
+
'x-user-agent': userAgent
|
|
41
|
+
}, headers),
|
|
42
|
+
body: _JSON$stringify(payload)
|
|
43
|
+
});
|
|
44
|
+
if (!response.ok) {
|
|
45
|
+
const text = await response.text();
|
|
46
|
+
let parsed;
|
|
47
|
+
try {
|
|
48
|
+
parsed = JSON.parse(text);
|
|
49
|
+
} catch (error) {}
|
|
50
|
+
const errorMessage = parsed ? parsed.message : text;
|
|
51
|
+
throw new Error(errorMessage);
|
|
52
|
+
}
|
|
53
|
+
const authToken = await response.json();
|
|
54
|
+
return authToken;
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
function createAuthCallbackServer(options) {
|
|
58
|
+
const server = http.createServer(async (request, response) => {
|
|
59
|
+
try {
|
|
60
|
+
if (request.url?.includes(`/${options.clientIdentifier}/oidc/callback`)) {
|
|
61
|
+
const incomingUrl = new _URL(request.url, 'http://localhost');
|
|
62
|
+
const sessionToken = incomingUrl.searchParams.get('sessionToken');
|
|
63
|
+
const requestedState = incomingUrl.searchParams.get('state');
|
|
64
|
+
if (!sessionToken) {
|
|
65
|
+
throw new Error('Invalid authentication flow (missing sessionToken)');
|
|
66
|
+
}
|
|
67
|
+
const decodedSessionToken = jwtDecode(sessionToken);
|
|
68
|
+
if (decodedSessionToken?.nonce !== options.nonce) {
|
|
69
|
+
throw new Error('Invalid authentication flow (nonce mismatch)');
|
|
70
|
+
}
|
|
71
|
+
if (requestedState !== options.state) {
|
|
72
|
+
throw new Error('Invalid authentication flow (state mismatch)');
|
|
73
|
+
}
|
|
74
|
+
options.onSuccess({
|
|
75
|
+
token: sessionToken,
|
|
76
|
+
expiresAt: decodedSessionToken.exp
|
|
77
|
+
});
|
|
78
|
+
response.setHeader('content-type', 'text/html');
|
|
79
|
+
response.end('Success!');
|
|
80
|
+
server.close();
|
|
81
|
+
}
|
|
82
|
+
} catch (error) {
|
|
83
|
+
response.setHeader('content-type', 'text/html');
|
|
84
|
+
if (error instanceof Error) {
|
|
85
|
+
console.error(error.message);
|
|
86
|
+
response.end(error.message);
|
|
87
|
+
} else {
|
|
88
|
+
console.error(error);
|
|
89
|
+
response.end(`Invalid authentication flow.`);
|
|
90
|
+
}
|
|
91
|
+
server.close();
|
|
92
|
+
}
|
|
93
|
+
});
|
|
94
|
+
return server;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
const credentialsStorage = new CredentialsStorage();
|
|
98
|
+
const port = 3001;
|
|
99
|
+
const clientIdentifier = `mc-scripts-${pkgJson.version}`;
|
|
100
|
+
const startServer = server => new _Promise((resolve, reject) => {
|
|
101
|
+
server.listen(port).on('listening', resolve).on('error', error => {
|
|
102
|
+
console.error('Problem starting server', error);
|
|
103
|
+
return reject(error);
|
|
104
|
+
}).on('close', () => {
|
|
105
|
+
process.exit();
|
|
106
|
+
});
|
|
107
|
+
});
|
|
108
|
+
const generateRandomHash = function () {
|
|
109
|
+
let length = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 16;
|
|
110
|
+
return crypto.randomBytes(length).toString('hex');
|
|
111
|
+
};
|
|
112
|
+
async function run() {
|
|
113
|
+
const shouldUseExperimentalIdentityAuthFlow = process.env.ENABLE_EXPERIMENTAL_IDENTITY_AUTH_FLOW === 'true';
|
|
114
|
+
const applicationConfig = await processConfig();
|
|
115
|
+
const mcApiUrl = applicationConfig.env.mcApiUrl;
|
|
116
|
+
console.log(`Using Merchant Center environment "${chalk.green(mcApiUrl)}".`);
|
|
117
|
+
console.log();
|
|
118
|
+
if (credentialsStorage.isSessionValid(mcApiUrl)) {
|
|
119
|
+
console.log(`You already have a valid session.`);
|
|
120
|
+
return;
|
|
121
|
+
}
|
|
122
|
+
if (shouldUseExperimentalIdentityAuthFlow) {
|
|
123
|
+
const open = await import('open');
|
|
124
|
+
const state = generateRandomHash();
|
|
125
|
+
const nonce = generateRandomHash();
|
|
126
|
+
const authUrl = new _URL('/login/authorize', mcApiUrl);
|
|
127
|
+
authUrl.searchParams.set('response_type', 'id_token');
|
|
128
|
+
authUrl.searchParams.set('response_mode', 'query');
|
|
129
|
+
authUrl.searchParams.set('client_id', `__local:${clientIdentifier}`);
|
|
130
|
+
authUrl.searchParams.set('scope', ['openid'
|
|
131
|
+
// 'project_key:??',
|
|
132
|
+
].join(' '));
|
|
133
|
+
authUrl.searchParams.set('state', state);
|
|
134
|
+
authUrl.searchParams.set('nonce', nonce);
|
|
135
|
+
const server = createAuthCallbackServer({
|
|
136
|
+
clientIdentifier,
|
|
137
|
+
state,
|
|
138
|
+
nonce,
|
|
139
|
+
onSuccess: tokenContext => {
|
|
140
|
+
credentialsStorage.setToken(mcApiUrl, tokenContext);
|
|
141
|
+
console.log();
|
|
142
|
+
console.log(chalk.green(`Login successful.`));
|
|
143
|
+
console.log();
|
|
144
|
+
}
|
|
145
|
+
});
|
|
146
|
+
await startServer(server);
|
|
147
|
+
await open.default(authUrl.toString());
|
|
148
|
+
console.log('Waiting for the OIDC authentication to complete...');
|
|
149
|
+
} else {
|
|
150
|
+
console.log(`Enter the login credentials:`);
|
|
151
|
+
const _await$prompts = await prompts({
|
|
152
|
+
type: 'text',
|
|
153
|
+
name: 'email',
|
|
154
|
+
message: 'Email'
|
|
155
|
+
}),
|
|
156
|
+
email = _await$prompts.email;
|
|
157
|
+
const _await$prompts2 = await prompts({
|
|
158
|
+
type: 'invisible',
|
|
159
|
+
name: 'password',
|
|
160
|
+
message: 'Password (hidden)'
|
|
161
|
+
}),
|
|
162
|
+
password = _await$prompts2.password;
|
|
163
|
+
if (!email || !password) {
|
|
164
|
+
throw new Error(`Missing email or password values. Aborting.`);
|
|
165
|
+
}
|
|
166
|
+
const credentials = await getAuthToken(mcApiUrl, {
|
|
167
|
+
email,
|
|
168
|
+
password
|
|
169
|
+
});
|
|
170
|
+
credentialsStorage.setToken(mcApiUrl, credentials);
|
|
171
|
+
console.log(chalk.green(`Login successful.`));
|
|
172
|
+
console.log();
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
export { run as default };
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
var pkgJson = {
|
|
2
2
|
name: "@commercetools-frontend/mc-scripts",
|
|
3
|
-
version: "23.2.
|
|
3
|
+
version: "23.2.3",
|
|
4
4
|
description: "Configuration and scripts for developing a MC application",
|
|
5
5
|
bugs: "https://github.com/commercetools/merchant-center-application-kit/issues",
|
|
6
6
|
repository: {
|
|
@@ -61,13 +61,13 @@ var pkgJson = {
|
|
|
61
61
|
"@babel/plugin-proposal-do-expressions": "^7.22.5",
|
|
62
62
|
"@babel/runtime": "^7.22.15",
|
|
63
63
|
"@babel/runtime-corejs3": "^7.22.15",
|
|
64
|
-
"@commercetools-frontend/application-components": "23.2.
|
|
65
|
-
"@commercetools-frontend/application-config": "23.2.
|
|
66
|
-
"@commercetools-frontend/assets": "23.2.
|
|
67
|
-
"@commercetools-frontend/babel-preset-mc-app": "23.2.
|
|
68
|
-
"@commercetools-frontend/constants": "23.2.
|
|
69
|
-
"@commercetools-frontend/mc-dev-authentication": "23.2.
|
|
70
|
-
"@commercetools-frontend/mc-html-template": "23.2.
|
|
64
|
+
"@commercetools-frontend/application-components": "23.2.3",
|
|
65
|
+
"@commercetools-frontend/application-config": "23.2.3",
|
|
66
|
+
"@commercetools-frontend/assets": "23.2.3",
|
|
67
|
+
"@commercetools-frontend/babel-preset-mc-app": "23.2.3",
|
|
68
|
+
"@commercetools-frontend/constants": "23.2.3",
|
|
69
|
+
"@commercetools-frontend/mc-dev-authentication": "23.2.3",
|
|
70
|
+
"@commercetools-frontend/mc-html-template": "23.2.3",
|
|
71
71
|
"@commercetools/http-user-agent": "3.0.0",
|
|
72
72
|
"@emotion/babel-plugin": "^11.13.5",
|
|
73
73
|
"@formatjs/cli-lib": "^6.3.8",
|
|
@@ -99,11 +99,13 @@ var pkgJson = {
|
|
|
99
99
|
"graphql-tag": "^2.12.6",
|
|
100
100
|
"html-webpack-plugin": "5.6.0",
|
|
101
101
|
"json-loader": "0.5.7",
|
|
102
|
+
"jwt-decode": "3.1.2",
|
|
102
103
|
lodash: "4.17.21",
|
|
103
104
|
"mini-css-extract-plugin": "2.9.0",
|
|
104
105
|
moment: "^2.29.4",
|
|
105
106
|
"moment-locales-webpack-plugin": "1.2.0",
|
|
106
107
|
"node-fetch": "2.7.0",
|
|
108
|
+
open: "^10.1.0",
|
|
107
109
|
postcss: "8.4.38",
|
|
108
110
|
"postcss-custom-media": "8.0.2",
|
|
109
111
|
"postcss-custom-properties": "12.1.4",
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
var pkgJson = {
|
|
4
4
|
name: "@commercetools-frontend/mc-scripts",
|
|
5
|
-
version: "23.2.
|
|
5
|
+
version: "23.2.3",
|
|
6
6
|
description: "Configuration and scripts for developing a MC application",
|
|
7
7
|
bugs: "https://github.com/commercetools/merchant-center-application-kit/issues",
|
|
8
8
|
repository: {
|
|
@@ -63,13 +63,13 @@ var pkgJson = {
|
|
|
63
63
|
"@babel/plugin-proposal-do-expressions": "^7.22.5",
|
|
64
64
|
"@babel/runtime": "^7.22.15",
|
|
65
65
|
"@babel/runtime-corejs3": "^7.22.15",
|
|
66
|
-
"@commercetools-frontend/application-components": "23.2.
|
|
67
|
-
"@commercetools-frontend/application-config": "23.2.
|
|
68
|
-
"@commercetools-frontend/assets": "23.2.
|
|
69
|
-
"@commercetools-frontend/babel-preset-mc-app": "23.2.
|
|
70
|
-
"@commercetools-frontend/constants": "23.2.
|
|
71
|
-
"@commercetools-frontend/mc-dev-authentication": "23.2.
|
|
72
|
-
"@commercetools-frontend/mc-html-template": "23.2.
|
|
66
|
+
"@commercetools-frontend/application-components": "23.2.3",
|
|
67
|
+
"@commercetools-frontend/application-config": "23.2.3",
|
|
68
|
+
"@commercetools-frontend/assets": "23.2.3",
|
|
69
|
+
"@commercetools-frontend/babel-preset-mc-app": "23.2.3",
|
|
70
|
+
"@commercetools-frontend/constants": "23.2.3",
|
|
71
|
+
"@commercetools-frontend/mc-dev-authentication": "23.2.3",
|
|
72
|
+
"@commercetools-frontend/mc-html-template": "23.2.3",
|
|
73
73
|
"@commercetools/http-user-agent": "3.0.0",
|
|
74
74
|
"@emotion/babel-plugin": "^11.13.5",
|
|
75
75
|
"@formatjs/cli-lib": "^6.3.8",
|
|
@@ -101,11 +101,13 @@ var pkgJson = {
|
|
|
101
101
|
"graphql-tag": "^2.12.6",
|
|
102
102
|
"html-webpack-plugin": "5.6.0",
|
|
103
103
|
"json-loader": "0.5.7",
|
|
104
|
+
"jwt-decode": "3.1.2",
|
|
104
105
|
lodash: "4.17.21",
|
|
105
106
|
"mini-css-extract-plugin": "2.9.0",
|
|
106
107
|
moment: "^2.29.4",
|
|
107
108
|
"moment-locales-webpack-plugin": "1.2.0",
|
|
108
109
|
"node-fetch": "2.7.0",
|
|
110
|
+
open: "^10.1.0",
|
|
109
111
|
postcss: "8.4.38",
|
|
110
112
|
"postcss-custom-media": "8.0.2",
|
|
111
113
|
"postcss-custom-properties": "12.1.4",
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
var pkgJson = {
|
|
4
4
|
name: "@commercetools-frontend/mc-scripts",
|
|
5
|
-
version: "23.2.
|
|
5
|
+
version: "23.2.3",
|
|
6
6
|
description: "Configuration and scripts for developing a MC application",
|
|
7
7
|
bugs: "https://github.com/commercetools/merchant-center-application-kit/issues",
|
|
8
8
|
repository: {
|
|
@@ -63,13 +63,13 @@ var pkgJson = {
|
|
|
63
63
|
"@babel/plugin-proposal-do-expressions": "^7.22.5",
|
|
64
64
|
"@babel/runtime": "^7.22.15",
|
|
65
65
|
"@babel/runtime-corejs3": "^7.22.15",
|
|
66
|
-
"@commercetools-frontend/application-components": "23.2.
|
|
67
|
-
"@commercetools-frontend/application-config": "23.2.
|
|
68
|
-
"@commercetools-frontend/assets": "23.2.
|
|
69
|
-
"@commercetools-frontend/babel-preset-mc-app": "23.2.
|
|
70
|
-
"@commercetools-frontend/constants": "23.2.
|
|
71
|
-
"@commercetools-frontend/mc-dev-authentication": "23.2.
|
|
72
|
-
"@commercetools-frontend/mc-html-template": "23.2.
|
|
66
|
+
"@commercetools-frontend/application-components": "23.2.3",
|
|
67
|
+
"@commercetools-frontend/application-config": "23.2.3",
|
|
68
|
+
"@commercetools-frontend/assets": "23.2.3",
|
|
69
|
+
"@commercetools-frontend/babel-preset-mc-app": "23.2.3",
|
|
70
|
+
"@commercetools-frontend/constants": "23.2.3",
|
|
71
|
+
"@commercetools-frontend/mc-dev-authentication": "23.2.3",
|
|
72
|
+
"@commercetools-frontend/mc-html-template": "23.2.3",
|
|
73
73
|
"@commercetools/http-user-agent": "3.0.0",
|
|
74
74
|
"@emotion/babel-plugin": "^11.13.5",
|
|
75
75
|
"@formatjs/cli-lib": "^6.3.8",
|
|
@@ -101,11 +101,13 @@ var pkgJson = {
|
|
|
101
101
|
"graphql-tag": "^2.12.6",
|
|
102
102
|
"html-webpack-plugin": "5.6.0",
|
|
103
103
|
"json-loader": "0.5.7",
|
|
104
|
+
"jwt-decode": "3.1.2",
|
|
104
105
|
lodash: "4.17.21",
|
|
105
106
|
"mini-css-extract-plugin": "2.9.0",
|
|
106
107
|
moment: "^2.29.4",
|
|
107
108
|
"moment-locales-webpack-plugin": "1.2.0",
|
|
108
109
|
"node-fetch": "2.7.0",
|
|
110
|
+
open: "^10.1.0",
|
|
109
111
|
postcss: "8.4.38",
|
|
110
112
|
"postcss-custom-media": "8.0.2",
|
|
111
113
|
"postcss-custom-properties": "12.1.4",
|
|
@@ -7,7 +7,7 @@ import openBrowser from 'react-dev-utils/openBrowser';
|
|
|
7
7
|
import { choosePort, prepareUrls, createCompiler } from 'react-dev-utils/WebpackDevServerUtils';
|
|
8
8
|
import webpack from 'webpack';
|
|
9
9
|
import WebpackDevServer from 'webpack-dev-server';
|
|
10
|
-
import { c as createWebpackConfigForDevelopment } from './create-webpack-config-for-development-
|
|
10
|
+
import { c as createWebpackConfigForDevelopment } from './create-webpack-config-for-development-12f499e6.esm.js';
|
|
11
11
|
import { p as paths } from './paths-39f22b8b.esm.js';
|
|
12
12
|
import { processConfig } from '@commercetools-frontend/application-config';
|
|
13
13
|
import { createMcDevAuthenticationMiddleware } from '@commercetools-frontend/mc-dev-authentication';
|
|
@@ -34,9 +34,9 @@ import 'webpackbar';
|
|
|
34
34
|
import '@babel/runtime-corejs3/helpers/classCallCheck';
|
|
35
35
|
import '@babel/runtime-corejs3/helpers/createClass';
|
|
36
36
|
import '@babel/runtime-corejs3/core-js-stable/object/assign';
|
|
37
|
-
import './create-postcss-config-
|
|
37
|
+
import './create-postcss-config-451f01ac.esm.js';
|
|
38
38
|
import '@babel/runtime-corejs3/helpers/slicedToArray';
|
|
39
|
-
import './package-
|
|
39
|
+
import './package-12437f2f.esm.js';
|
|
40
40
|
import './has-jsx-runtime-e3ecb09b.esm.js';
|
|
41
41
|
import './optimizations-bf991634.esm.js';
|
|
42
42
|
import '@babel/runtime-corejs3/core-js-stable/instance/reduce';
|
|
@@ -9,7 +9,7 @@ var openBrowser = require('react-dev-utils/openBrowser');
|
|
|
9
9
|
var WebpackDevServerUtils = require('react-dev-utils/WebpackDevServerUtils');
|
|
10
10
|
var webpack = require('webpack');
|
|
11
11
|
var WebpackDevServer = require('webpack-dev-server');
|
|
12
|
-
var createWebpackConfigForDevelopment = require('./create-webpack-config-for-development-
|
|
12
|
+
var createWebpackConfigForDevelopment = require('./create-webpack-config-for-development-c2ee14e5.cjs.dev.js');
|
|
13
13
|
var paths = require('./paths-b76fc753.cjs.dev.js');
|
|
14
14
|
var applicationConfig = require('@commercetools-frontend/application-config');
|
|
15
15
|
var mcDevAuthentication = require('@commercetools-frontend/mc-dev-authentication');
|
|
@@ -36,9 +36,9 @@ require('webpackbar');
|
|
|
36
36
|
require('@babel/runtime-corejs3/helpers/classCallCheck');
|
|
37
37
|
require('@babel/runtime-corejs3/helpers/createClass');
|
|
38
38
|
require('@babel/runtime-corejs3/core-js-stable/object/assign');
|
|
39
|
-
require('./create-postcss-config-
|
|
39
|
+
require('./create-postcss-config-556e8979.cjs.dev.js');
|
|
40
40
|
require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
41
|
-
require('./package-
|
|
41
|
+
require('./package-da809c85.cjs.dev.js');
|
|
42
42
|
require('./has-jsx-runtime-aa5d21ee.cjs.dev.js');
|
|
43
43
|
require('./optimizations-7789145e.cjs.dev.js');
|
|
44
44
|
require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
|
|
@@ -9,7 +9,7 @@ var openBrowser = require('react-dev-utils/openBrowser');
|
|
|
9
9
|
var WebpackDevServerUtils = require('react-dev-utils/WebpackDevServerUtils');
|
|
10
10
|
var webpack = require('webpack');
|
|
11
11
|
var WebpackDevServer = require('webpack-dev-server');
|
|
12
|
-
var createWebpackConfigForDevelopment = require('./create-webpack-config-for-development-
|
|
12
|
+
var createWebpackConfigForDevelopment = require('./create-webpack-config-for-development-b6fd96b4.cjs.prod.js');
|
|
13
13
|
var paths = require('./paths-7768b440.cjs.prod.js');
|
|
14
14
|
var applicationConfig = require('@commercetools-frontend/application-config');
|
|
15
15
|
var mcDevAuthentication = require('@commercetools-frontend/mc-dev-authentication');
|
|
@@ -36,9 +36,9 @@ require('webpackbar');
|
|
|
36
36
|
require('@babel/runtime-corejs3/helpers/classCallCheck');
|
|
37
37
|
require('@babel/runtime-corejs3/helpers/createClass');
|
|
38
38
|
require('@babel/runtime-corejs3/core-js-stable/object/assign');
|
|
39
|
-
require('./create-postcss-config-
|
|
39
|
+
require('./create-postcss-config-a45dc69a.cjs.prod.js');
|
|
40
40
|
require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
41
|
-
require('./package-
|
|
41
|
+
require('./package-325393f8.cjs.prod.js');
|
|
42
42
|
require('./has-jsx-runtime-c3202df5.cjs.prod.js');
|
|
43
43
|
require('./optimizations-fb93514f.cjs.prod.js');
|
|
44
44
|
require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@commercetools-frontend/mc-scripts",
|
|
3
|
-
"version": "23.2.
|
|
3
|
+
"version": "23.2.3",
|
|
4
4
|
"description": "Configuration and scripts for developing a MC application",
|
|
5
5
|
"bugs": "https://github.com/commercetools/merchant-center-application-kit/issues",
|
|
6
6
|
"repository": {
|
|
@@ -61,13 +61,13 @@
|
|
|
61
61
|
"@babel/plugin-proposal-do-expressions": "^7.22.5",
|
|
62
62
|
"@babel/runtime": "^7.22.15",
|
|
63
63
|
"@babel/runtime-corejs3": "^7.22.15",
|
|
64
|
-
"@commercetools-frontend/application-components": "23.2.
|
|
65
|
-
"@commercetools-frontend/application-config": "23.2.
|
|
66
|
-
"@commercetools-frontend/assets": "23.2.
|
|
67
|
-
"@commercetools-frontend/babel-preset-mc-app": "23.2.
|
|
68
|
-
"@commercetools-frontend/constants": "23.2.
|
|
69
|
-
"@commercetools-frontend/mc-dev-authentication": "23.2.
|
|
70
|
-
"@commercetools-frontend/mc-html-template": "23.2.
|
|
64
|
+
"@commercetools-frontend/application-components": "23.2.3",
|
|
65
|
+
"@commercetools-frontend/application-config": "23.2.3",
|
|
66
|
+
"@commercetools-frontend/assets": "23.2.3",
|
|
67
|
+
"@commercetools-frontend/babel-preset-mc-app": "23.2.3",
|
|
68
|
+
"@commercetools-frontend/constants": "23.2.3",
|
|
69
|
+
"@commercetools-frontend/mc-dev-authentication": "23.2.3",
|
|
70
|
+
"@commercetools-frontend/mc-html-template": "23.2.3",
|
|
71
71
|
"@commercetools/http-user-agent": "3.0.0",
|
|
72
72
|
"@emotion/babel-plugin": "^11.13.5",
|
|
73
73
|
"@formatjs/cli-lib": "^6.3.8",
|
|
@@ -99,11 +99,13 @@
|
|
|
99
99
|
"graphql-tag": "^2.12.6",
|
|
100
100
|
"html-webpack-plugin": "5.6.0",
|
|
101
101
|
"json-loader": "0.5.7",
|
|
102
|
+
"jwt-decode": "3.1.2",
|
|
102
103
|
"lodash": "4.17.21",
|
|
103
104
|
"mini-css-extract-plugin": "2.9.0",
|
|
104
105
|
"moment": "^2.29.4",
|
|
105
106
|
"moment-locales-webpack-plugin": "1.2.0",
|
|
106
107
|
"node-fetch": "2.7.0",
|
|
108
|
+
"open": "^10.1.0",
|
|
107
109
|
"postcss": "8.4.38",
|
|
108
110
|
"postcss-custom-media": "8.0.2",
|
|
109
111
|
"postcss-custom-properties": "12.1.4",
|
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var createPostcssConfig = require('../../dist/create-postcss-config-
|
|
5
|
+
var createPostcssConfig = require('../../dist/create-postcss-config-556e8979.cjs.dev.js');
|
|
6
6
|
require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
7
7
|
require('path');
|
|
8
|
-
require('../../dist/package-
|
|
8
|
+
require('../../dist/package-da809c85.cjs.dev.js');
|
|
9
9
|
|
|
10
10
|
|
|
11
11
|
|
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var createPostcssConfig = require('../../dist/create-postcss-config-
|
|
5
|
+
var createPostcssConfig = require('../../dist/create-postcss-config-a45dc69a.cjs.prod.js');
|
|
6
6
|
require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
7
7
|
require('path');
|
|
8
|
-
require('../../dist/package-
|
|
8
|
+
require('../../dist/package-325393f8.cjs.prod.js');
|
|
9
9
|
|
|
10
10
|
|
|
11
11
|
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export { c as createPostcssConfig } from '../../dist/create-postcss-config-
|
|
1
|
+
export { c as createPostcssConfig } from '../../dist/create-postcss-config-451f01ac.esm.js';
|
|
2
2
|
import '@babel/runtime-corejs3/helpers/slicedToArray';
|
|
3
3
|
import 'path';
|
|
4
|
-
import '../../dist/package-
|
|
4
|
+
import '../../dist/package-12437f2f.esm.js';
|
|
@@ -2,8 +2,8 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var createWebpackConfigForDevelopment = require('../../dist/create-webpack-config-for-development-
|
|
6
|
-
var createWebpackConfigForProduction = require('../../dist/create-webpack-config-for-production-
|
|
5
|
+
var createWebpackConfigForDevelopment = require('../../dist/create-webpack-config-for-development-c2ee14e5.cjs.dev.js');
|
|
6
|
+
var createWebpackConfigForProduction = require('../../dist/create-webpack-config-for-production-c0d65bed.cjs.dev.js');
|
|
7
7
|
require('@babel/runtime-corejs3/core-js-stable/object/keys');
|
|
8
8
|
require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
|
|
9
9
|
require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor');
|
|
@@ -29,9 +29,9 @@ require('@babel/runtime-corejs3/helpers/createClass');
|
|
|
29
29
|
require('@babel/runtime-corejs3/core-js-stable/object/assign');
|
|
30
30
|
require('@commercetools-frontend/application-config');
|
|
31
31
|
require('@commercetools-frontend/mc-html-template');
|
|
32
|
-
require('../../dist/create-postcss-config-
|
|
32
|
+
require('../../dist/create-postcss-config-556e8979.cjs.dev.js');
|
|
33
33
|
require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
34
|
-
require('../../dist/package-
|
|
34
|
+
require('../../dist/package-da809c85.cjs.dev.js');
|
|
35
35
|
require('../../dist/has-jsx-runtime-aa5d21ee.cjs.dev.js');
|
|
36
36
|
require('../../dist/optimizations-7789145e.cjs.dev.js');
|
|
37
37
|
require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
|
|
@@ -2,8 +2,8 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var createWebpackConfigForDevelopment = require('../../dist/create-webpack-config-for-development-
|
|
6
|
-
var createWebpackConfigForProduction = require('../../dist/create-webpack-config-for-production-
|
|
5
|
+
var createWebpackConfigForDevelopment = require('../../dist/create-webpack-config-for-development-b6fd96b4.cjs.prod.js');
|
|
6
|
+
var createWebpackConfigForProduction = require('../../dist/create-webpack-config-for-production-ce997721.cjs.prod.js');
|
|
7
7
|
require('@babel/runtime-corejs3/core-js-stable/object/keys');
|
|
8
8
|
require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
|
|
9
9
|
require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor');
|
|
@@ -29,9 +29,9 @@ require('@babel/runtime-corejs3/helpers/createClass');
|
|
|
29
29
|
require('@babel/runtime-corejs3/core-js-stable/object/assign');
|
|
30
30
|
require('@commercetools-frontend/application-config');
|
|
31
31
|
require('@commercetools-frontend/mc-html-template');
|
|
32
|
-
require('../../dist/create-postcss-config-
|
|
32
|
+
require('../../dist/create-postcss-config-a45dc69a.cjs.prod.js');
|
|
33
33
|
require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
34
|
-
require('../../dist/package-
|
|
34
|
+
require('../../dist/package-325393f8.cjs.prod.js');
|
|
35
35
|
require('../../dist/has-jsx-runtime-c3202df5.cjs.prod.js');
|
|
36
36
|
require('../../dist/optimizations-fb93514f.cjs.prod.js');
|
|
37
37
|
require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
export { c as createWebpackConfigForDevelopment } from '../../dist/create-webpack-config-for-development-
|
|
2
|
-
export { c as createWebpackConfigForProduction } from '../../dist/create-webpack-config-for-production-
|
|
1
|
+
export { c as createWebpackConfigForDevelopment } from '../../dist/create-webpack-config-for-development-12f499e6.esm.js';
|
|
2
|
+
export { c as createWebpackConfigForProduction } from '../../dist/create-webpack-config-for-production-d1cab2fd.esm.js';
|
|
3
3
|
import '@babel/runtime-corejs3/core-js-stable/object/keys';
|
|
4
4
|
import '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
|
|
5
5
|
import '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor';
|
|
@@ -25,9 +25,9 @@ import '@babel/runtime-corejs3/helpers/createClass';
|
|
|
25
25
|
import '@babel/runtime-corejs3/core-js-stable/object/assign';
|
|
26
26
|
import '@commercetools-frontend/application-config';
|
|
27
27
|
import '@commercetools-frontend/mc-html-template';
|
|
28
|
-
import '../../dist/create-postcss-config-
|
|
28
|
+
import '../../dist/create-postcss-config-451f01ac.esm.js';
|
|
29
29
|
import '@babel/runtime-corejs3/helpers/slicedToArray';
|
|
30
|
-
import '../../dist/package-
|
|
30
|
+
import '../../dist/package-12437f2f.esm.js';
|
|
31
31
|
import '../../dist/has-jsx-runtime-e3ecb09b.esm.js';
|
|
32
32
|
import '../../dist/optimizations-bf991634.esm.js';
|
|
33
33
|
import '@babel/runtime-corejs3/core-js-stable/instance/reduce';
|
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
import chalk from 'chalk';
|
|
2
|
-
import prompts from 'prompts';
|
|
3
|
-
import { processConfig } from '@commercetools-frontend/application-config';
|
|
4
|
-
import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
|
|
5
|
-
import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
|
|
6
|
-
import _filterInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/filter';
|
|
7
|
-
import _Object$getOwnPropertyDescriptor from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor';
|
|
8
|
-
import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/for-each';
|
|
9
|
-
import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
|
|
10
|
-
import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
|
|
11
|
-
import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
|
|
12
|
-
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
13
|
-
import _JSON$stringify from '@babel/runtime-corejs3/core-js-stable/json/stringify';
|
|
14
|
-
import fetch from 'node-fetch';
|
|
15
|
-
import { u as userAgent, C as CredentialsStorage } from './credentials-storage-caf1c2ad.esm.js';
|
|
16
|
-
import '@commercetools/http-user-agent';
|
|
17
|
-
import './package-fdee3971.esm.js';
|
|
18
|
-
import '@babel/runtime-corejs3/helpers/classCallCheck';
|
|
19
|
-
import '@babel/runtime-corejs3/helpers/createClass';
|
|
20
|
-
import '@babel/runtime-corejs3/core-js-stable/date/now';
|
|
21
|
-
import 'node:fs';
|
|
22
|
-
import 'node:os';
|
|
23
|
-
import 'node:path';
|
|
24
|
-
import './does-file-exist-32618334.esm.js';
|
|
25
|
-
|
|
26
|
-
function ownKeys(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
27
|
-
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
28
|
-
const getAuthToken = async (mcApiUrl, payload, headers) => {
|
|
29
|
-
const response = await fetch(`${mcApiUrl}/tokens/cli`, {
|
|
30
|
-
method: 'POST',
|
|
31
|
-
headers: _objectSpread({
|
|
32
|
-
Accept: 'application/json',
|
|
33
|
-
'Content-Type': 'application/json',
|
|
34
|
-
'x-user-agent': userAgent
|
|
35
|
-
}, headers),
|
|
36
|
-
body: _JSON$stringify(payload)
|
|
37
|
-
});
|
|
38
|
-
if (!response.ok) {
|
|
39
|
-
const text = await response.text();
|
|
40
|
-
let parsed;
|
|
41
|
-
try {
|
|
42
|
-
parsed = JSON.parse(text);
|
|
43
|
-
} catch (error) {}
|
|
44
|
-
const errorMessage = parsed ? parsed.message : text;
|
|
45
|
-
throw new Error(errorMessage);
|
|
46
|
-
}
|
|
47
|
-
const authToken = await response.json();
|
|
48
|
-
return authToken;
|
|
49
|
-
};
|
|
50
|
-
|
|
51
|
-
const credentialsStorage = new CredentialsStorage();
|
|
52
|
-
async function run() {
|
|
53
|
-
const applicationConfig = await processConfig();
|
|
54
|
-
const mcApiUrl = applicationConfig.env.mcApiUrl;
|
|
55
|
-
console.log(`Using Merchant Center environment "${chalk.green(mcApiUrl)}".`);
|
|
56
|
-
console.log();
|
|
57
|
-
if (credentialsStorage.isSessionValid(mcApiUrl)) {
|
|
58
|
-
console.log(`You already have a valid session.`);
|
|
59
|
-
return;
|
|
60
|
-
}
|
|
61
|
-
console.log(`Enter the login credentials:`);
|
|
62
|
-
const _await$prompts = await prompts({
|
|
63
|
-
type: 'text',
|
|
64
|
-
name: 'email',
|
|
65
|
-
message: 'Email'
|
|
66
|
-
}),
|
|
67
|
-
email = _await$prompts.email;
|
|
68
|
-
const _await$prompts2 = await prompts({
|
|
69
|
-
type: 'invisible',
|
|
70
|
-
name: 'password',
|
|
71
|
-
message: 'Password (hidden)'
|
|
72
|
-
}),
|
|
73
|
-
password = _await$prompts2.password;
|
|
74
|
-
if (!email || !password) {
|
|
75
|
-
throw new Error(`Missing email or password values. Aborting.`);
|
|
76
|
-
}
|
|
77
|
-
const credentials = await getAuthToken(mcApiUrl, {
|
|
78
|
-
email,
|
|
79
|
-
password
|
|
80
|
-
});
|
|
81
|
-
credentialsStorage.setToken(mcApiUrl, credentials);
|
|
82
|
-
console.log(chalk.green(`Login successful.\n`));
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
export { run as default };
|