@electron-forge/publisher-electron-release-server 6.0.0-beta.7 → 6.0.0-beta.70

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 }: 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":"AAGA,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,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;CA+GhE;AAED,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,CAAC"}
@@ -1,210 +1,155 @@
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
-
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"));
12
13
  var _asyncOra = require("@electron-forge/async-ora");
13
-
14
+ var _publisherBase = require("@electron-forge/publisher-base");
14
15
  var _debug = _interopRequireDefault(require("debug"));
15
-
16
- var _nodeFetch = _interopRequireDefault(require("node-fetch"));
17
-
18
16
  var _formData = _interopRequireDefault(require("form-data"));
19
-
20
17
  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
- }
18
+ var _nodeFetch = _interopRequireDefault(require("node-fetch"));
19
+ var _config = require("./Config");
20
+ function _interopRequireDefault(obj) {
21
+ return obj && obj.__esModule ? obj : {
22
+ default: obj
23
+ };
24
+ }
25
+ const d = (0, _debug).default('electron-forge:publish:ers');
26
+ const fetchAndCheckStatus = async (url, init)=>{
27
+ const result = await (0, _nodeFetch).default(url, init);
28
+ if (result.ok) {
29
+ // res.status >= 200 && res.status < 300
30
+ return result;
31
+ }
32
+ throw new Error(`ERS publish failed with status code: ${result.status} (${result.url})`);
33
+ };
34
+ const ersPlatform = (platform, arch)=>{
35
+ switch(platform){
36
+ case 'darwin':
37
+ return 'osx_64';
38
+ case 'linux':
39
+ return arch === 'ia32' ? 'linux_32' : 'linux_64';
40
+ case 'win32':
41
+ return arch === 'ia32' ? 'windows_32' : 'windows_64';
42
+ default:
43
+ return platform;
44
+ }
44
45
  };
45
-
46
46
  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'
47
+ class PublisherERS extends _publisherBase.PublisherBase {
48
+ async publish({ makeResults }) {
49
+ const { config } = this;
50
+ if (!(config.baseUrl && config.username && config.password)) {
51
+ 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
52
  }
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: {
53
+ d('attempting to authenticate to ERS');
54
+ const api = (apiPath)=>`${config.baseUrl}/${apiPath}`
55
+ ;
56
+ const { token } = await (await fetchAndCheckStatus(api('api/auth/login'), {
57
+ method: 'POST',
58
+ body: JSON.stringify({
59
+ username: config.username,
60
+ password: config.password
61
+ }),
62
+ headers: {
126
63
  'Content-Type': 'application/json'
127
- }
64
+ }
65
+ })).json();
66
+ const authFetch = (apiPath, options)=>fetchAndCheckStatus(api(apiPath), {
67
+ ...options || {},
68
+ headers: {
69
+ ...(options || {}).headers,
70
+ Authorization: `Bearer ${token}`
71
+ }
72
+ })
73
+ ;
74
+ const versions = await (await authFetch('api/version')).json();
75
+ const flavor = config.flavor || 'default';
76
+ for (const makeResult of makeResults){
77
+ const { packageJSON } = makeResult;
78
+ const artifacts = makeResult.artifacts.filter((artifactPath)=>_path.default.basename(artifactPath).toLowerCase() !== 'releases'
79
+ );
80
+ const existingVersion = versions.find((version)=>{
81
+ return version.name === packageJSON.version && (!version.flavor || version.flavor === flavor);
128
82
  });
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;
83
+ let channel = 'stable';
84
+ if (config.channel) {
85
+ channel = config.channel;
86
+ } else if (packageJSON.version.includes('beta')) {
87
+ channel = 'beta';
88
+ } else if (packageJSON.version.includes('alpha')) {
89
+ channel = 'alpha';
90
+ }
91
+ if (!existingVersion) {
92
+ await authFetch('api/version', {
93
+ method: 'POST',
94
+ body: JSON.stringify({
95
+ channel: {
96
+ name: channel
97
+ },
98
+ flavor: config.flavor,
99
+ name: packageJSON.version,
100
+ notes: ''
101
+ }),
102
+ headers: {
103
+ 'Content-Type': 'application/json'
104
+ }
105
+ });
106
+ }
107
+ let uploaded = 0;
108
+ const getText = ()=>`Uploading Artifacts ${uploaded}/${artifacts.length}`
109
+ ;
110
+ await (0, _asyncOra).asyncOra(getText(), async (uploadSpinner)=>{
111
+ const updateSpinner = ()=>{
112
+ uploadSpinner.text = getText();
113
+ };
114
+ await Promise.all(artifacts.map(async (artifactPath)=>{
115
+ if (existingVersion) {
116
+ const existingAsset = existingVersion.assets.find((asset)=>asset.name === _path.default.basename(artifactPath)
117
+ );
118
+ if (existingAsset) {
119
+ d('asset at path:', artifactPath, 'already exists on server');
120
+ uploaded += 1;
121
+ updateSpinner();
122
+ return;
123
+ }
155
124
  }
156
- }
157
-
158
- try {
159
125
  d('attempting to upload asset:', artifactPath);
160
126
  const artifactForm = new _formData.default();
161
127
  artifactForm.append('token', token);
162
128
  artifactForm.append('version', packageJSON.version);
163
129
  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()
130
+ // see https://github.com/form-data/form-data/issues/426
131
+ const fileOptions = {
132
+ knownLength: _fsExtra.default.statSync(artifactPath).size
133
+ };
134
+ artifactForm.append('file', _fsExtra.default.createReadStream(artifactPath), fileOptions);
135
+ await authFetch('api/asset', {
136
+ method: 'POST',
137
+ body: artifactForm,
138
+ headers: artifactForm.getHeaders()
169
139
  });
170
140
  d('upload successful for asset:', artifactPath);
171
141
  uploaded += 1;
172
142
  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
- }())));
143
+ }));
183
144
  });
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
- }
202
145
  }
