@electron-forge/publisher-electron-release-server 6.0.0-beta.9 → 6.0.1

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/README.md CHANGED
@@ -1,21 +1,24 @@
1
- # Electron Release Server
1
+ ## publisher-electron-release-server
2
2
 
3
- The Electron Release Server target publishes all your artifacts to a hosted instance of [Electron Release Server](https://github.com/ArekSredzki/electron-release-server).
3
+ `@electron-forge/publisher-electron-release-server` publishes all your artifacts to a hosted instance of [Electron Release Server](https://github.com/ArekSredzki/electron-release-server) where users will be able to download them.
4
4
 
5
5
  Please note that Electron Release Server is a community powered project and is not associated with Electron Forge or the Electron project directly.
6
6
 
7
- Configuration options are documented in [`PublisherERSConfig`](https://js.electronforge.io/publisher/electron-release-server/interfaces/publisherersconfig.html)
7
+ Configuration options are documented in [`PublisherERSConfig`](https://js.electronforge.io/interfaces/_electron_forge_publisher_electron_release_server.PublisherERSConfig.html).
8
8
 
9
- ### Usage
10
9
 
11
- ```javascript
12
- {
13
- name: '@electron-forge/publisher-electron-release-server',
14
- config: {
15
- baseUrl: 'https://update.server.com',
16
- username: 'admin',
17
- password: 'admin'
18
- }
10
+ ```javascript title=forge.config.js
11
+ module.exports = {
12
+ // ...
13
+ publishers: [
14
+ {
15
+ name: '@electron-forge/publisher-electron-release-server',
16
+ config: {
17
+ baseUrl: 'https://update.server.com',
18
+ username: 'admin',
19
+ password: 'admin'
20
+ }
21
+ }
22
+ ]
19
23
  }
20
- ```
21
-
24
+ ```
package/dist/Config.d.ts CHANGED
@@ -23,4 +23,12 @@ export interface PublisherERSConfig {
23
23
  * Default: stable
24
24
  */
25
25
  channel?: string;
26
+ /**
27
+ * The "flavor" of the binary that you want to release to.
28
+ * This is useful if you want to provide multiple versions
29
+ * of the same application version (e.g. full and lite)
30
+ * to end users.
31
+ */
32
+ flavor?: string;
26
33
  }
34
+ //# sourceMappingURL=Config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Config.d.ts","sourceRoot":"","sources":["../src/Config.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,kBAAkB;IACjC;;;;OAIG;IACH,OAAO,EAAE,MAAM,CAAC;IAChB;;OAEG;IACH,QAAQ,EAAE,MAAM,CAAC;IACjB;;OAEG;IACH,QAAQ,EAAE,MAAM,CAAC;IACjB;;;;;;;;OAQG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB;;;;;OAKG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB"}
package/dist/Config.js CHANGED
@@ -1,4 +1,6 @@
1
1
  "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
2
5
 
3
- require("source-map-support/register");
4
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbXX0=
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiJ9
@@ -1,8 +1,10 @@
1
- import PublisherBase, { PublisherOptions } from '@electron-forge/publisher-base';
2
- import { ForgePlatform, ForgeArch } from '@electron-forge/shared-types';
1
+ import { PublisherBase, PublisherOptions } from '@electron-forge/publisher-base';
2
+ import { ForgeArch, ForgePlatform } from '@electron-forge/shared-types';
3
3
  import { PublisherERSConfig } from './Config';
4
- export declare const ersPlatform: (platform: ForgePlatform, arch: ForgeArch) => "mas" | "osx_64" | "linux_32" | "linux_64" | "windows_32" | "windows_64";
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, setStatusLine }: PublisherOptions): Promise<void>;
8
8
  }
9
+ export { PublisherERS, PublisherERSConfig };
10
+ //# sourceMappingURL=PublisherERS.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PublisherERS.d.ts","sourceRoot":"","sources":["../src/PublisherERS.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AACjF,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAMxE,OAAO,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAmB9C,eAAO,MAAM,WAAW,aAAc,aAAa,QAAQ,SAAS,KAAG,MAWtE,CAAC;AAEF,MAAM,CAAC,OAAO,OAAO,YAAa,SAAQ,aAAa,CAAC,kBAAkB,CAAC;IACzE,IAAI,SAA6B;IAE3B,OAAO,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;CA0G/E;AAED,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,CAAC"}
@@ -1,210 +1,150 @@
1
1
  "use strict";
2
-
3
2
  Object.defineProperty(exports, "__esModule", {
4
- value: true
3
+ value: true
5
4
  });
6
- exports.default = exports.ersPlatform = void 0;
7
-
8
- require("source-map-support/register");
9
-
10
- var _publisherBase = _interopRequireDefault(require("@electron-forge/publisher-base"));
11
-
12
- var _asyncOra = require("@electron-forge/async-ora");
13
-
5
+ Object.defineProperty(exports, "PublisherERSConfig", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return _config.PublisherERSConfig;
9
+ }
10
+ });
11
+ exports.PublisherERS = exports.default = exports.ersPlatform = void 0;
12
+ var _path = _interopRequireDefault(require("path"));
13
+ var _publisherBase = require("@electron-forge/publisher-base");
14
14
  var _debug = _interopRequireDefault(require("debug"));
