@electron-forge/publisher-electron-release-server 6.0.0-beta.6 → 6.0.0-beta.63
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/PublisherERS.d.ts +2 -2
- package/dist/PublisherERS.js +115 -147
- package/package.json +13 -14
- package/tsconfig.json +26 -22
- package/doc/assets/css/main.css +0 -865
- package/doc/assets/css/main.css.map +0 -7
- package/doc/assets/images/icons.png +0 -0
- package/doc/assets/images/icons@2x.png +0 -0
- package/doc/assets/images/widgets.png +0 -0
- package/doc/assets/images/widgets@2x.png +0 -0
- package/doc/assets/js/main.js +0 -5
- package/doc/assets/js/search.js +0 -3
- package/doc/classes/publisherers.html +0 -350
- package/doc/globals.html +0 -243
- package/doc/index.html +0 -246
- package/doc/interfaces/ersversion.html +0 -218
- package/doc/interfaces/publisherersconfig.html +0 -271
- package/src/Config.ts +0 -26
- package/src/PublisherERS.ts +0 -141
- package/tslint.json +0 -12
package/dist/PublisherERS.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import PublisherBase, { PublisherOptions } from '@electron-forge/publisher-base';
|
|
2
2
|
import { ForgePlatform, ForgeArch } from '@electron-forge/shared-types';
|
|
3
3
|
import { PublisherERSConfig } from './Config';
|
|
4
|
-
export declare const ersPlatform: (platform: ForgePlatform, arch: ForgeArch) =>
|
|
4
|
+
export declare const ersPlatform: (platform: ForgePlatform, arch: ForgeArch) => string;
|
|
5
5
|
export default class PublisherERS extends PublisherBase<PublisherERSConfig> {
|
|
6
6
|
name: string;
|
|
7
|
-
publish({makeResults}: PublisherOptions): Promise<void>;
|
|
7
|
+
publish({ makeResults }: PublisherOptions): Promise<void>;
|
|
8
8
|
}
|
package/dist/PublisherERS.js
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.
|
|
6
|
+
exports.ersPlatform = exports.default = void 0;
|
|
7
7
|
|
|
8
8
|
require("source-map-support/register");
|
|
9
9
|
|
|
@@ -23,10 +23,21 @@ var _path = _interopRequireDefault(require("path"));
|
|
|
23
23
|
|
|
24
24
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
25
25
|
|
|
26
|
-
function
|
|
26
|
+
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
27
27
|
|
|
28
28
|
const d = (0, _debug.default)('electron-forge:publish:ers');
|
|
29
29
|
|
|
30
|
+
const fetchAndCheckStatus = async (url, init) => {
|
|
31
|
+
const result = await (0, _nodeFetch.default)(url, init);
|
|
32
|
+
|
|
33
|
+
if (result.ok) {
|
|
34
|
+
// res.status >= 200 && res.status < 300
|
|
35
|
+
return result;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
throw new Error(`ERS publish failed with status code: ${result.status} (${result.url})`);
|
|
39
|
+
};
|
|
40
|
+
|
|
30
41
|
const ersPlatform = (platform, arch) => {
|
|
31
42
|
switch (platform) {
|
|
32
43
|
case 'darwin':
|
|
@@ -47,164 +58,121 @@ exports.ersPlatform = ersPlatform;
|
|
|
47
58
|
|
|
48
59
|
class PublisherERS extends _publisherBase.default {
|
|
49
60
|
constructor(...args) {
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
configurable: true,
|
|
54
|
-
enumerable: true,
|
|
55
|
-
writable: true,
|
|
56
|
-
value: 'electron-release-server'
|
|
57
|
-
}), _temp;
|
|
61
|
+
super(...args);
|
|
62
|
+
|
|
63
|
+
_defineProperty(this, "name", 'electron-release-server');
|
|
58
64
|
}
|
|
59
65
|
|
|
60
|
-
publish({
|
|
66
|
+
async publish({
|
|
61
67
|
makeResults
|
|
62
68
|
}) {
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
69
|
+
const {
|
|
70
|
+
config
|
|
71
|
+
} = this;
|
|
72
|
+
|
|
73
|
+
if (!(config.baseUrl && config.username && config.password)) {
|
|
74
|
+
throw new Error('In order to publish to ERS you must set the "electronReleaseServer.baseUrl", "electronReleaseServer.username" and "electronReleaseServer.password" properties in your Forge config. See the docs for more info');
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
d('attempting to authenticate to ERS');
|
|
78
|
+
|
|
79
|
+
const api = apiPath => `${config.baseUrl}/${apiPath}`;
|
|
80
|
+
|
|
81
|
+
const {
|
|
82
|
+
token
|
|
83
|
+
} = await (await fetchAndCheckStatus(api('api/auth/login'), {
|
|
84
|
+
method: 'POST',
|
|
85
|
+
body: JSON.stringify({
|
|
86
|
+
username: config.username,
|
|
87
|
+
password: config.password
|
|
88
|
+
}),
|
|
89
|
+
headers: {
|
|
90
|
+
'Content-Type': 'application/json'
|
|
91
|
+
}
|
|
92
|
+
})).json(); // eslint-disable-next-line max-len
|
|
67
93
|
|
|
68
|
-
|
|
69
|
-
|
|
94
|
+
const authFetch = (apiPath, options) => fetchAndCheckStatus(api(apiPath), { ...(options || {}),
|
|
95
|
+
headers: { ...(options || {}).headers,
|
|
96
|
+
Authorization: `Bearer ${token}`
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
const versions = await (await authFetch('api/version')).json();
|
|
101
|
+
|
|
102
|
+
for (const makeResult of makeResults) {
|
|
103
|
+
const {
|
|
104
|
+
artifacts,
|
|
105
|
+
packageJSON
|
|
106
|
+
} = makeResult;
|
|
107
|
+
const existingVersion = versions.find(version => version.name === packageJSON.version);
|
|
108
|
+
let channel = 'stable';
|
|
109
|
+
|
|
110
|
+
if (config.channel) {
|
|
111
|
+
// eslint-disable-next-line prefer-destructuring
|
|
112
|
+
channel = config.channel;
|
|
113
|
+
} else if (packageJSON.version.includes('beta')) {
|
|
114
|
+
channel = 'beta';
|
|
115
|
+
} else if (packageJSON.version.includes('alpha')) {
|
|
116
|
+
channel = 'alpha';
|
|
70
117
|
}
|
|
71
118
|
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
}
|
|
85
|
-
})).json(),
|
|
86
|
-
token = _ref.token;
|
|
87
|
-
|
|
88
|
-
const authFetch = (apiPath, options) => (0, _nodeFetch.default)(api(apiPath), Object.assign({}, options || {}, {
|
|
89
|
-
headers: Object.assign({}, (options || {}).headers, {
|
|
90
|
-
Authorization: `Bearer ${token}`
|
|
91
|
-
})
|
|
92
|
-
}));
|
|
93
|
-
|
|
94
|
-
const versions = yield (yield authFetch('api/version')).json();
|
|
95
|
-
var _iteratorNormalCompletion = true;
|
|
96
|
-
var _didIteratorError = false;
|
|
97
|
-
var _iteratorError = undefined;
|
|
98
|
-
|
|
99
|
-
try {
|
|
100
|
-
for (var _iterator = makeResults[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
|
101
|
-
const makeResult = _step.value;
|
|
102
|
-
const artifacts = makeResult.artifacts,
|
|
103
|
-
packageJSON = makeResult.packageJSON;
|
|
104
|
-
const existingVersion = versions.find(version => version.name === packageJSON.version);
|
|
105
|
-
let channel = 'stable';
|
|
106
|
-
|
|
107
|
-
if (config.channel) {
|
|
108
|
-
channel = config.channel;
|
|
109
|
-
} else if (packageJSON.version.includes('beta')) {
|
|
110
|
-
channel = 'beta';
|
|
111
|
-
} else if (packageJSON.version.includes('alpha')) {
|
|
112
|
-
channel = 'alpha';
|
|
119
|
+
if (!existingVersion) {
|
|
120
|
+
await authFetch('api/version', {
|
|
121
|
+
method: 'POST',
|
|
122
|
+
body: JSON.stringify({
|
|
123
|
+
channel: {
|
|
124
|
+
name: channel
|
|
125
|
+
},
|
|
126
|
+
name: packageJSON.version,
|
|
127
|
+
notes: ''
|
|
128
|
+
}),
|
|
129
|
+
headers: {
|
|
130
|
+
'Content-Type': 'application/json'
|
|
113
131
|
}
|
|
132
|
+
});
|
|
133
|
+
}
|
|
114
134
|
|
|
115
|
-
|
|
116
|
-
yield authFetch('api/version', {
|
|
117
|
-
method: 'POST',
|
|
118
|
-
body: JSON.stringify({
|
|
119
|
-
channel: {
|
|
120
|
-
name: channel
|
|
121
|
-
},
|
|
122
|
-
name: packageJSON.version,
|
|
123
|
-
notes: ''
|
|
124
|
-
}),
|
|
125
|
-
headers: {
|
|
126
|
-
'Content-Type': 'application/json'
|
|
127
|
-
}
|
|
128
|
-
});
|
|
129
|
-
}
|
|
135
|
+
let uploaded = 0;
|
|
130
136
|
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
const existingAsset = existingVersion.assets.find(asset => asset.name === _path.default.basename(artifactPath));
|
|
149
|
-
|
|
150
|
-
if (existingAsset) {
|
|
151
|
-
d('asset at path:', artifactPath, 'already exists on server');
|
|
152
|
-
uploaded += 1;
|
|
153
|
-
updateSpinner();
|
|
154
|
-
return;
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
try {
|
|
159
|
-
d('attempting to upload asset:', artifactPath);
|
|
160
|
-
const artifactForm = new _formData.default();
|
|
161
|
-
artifactForm.append('token', token);
|
|
162
|
-
artifactForm.append('version', packageJSON.version);
|
|
163
|
-
artifactForm.append('platform', ersPlatform(makeResult.platform, makeResult.arch));
|
|
164
|
-
artifactForm.append('file', _fsExtra.default.createReadStream(artifactPath));
|
|
165
|
-
yield authFetch('api/asset', {
|
|
166
|
-
method: 'POST',
|
|
167
|
-
body: artifactForm,
|
|
168
|
-
headers: artifactForm.getHeaders()
|
|
169
|
-
});
|
|
170
|
-
d('upload successful for asset:', artifactPath);
|
|
171
|
-
uploaded += 1;
|
|
172
|
-
updateSpinner();
|
|
173
|
-
resolve();
|
|
174
|
-
} catch (err) {
|
|
175
|
-
reject(err);
|
|
176
|
-
}
|
|
177
|
-
});
|
|
178
|
-
|
|
179
|
-
return function (_x2, _x3) {
|
|
180
|
-
return _ref3.apply(this, arguments);
|
|
181
|
-
};
|
|
182
|
-
}())));
|
|
183
|
-
});
|
|
184
|
-
|
|
185
|
-
return function (_x) {
|
|
186
|
-
return _ref2.apply(this, arguments);
|
|
187
|
-
};
|
|
188
|
-
}());
|
|
189
|
-
}
|
|
190
|
-
} catch (err) {
|
|
191
|
-
_didIteratorError = true;
|
|
192
|
-
_iteratorError = err;
|
|
193
|
-
} finally {
|
|
194
|
-
try {
|
|
195
|
-
if (!_iteratorNormalCompletion && _iterator.return != null) {
|
|
196
|
-
_iterator.return();
|
|
197
|
-
}
|
|
198
|
-
} finally {
|
|
199
|
-
if (_didIteratorError) {
|
|
200
|
-
throw _iteratorError;
|
|
137
|
+
const getText = () => `Uploading Artifacts ${uploaded}/${artifacts.length}`;
|
|
138
|
+
|
|
139
|
+
await (0, _asyncOra.asyncOra)(getText(), async uploadSpinner => {
|
|
140
|
+
const updateSpinner = () => {
|
|
141
|
+
uploadSpinner.text = getText();
|
|
142
|
+
};
|
|
143
|
+
|
|
144
|
+
await Promise.all(artifacts.map(async artifactPath => {
|
|
145
|
+
if (existingVersion) {
|
|
146
|
+
const existingAsset = existingVersion.assets.find(asset => asset.name === _path.default.basename(artifactPath));
|
|
147
|
+
|
|
148
|
+
if (existingAsset) {
|
|
149
|
+
d('asset at path:', artifactPath, 'already exists on server');
|
|
150
|
+
uploaded += 1;
|
|
151
|
+
updateSpinner();
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
201
154
|
}
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
155
|
+
|
|
156
|
+
d('attempting to upload asset:', artifactPath);
|
|
157
|
+
const artifactForm = new _formData.default();
|
|
158
|
+
artifactForm.append('token', token);
|
|
159
|
+
artifactForm.append('version', packageJSON.version);
|
|
160
|
+
artifactForm.append('platform', ersPlatform(makeResult.platform, makeResult.arch));
|
|
161
|
+
artifactForm.append('file', _fsExtra.default.createReadStream(artifactPath));
|
|
162
|
+
await authFetch('api/asset', {
|
|
163
|
+
method: 'POST',
|
|
164
|
+
body: artifactForm,
|
|
165
|
+
headers: artifactForm.getHeaders()
|
|
166
|
+
});
|
|
167
|
+
d('upload successful for asset:', artifactPath);
|
|
168
|
+
uploaded += 1;
|
|
169
|
+
updateSpinner();
|
|
170
|
+
}));
|
|
171
|
+
});
|
|
172
|
+
}
|
|
205
173
|
}
|
|
206
174
|
|
|
207
175
|
}
|
|
208
176
|
|
|
209
177
|
exports.default = PublisherERS;
|
|
210
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/PublisherERS.ts"],"names":["d","ersPlatform","platform","arch","PublisherERS","PublisherBase","publish","makeResults","config","baseUrl","username","password","api","apiPath","method","body","JSON","stringify","headers","json","token","authFetch","options","Object","assign","Authorization","versions","makeResult","artifacts","packageJSON","existingVersion","find","version","name","channel","includes","notes","uploaded","getText","length","uploadSpinner","updateSpinner","text","Promise","all","map","artifactPath","resolve","reject","existingAsset","assets","asset","path","basename","artifactForm","FormData","append","fs","createReadStream","getHeaders","err"],"mappings":"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","sourcesContent":["import PublisherBase, { PublisherOptions } from '@electron-forge/publisher-base';\nimport { asyncOra } from '@electron-forge/async-ora';\nimport { ForgePlatform, ForgeArch } from '@electron-forge/shared-types';\n\nimport debug from 'debug';\nimport fetch from 'node-fetch';\nimport FormData from 'form-data';\nimport fs from 'fs-extra';\nimport path from 'path';\n\nimport { PublisherERSConfig } from './Config';\n\nconst d = debug('electron-forge:publish:ers');\n\ninterface ERSVersion {\n  name: string;\n  assets: { name: string; }[];\n}\n\nexport const ersPlatform = (platform: ForgePlatform, arch: ForgeArch) => {\n  switch (platform) {\n    case 'darwin':\n      return 'osx_64';\n    case 'linux':\n      return arch === 'ia32' ? 'linux_32' : 'linux_64';\n    case 'win32':\n      return arch === 'ia32' ? 'windows_32' : 'windows_64';\n    default:\n      return platform;\n  }\n};\n\nexport default class PublisherERS extends PublisherBase<PublisherERSConfig> {\n  name = 'electron-release-server';\n\n  async publish({ makeResults }: PublisherOptions) {\n    const { config } = this;\n\n    if (!(config.baseUrl && config.username && config.password)) {\n      throw 'In order to publish to ERS you must set the \"electronReleaseServer.baseUrl\", \"electronReleaseServer.username\" and \"electronReleaseServer.password\" properties in your forge config. See the docs for more info'; // eslint-disable-line\n    }\n\n    d('attempting to authenticate to ERS');\n\n    const api = (apiPath: string) => `${config.baseUrl}/${apiPath}`;\n\n    const { token } = await (await fetch(api('api/auth/login'), {\n      method: 'POST',\n      body: JSON.stringify({\n        username: config.username,\n        password: config.password,\n      }),\n      headers: {\n        'Content-Type': 'application/json',\n      },\n    })).json();\n\n    const authFetch = (apiPath: string, options?: any) =>\n      fetch(api(apiPath), Object.assign({}, options || {}, {\n        headers: Object.assign({}, (options || {}).headers, { Authorization: `Bearer ${token}` }),\n      }));\n\n    const versions: ERSVersion[] = await (await authFetch('api/version')).json();\n\n    for (const makeResult of makeResults) {\n      const { artifacts, packageJSON } = makeResult;\n\n      const existingVersion = versions.find(version => version.name === packageJSON.version);\n\n      let channel = 'stable';\n      if (config.channel) {\n        channel = config.channel;\n      } else if (packageJSON.version.includes('beta')) {\n        channel = 'beta';\n      } else if (packageJSON.version.includes('alpha')) {\n        channel = 'alpha';\n      }\n\n      if (!existingVersion) {\n        await authFetch('api/version', {\n          method: 'POST',\n          body: JSON.stringify({\n            channel: {\n              name: channel,\n            },\n            name: packageJSON.version,\n            notes: '',\n          }),\n          headers: {\n            'Content-Type': 'application/json',\n          },\n        });\n      }\n\n      let uploaded = 0;\n      const getText = () => `Uploading Artifacts ${uploaded}/${artifacts.length}`;\n\n      await asyncOra(getText(), async (uploadSpinner) => {\n        const updateSpinner = () => {\n          uploadSpinner.text = getText();\n        };\n\n        await Promise.all(artifacts.map(artifactPath =>\n          new Promise(async (resolve, reject) => {\n            if (existingVersion) {\n              const existingAsset = existingVersion.assets.find(\n                asset => asset.name === path.basename(artifactPath),\n              );\n\n              if (existingAsset) {\n                d('asset at path:', artifactPath, 'already exists on server');\n                uploaded += 1;\n                updateSpinner();\n                return;\n              }\n            }\n            try {\n              d('attempting to upload asset:', artifactPath);\n              const artifactForm = new FormData();\n              artifactForm.append('token', token);\n              artifactForm.append('version', packageJSON.version);\n              artifactForm.append('platform', ersPlatform(makeResult.platform, makeResult.arch));\n              artifactForm.append('file', fs.createReadStream(artifactPath));\n              await authFetch('api/asset', {\n                method: 'POST',\n                body: artifactForm,\n                headers: artifactForm.getHeaders(),\n              });\n              d('upload successful for asset:', artifactPath);\n              uploaded += 1;\n              updateSpinner();\n              resolve();\n            } catch (err) {\n              reject(err);\n            }\n          }),\n        ));\n      });\n    }\n  }\n}\n"]}
|
|
178
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/PublisherERS.ts"],"names":["d","fetchAndCheckStatus","url","init","result","ok","Error","status","ersPlatform","platform","arch","PublisherERS","PublisherBase","publish","makeResults","config","baseUrl","username","password","api","apiPath","token","method","body","JSON","stringify","headers","json","authFetch","options","Authorization","versions","makeResult","artifacts","packageJSON","existingVersion","find","version","name","channel","includes","notes","uploaded","getText","length","uploadSpinner","updateSpinner","text","Promise","all","map","artifactPath","existingAsset","assets","asset","path","basename","artifactForm","FormData","append","fs","createReadStream","getHeaders"],"mappings":"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","sourcesContent":["import PublisherBase, { PublisherOptions } from '@electron-forge/publisher-base';\nimport { asyncOra } from '@electron-forge/async-ora';\nimport { ForgePlatform, ForgeArch } from '@electron-forge/shared-types';\n\nimport debug from 'debug';\nimport fetch, { RequestInfo, RequestInit, Response } from 'node-fetch';\nimport FormData from 'form-data';\nimport fs from 'fs-extra';\nimport path from 'path';\n\nimport { PublisherERSConfig } from './Config';\n\nconst d = debug('electron-forge:publish:ers');\n\ninterface ERSVersion {\n  name: string;\n  assets: { name: string }[];\n}\n\nconst fetchAndCheckStatus = async (url: RequestInfo, init?: RequestInit): Promise<Response> => {\n  const result = await fetch(url, init);\n  if (result.ok) {\n    // res.status >= 200 && res.status < 300\n    return result;\n  }\n  throw new Error(`ERS publish failed with status code: ${result.status} (${result.url})`);\n};\n\nexport const ersPlatform = (platform: ForgePlatform, arch: ForgeArch): string => {\n  switch (platform) {\n    case 'darwin':\n      return 'osx_64';\n    case 'linux':\n      return arch === 'ia32' ? 'linux_32' : 'linux_64';\n    case 'win32':\n      return arch === 'ia32' ? 'windows_32' : 'windows_64';\n    default:\n      return platform;\n  }\n};\n\nexport default class PublisherERS extends PublisherBase<PublisherERSConfig> {\n  name = 'electron-release-server';\n\n  async publish({ makeResults }: PublisherOptions): Promise<void> {\n    const { config } = this;\n\n    if (!(config.baseUrl && config.username && config.password)) {\n      throw new Error(\n        'In order to publish to ERS you must set the \"electronReleaseServer.baseUrl\", \"electronReleaseServer.username\" and \"electronReleaseServer.password\" properties in your Forge config. See the docs for more info'\n      );\n    }\n\n    d('attempting to authenticate to ERS');\n\n    const api = (apiPath: string) => `${config.baseUrl}/${apiPath}`;\n\n    const { token } = await (\n      await fetchAndCheckStatus(api('api/auth/login'), {\n        method: 'POST',\n        body: JSON.stringify({\n          username: config.username,\n          password: config.password,\n        }),\n        headers: {\n          'Content-Type': 'application/json',\n        },\n      })\n    ).json();\n\n    // eslint-disable-next-line max-len\n    const authFetch = (apiPath: string, options?: RequestInit) =>\n      fetchAndCheckStatus(api(apiPath), { ...(options || {}), headers: { ...(options || {}).headers, Authorization: `Bearer ${token}` } });\n\n    const versions: ERSVersion[] = await (await authFetch('api/version')).json();\n\n    for (const makeResult of makeResults) {\n      const { artifacts, packageJSON } = makeResult;\n\n      const existingVersion = versions.find((version) => version.name === packageJSON.version);\n\n      let channel = 'stable';\n      if (config.channel) {\n        // eslint-disable-next-line prefer-destructuring\n        channel = config.channel;\n      } else if (packageJSON.version.includes('beta')) {\n        channel = 'beta';\n      } else if (packageJSON.version.includes('alpha')) {\n        channel = 'alpha';\n      }\n\n      if (!existingVersion) {\n        await authFetch('api/version', {\n          method: 'POST',\n          body: JSON.stringify({\n            channel: {\n              name: channel,\n            },\n            name: packageJSON.version,\n            notes: '',\n          }),\n          headers: {\n            'Content-Type': 'application/json',\n          },\n        });\n      }\n\n      let uploaded = 0;\n      const getText = () => `Uploading Artifacts ${uploaded}/${artifacts.length}`;\n\n      await asyncOra(getText(), async (uploadSpinner) => {\n        const updateSpinner = () => {\n          uploadSpinner.text = getText();\n        };\n\n        await Promise.all(\n          artifacts.map(async (artifactPath) => {\n            if (existingVersion) {\n              const existingAsset = existingVersion.assets.find((asset) => asset.name === path.basename(artifactPath));\n\n              if (existingAsset) {\n                d('asset at path:', artifactPath, 'already exists on server');\n                uploaded += 1;\n                updateSpinner();\n                return;\n              }\n            }\n            d('attempting to upload asset:', artifactPath);\n            const artifactForm = new FormData();\n            artifactForm.append('token', token);\n            artifactForm.append('version', packageJSON.version);\n            artifactForm.append('platform', ersPlatform(makeResult.platform, makeResult.arch));\n            artifactForm.append('file', fs.createReadStream(artifactPath));\n            await authFetch('api/asset', {\n              method: 'POST',\n              body: artifactForm,\n              headers: artifactForm.getHeaders(),\n            });\n            d('upload successful for asset:', artifactPath);\n            uploaded += 1;\n            updateSpinner();\n          })\n        );\n      });\n    }\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,29 +1,28 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@electron-forge/publisher-electron-release-server",
|
|
3
|
-
"version": "6.0.0-beta.
|
|
3
|
+
"version": "6.0.0-beta.63",
|
|
4
4
|
"description": "Electron release server publisher for Electron Forge",
|
|
5
5
|
"repository": "https://github.com/electron-userland/electron-forge",
|
|
6
6
|
"author": "Samuel Attard",
|
|
7
7
|
"license": "MIT",
|
|
8
8
|
"main": "dist/PublisherERS.js",
|
|
9
9
|
"typings": "dist/PublisherERS.d.ts",
|
|
10
|
-
"scripts": {
|
|
11
|
-
"test": "exit 0"
|
|
12
|
-
},
|
|
13
10
|
"devDependencies": {
|
|
14
|
-
"chai": "^4.
|
|
15
|
-
"
|
|
11
|
+
"chai": "^4.3.3",
|
|
12
|
+
"fetch-mock": "^9.10.7",
|
|
13
|
+
"mocha": "^9.0.1",
|
|
14
|
+
"proxyquire": "^2.1.3"
|
|
16
15
|
},
|
|
17
16
|
"engines": {
|
|
18
|
-
"node": ">=
|
|
17
|
+
"node": ">= 12.13.0"
|
|
19
18
|
},
|
|
20
19
|
"dependencies": {
|
|
21
|
-
"@electron-forge/async-ora": "6.0.0-beta.
|
|
22
|
-
"@electron-forge/publisher-base": "6.0.0-beta.
|
|
23
|
-
"@electron-forge/shared-types": "6.0.0-beta.
|
|
24
|
-
"debug": "^3.
|
|
25
|
-
"form-data": "^
|
|
26
|
-
"fs-extra": "^
|
|
27
|
-
"node-fetch": "^2.
|
|
20
|
+
"@electron-forge/async-ora": "6.0.0-beta.63",
|
|
21
|
+
"@electron-forge/publisher-base": "6.0.0-beta.63",
|
|
22
|
+
"@electron-forge/shared-types": "6.0.0-beta.63",
|
|
23
|
+
"debug": "^4.3.1",
|
|
24
|
+
"form-data": "^4.0.0",
|
|
25
|
+
"fs-extra": "^10.0.0",
|
|
26
|
+
"node-fetch": "^2.6.0"
|
|
28
27
|
}
|
|
29
28
|
}
|
package/tsconfig.json
CHANGED
|
@@ -1,23 +1,27 @@
|
|
|
1
1
|
{
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
2
|
+
"compilerOptions": {
|
|
3
|
+
"module": "commonjs",
|
|
4
|
+
"target": "es2019",
|
|
5
|
+
"outDir": "dist",
|
|
6
|
+
"lib": [
|
|
7
|
+
"dom",
|
|
8
|
+
"es2019"
|
|
9
|
+
],
|
|
10
|
+
"sourceMap": true,
|
|
11
|
+
"rootDir": ".",
|
|
12
|
+
"experimentalDecorators": true,
|
|
13
|
+
"strict": true,
|
|
14
|
+
"esModuleInterop": true,
|
|
15
|
+
"declaration": true,
|
|
16
|
+
"typeRoots": [
|
|
17
|
+
"../../../node_modules/@types",
|
|
18
|
+
"../../../typings"
|
|
19
|
+
]
|
|
20
|
+
},
|
|
21
|
+
"exclude": [
|
|
22
|
+
"node_modules",
|
|
23
|
+
"dist",
|
|
24
|
+
"test",
|
|
25
|
+
"index.ts"
|
|
26
|
+
]
|
|
27
|
+
}
|