203
- }
204
- })();
205
- }
206
-
146
+ }
147
+ constructor(...args){
148
+ super(...args);
149
+ this.name = 'electron-release-server';
150
+ }
207
151
  }
208
-
209
152
  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"]}
153
+ exports.PublisherERS = PublisherERS;
154
+
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/PublisherERS.ts"],"sourcesContent":["import path from 'path';\n\nimport { asyncOra } from '@electron-forge/async-ora';\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 }: 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 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\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            updateSpinner();\n          })\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","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","getText","length","asyncOra","uploadSpinner","updateSpinner","text","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,29 @@
1
1
  {
2
2
  "name": "@electron-forge/publisher-electron-release-server",
3
- "version": "6.0.0-beta.7",
3
+ "version": "6.0.0-beta.70",
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.7",
22
- "@electron-forge/publisher-base": "6.0.0-beta.7",
23
- "@electron-forge/shared-types": "6.0.0-beta.7",
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/async-ora": "6.0.0-beta.70",
22
+ "@electron-forge/publisher-base": "6.0.0-beta.70",
23
+ "@electron-forge/shared-types": "6.0.0-beta.70",
24
+ "debug": "^4.3.1",
25
+ "form-data": "^4.0.0",
26
+ "fs-extra": "^10.0.0",
27
+ "node-fetch": "^2.6.7"
28
28
  }
29
29
  }
package/src/Config.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  export interface PublisherERSConfig {
2
2
  /**
3
3
  * The base URL of your instance of ERS.
4
- *
4
+ *
5
5
  * E.g. https://my-update.server.com
6
6
  */
7
7
  baseUrl: string;
@@ -16,11 +16,19 @@ export interface PublisherERSConfig {
16
16
  /**
17
17
  * The release channel you want to send artifacts to, normally something like
18
18
  * "stable", "beta" or "alpha".
19
- *
19
+ *
20
20
  * If left unspecified we will try to infer the channel from your version
21
21
  * field in your package.json.
22
- *
22
+ *
23
23
  * Default: stable
24
24
  */
25
25
  channel?: string;
26
+
27
+ /**
28
+ * The "flavor" of the binary that you want to release to.
29
+ * This is useful if you want to provide multiple versions
30
+ * of the same application version (e.g. full and lite)
31
+ * to end users.
32
+ */
33
+ flavor?: string;
26
34
  }