15
-
16
- var _nodeFetch = _interopRequireDefault(require("node-fetch"));
17
-
18
15
  var _formData = _interopRequireDefault(require("form-data"));
19
-
20
16
  var _fsExtra = _interopRequireDefault(require("fs-extra"));
21
-
22
- var _path = _interopRequireDefault(require("path"));
23
-
24
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
25
-
26
- function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } function _next(value) { step("next", value); } function _throw(err) { step("throw", err); } _next(); }); }; }
27
-
28
- const d = (0, _debug.default)('electron-forge:publish:ers');
29
-
30
- const ersPlatform = (platform, arch) => {
31
- switch (platform) {
32
- case 'darwin':
33
- return 'osx_64';
34
-
35
- case 'linux':
36
- return arch === 'ia32' ? 'linux_32' : 'linux_64';
37
-
38
- case 'win32':
39
- return arch === 'ia32' ? 'windows_32' : 'windows_64';
40
-
41
- default:
42
- return platform;
43
- }
17
+ var _nodeFetch = _interopRequireDefault(require("node-fetch"));
18
+ var _config = require("./Config");
19
+ function _interopRequireDefault(obj) {
20
+ return obj && obj.__esModule ? obj : {
21
+ default: obj
22
+ };
23
+ }
24
+ const d = (0, _debug).default('electron-forge:publish:ers');
25
+ const fetchAndCheckStatus = async (url, init)=>{
26
+ const result = await (0, _nodeFetch).default(url, init);
27
+ if (result.ok) {
28
+ // res.status >= 200 && res.status < 300
29
+ return result;
30
+ }
31
+ throw new Error(`ERS publish failed with status code: ${result.status} (${result.url})`);
32
+ };
33
+ const ersPlatform = (platform, arch)=>{
34
+ switch(platform){
35
+ case 'darwin':
36
+ return 'osx_64';
37
+ case 'linux':
38
+ return arch === 'ia32' ? 'linux_32' : 'linux_64';
39
+ case 'win32':
40
+ return arch === 'ia32' ? 'windows_32' : 'windows_64';
41
+ default:
42
+ return platform;
43
+ }
44
44
  };
45
-
46
45
  exports.ersPlatform = ersPlatform;
47
-
48
- class PublisherERS extends _publisherBase.default {
49
- constructor(...args) {
50
- var _temp;
51
-
52
- return _temp = super(...args), Object.defineProperty(this, "name", {
53
- configurable: true,
54
- enumerable: true,
55
- writable: true,
56
- value: 'electron-release-server'
57
- }), _temp;
58
- }
59
-
60
- publish({
61
- makeResults
62
- }) {
63
- var _this = this;
64
-
65
- return _asyncToGenerator(function* () {
66
- const config = _this.config;
67
-
68
- if (!(config.baseUrl && config.username && config.password)) {
69
- 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
70
- }
71
-
72
- d('attempting to authenticate to ERS');
73
-
74
- const api = apiPath => `${config.baseUrl}/${apiPath}`;
75
-
76
- const _ref = yield (yield (0, _nodeFetch.default)(api('api/auth/login'), {
77
- method: 'POST',
78
- body: JSON.stringify({
79
- username: config.username,
80
- password: config.password
81
- }),
82
- headers: {
83
- 'Content-Type': 'application/json'
46
+ class PublisherERS extends _publisherBase.PublisherBase {
47
+ async publish({ makeResults , setStatusLine }) {
48
+ const { config } = this;
49
+ if (!(config.baseUrl && config.username && config.password)) {
50
+ 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');
84
51
  }
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';
113
- }
114
-
115
- if (!existingVersion) {
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: {
52
+ d('attempting to authenticate to ERS');
53
+ const api = (apiPath)=>`${config.baseUrl}/${apiPath}`
54
+ ;
55
+ const { token } = await (await fetchAndCheckStatus(api('api/auth/login'), {
56
+ method: 'POST',
57
+ body: JSON.stringify({
58
+ username: config.username,
59
+ password: config.password
60
+ }),
61
+ headers: {
126
62
  'Content-Type': 'application/json'
127
- }
63
+ }
64
+ })).json();
65
+ const authFetch = (apiPath, options)=>fetchAndCheckStatus(api(apiPath), {
66
+ ...options || {},
67
+ headers: {
68
+ ...(options || {}).headers,
69
+ Authorization: `Bearer ${token}`
70
+ }
71
+ })
72
+ ;
73
+ const versions = await (await authFetch('api/version')).json();
74
+ const flavor = config.flavor || 'default';
75
+ for (const makeResult of makeResults){
76
+ const { packageJSON } = makeResult;
77
+ const artifacts = makeResult.artifacts.filter((artifactPath)=>_path.default.basename(artifactPath).toLowerCase() !== 'releases'
78
+ );
79
+ const existingVersion = versions.find((version)=>{
80
+ return version.name === packageJSON.version && (!version.flavor || version.flavor === flavor);
128
81
  });
129
- }
130
-
131
- let uploaded = 0;
132
-
133
- const getText = () => `Uploading Artifacts ${uploaded}/${artifacts.length}`;
134
-
135
- yield (0, _asyncOra.asyncOra)(getText(),
136
- /*#__PURE__*/
137
- function () {
138
- var _ref2 = _asyncToGenerator(function* (uploadSpinner) {
139
- const updateSpinner = () => {
140
- uploadSpinner.text = getText();
141
- };
142
-
143
- yield Promise.all(artifacts.map(artifactPath => new Promise(
144
- /*#__PURE__*/
145
- function () {
146
- var _ref3 = _asyncToGenerator(function* (resolve, reject) {
147
- if (existingVersion) {
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;
82
+ let channel = 'stable';
83
+ if (config.channel) {
84
+ channel = config.channel;
85
+ } else if (packageJSON.version.includes('beta')) {
86
+ channel = 'beta';
87
+ } else if (packageJSON.version.includes('alpha')) {
88
+ channel = 'alpha';
89
+ }
90
+ if (!existingVersion) {
91
+ await authFetch('api/version', {
92
+ method: 'POST',
93
+ body: JSON.stringify({
94
+ channel: {
95
+ name: channel
96
+ },
97
+ flavor: config.flavor,
98
+ name: packageJSON.version,
99
+ notes: ''
100
+ }),
101
+ headers: {
102
+ 'Content-Type': 'application/json'
155
103
  }
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
104
  });
178
-
179
- return function (_x2, _x3) {
180
- return _ref3.apply(this, arguments);
105
+ }
106
+ let uploaded = 0;
107
+ const updateStatusLine = ()=>setStatusLine(`Uploading distributable (${uploaded}/${artifacts.length})`)
108
+ ;
109
+ updateStatusLine();
110
+ await Promise.all(artifacts.map(async (artifactPath)=>{
111
+ if (existingVersion) {
112
+ const existingAsset = existingVersion.assets.find((asset)=>asset.name === _path.default.basename(artifactPath)
113
+ );
114
+ if (existingAsset) {
115
+ d('asset at path:', artifactPath, 'already exists on server');
116
+ uploaded += 1;
117
+ updateStatusLine();
118
+ return;
119
+ }
120
+ }
121
+ d('attempting to upload asset:', artifactPath);
122
+ const artifactForm = new _formData.default();
123
+ artifactForm.append('token', token);
124
+ artifactForm.append('version', packageJSON.version);
125
+ artifactForm.append('platform', ersPlatform(makeResult.platform, makeResult.arch));
126
+ // see https://github.com/form-data/form-data/issues/426
127
+ const fileOptions = {
128
+ knownLength: _fsExtra.default.statSync(artifactPath).size
181
129
  };
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;
201
- }
130
+ artifactForm.append('file', _fsExtra.default.createReadStream(artifactPath), fileOptions);
131
+ await authFetch('api/asset', {
132
+ method: 'POST',
133
+ body: artifactForm,
134
+ headers: artifactForm.getHeaders()
135
+ });
136
+ d('upload successful for asset:', artifactPath);
137
+ uploaded += 1;
138
+ updateStatusLine();
139
+ }));
202
140
  }
203
- }
204
- })();
205
- }
206
-
141
+ }
142
+ constructor(...args){
143
+ super(...args);
144
+ this.name = 'electron-release-server';
145
+ }
207
146
  }
208
-
209
147
  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"]}
148
+ exports.PublisherERS = PublisherERS;
149
+
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/PublisherERS.ts"],"sourcesContent":["import path from 'path';\n\nimport { PublisherBase, PublisherOptions } from '@electron-forge/publisher-base';\nimport { ForgeArch, ForgePlatform } from '@electron-forge/shared-types';\nimport debug from 'debug';\nimport FormData from 'form-data';\nimport fs from 'fs-extra';\nimport fetch, { RequestInfo, RequestInit, Response } from 'node-fetch';\n\nimport { PublisherERSConfig } from './Config';\n\nconst d = debug('electron-forge:publish:ers');\n\ninterface ERSVersion {\n  name: string;\n  assets: { name: string }[];\n  flavor?: 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, setStatusLine }: 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    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    const flavor = config.flavor || 'default';\n\n    for (const makeResult of makeResults) {\n      const { packageJSON } = makeResult;\n      const artifacts = makeResult.artifacts.filter((artifactPath) => path.basename(artifactPath).toLowerCase() !== 'releases');\n\n      const existingVersion = versions.find((version) => {\n        return version.name === packageJSON.version && (!version.flavor || version.flavor === flavor);\n      });\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            flavor: config.flavor,\n            name: packageJSON.version,\n            notes: '',\n          }),\n          headers: {\n            'Content-Type': 'application/json',\n          },\n        });\n      }\n\n      let uploaded = 0;\n      const updateStatusLine = () => setStatusLine(`Uploading distributable (${uploaded}/${artifacts.length})`);\n      updateStatusLine();\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              updateStatusLine();\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\n          // see https://github.com/form-data/form-data/issues/426\n          const fileOptions = {\n            knownLength: fs.statSync(artifactPath).size,\n          };\n          artifactForm.append('file', fs.createReadStream(artifactPath), fileOptions);\n\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          updateStatusLine();\n        })\n      );\n    }\n  }\n}\n\nexport { PublisherERS, PublisherERSConfig };\n"],"names":["PublisherERSConfig","d","debug","fetchAndCheckStatus","url","init","result","fetch","ok","Error","status","ersPlatform","platform","arch","PublisherERS","PublisherBase","publish","makeResults","setStatusLine","config","baseUrl","username","password","api","apiPath","token","method","body","JSON","stringify","headers","json","authFetch","options","Authorization","versions","flavor","makeResult","packageJSON","artifacts","filter","artifactPath","path","basename","toLowerCase","existingVersion","find","version","name","channel","includes","notes","uploaded","updateStatusLine","length","Promise","all","map","existingAsset","assets","asset","artifactForm","FormData","append","fileOptions","knownLength","fs","statSync","size","createReadStream","getHeaders"],"mappings":"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"}
package/index.ts ADDED
@@ -0,0 +1,5 @@
1
+ // ⚠️ AUTOGENERATED ⚠️ AUTOGENERATED ⚠️ AUTOGENERATED ⚠️
2
+ // This file was automatically generated by `tools/gen-ts-glue.ts`. Do not modify directly if you want to keep your changes.
3
+ export * from "./src/PublisherERS";
4
+ import defaultExport from "./src/PublisherERS";
5
+ export default defaultExport;
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.9",
3
+ "version": "6.0.1",
4
4
  "description": "Electron release server publisher for Electron Forge",
5
- "repository": "https://github.com/electron-userland/electron-forge",
5
+ "repository": "https://github.com/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.0.0",
15
- "mocha": "^5.0.0"
11
+ "chai": "^4.3.3",
12
+ "fetch-mock": "^9.10.7",
13
+ "mocha": "^9.0.1",
14
+ "proxyquire": "^2.1.3",
15
+ "sinon": "^13.0.1"
16
16
  },
17
17
  "engines": {
18
- "node": ">= 6.0"
18
+ "node": ">= 14.17.5"
19
19
  },
20
20
  "dependencies": {
21
- "@electron-forge/async-ora": "6.0.0-beta.9",
22
- "@electron-forge/publisher-base": "6.0.0-beta.9",
23
- "@electron-forge/shared-types": "6.0.0-beta.9",
24
- "debug": "^3.0.0",
25
- "form-data": "^2.1.4",
26
- "fs-extra": "^5.0.0",
27
- "node-fetch": "^2.0.0"
21
+ "@electron-forge/publisher-base": "6.0.1",
22
+ "@electron-forge/shared-types": "6.0.1",
23
+ "debug": "^4.3.1",
24
+ "form-data": "^4.0.0",
25
+ "fs-extra": "^10.0.0",
26
+ "node-fetch": "^2.6.7"
28
27
  }
29
28
  }
package/tsconfig.json CHANGED
@@ -1,23 +1,39 @@
1
1
  {
2
- "compilerOptions": {
3
- "module": "commonjs",
4
- "target": "es6",
5
- "outDir": "dist",
6
- "lib": [
7
- "es6",
8
- "dom",
9
- "es7"
10
- ],
11
- "sourceMap": true,
12
- "rootDir": "src",
13
- "experimentalDecorators": true,
14
- "strict": true,
15
- "esModuleInterop": true,
16
- "declaration": true
17
- },
18
- "exclude": [
19
- "node_modules",
20
- "dist",
21
- "test"
22
- ]
2
+ "//": "⚠️ AUTOGENERATED ⚠️ This file was automatically generated by tools/gen-tsconfigs.ts, do not edit manually.",
3
+ "compilerOptions": {
4
+ "module": "commonjs",
5
+ "target": "es2019",
6
+ "outDir": "dist",
7
+ "lib": [
8
+ "dom",
9
+ "es2019"
10
+ ],
11
+ "sourceMap": true,
12
+ "rootDir": "src",
13
+ "experimentalDecorators": true,
14
+ "strict": true,
15
+ "esModuleInterop": true,
16
+ "declaration": true,
17
+ "composite": true,
18
+ "declarationMap": true,
19
+ "typeRoots": [
20
+ "../../../typings",
21
+ "../../../node_modules/@types"
22
+ ]
23
+ },
24
+ "exclude": [
25
+ "node_modules",
26
+ "dist",
27
+ "test",
28
+ "index.ts",
29
+ "tmpl"
30
+ ],
31
+ "references": [
32
+ {
33
+ "path": "../base"
34
+ },
35
+ {
36
+ "path": "../../utils/types"
37
+ }
38
+ ]
23
39
  }