npm-update-package 0.36.0 → 0.39.0

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "npm-update-package",
3
- "version": "0.36.0",
3
+ "version": "0.39.0",
4
4
  "description": "CLI tool for creating pull requests to update npm packages",
5
5
  "scripts": {
6
6
  "build": "tsc --project tsconfig.build.json",
@@ -36,7 +36,7 @@
36
36
  "@types/parse-github-url": "1.0.0",
37
37
  "@types/semver": "7.3.9",
38
38
  "@typescript-eslint/eslint-plugin": "5.12.1",
39
- "eslint": "8.9.0",
39
+ "eslint": "8.10.0",
40
40
  "eslint-config-standard-with-typescript": "21.0.1",
41
41
  "eslint-plugin-import": "2.25.4",
42
42
  "eslint-plugin-jest": "26.1.1",
@@ -75,6 +75,22 @@ class GitHub {
75
75
  });
76
76
  return data;
77
77
  }
78
+ async fetchReleases({ owner, repo }) {
79
+ const releases = [];
80
+ for (let page = 1;; page++) {
81
+ const { data } = await this.octokit.repos.listReleases({
82
+ owner,
83
+ repo,
84
+ per_page: 100,
85
+ page
86
+ });
87
+ if (data.length === 0) {
88
+ break;
89
+ }
90
+ releases.push(...data);
91
+ }
92
+ return releases;
93
+ }
78
94
  async fetchRepository({ owner, repo }) {
79
95
  const { data } = await this.octokit.repos.get({
80
96
  owner,
@@ -3,9 +3,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.createGitHub = void 0;
4
4
  const createOctokit_1 = require("./createOctokit");
5
5
  const GitHub_1 = require("./GitHub");
6
- const createGitHub = ({ repository, token }) => {
6
+ const createGitHub = ({ host, token }) => {
7
7
  const octokit = (0, createOctokit_1.createOctokit)({
8
- repository,
8
+ host,
9
9
  token
10
10
  });
11
11
  return new GitHub_1.GitHub(octokit);
@@ -6,22 +6,24 @@ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.createOctokit = void 0;
7
7
  const rest_1 = require("@octokit/rest");
8
8
  const package_json_1 = __importDefault(require("../../package.json"));
9
- const createOctokit = ({ repository, token }) => {
10
- const { host } = repository.url;
11
- const auth = `token ${token}`;
9
+ const createOctokit = ({ host, token }) => {
12
10
  const userAgent = `${package_json_1.default.name}/${package_json_1.default.version}`;
13
- if (host === 'github.com') {
11
+ if (token === undefined) {
14
12
  return new rest_1.Octokit({
15
- auth,
16
13
  userAgent
17
14
  });
18
15
  }
19
- else {
16
+ const auth = `token ${token}`;
17
+ if (host === 'github.com') {
20
18
  return new rest_1.Octokit({
21
19
  auth,
22
- userAgent,
23
- baseUrl: `https://${host}/api/v3`
20
+ userAgent
24
21
  });
25
22
  }
23
+ return new rest_1.Octokit({
24
+ auth,
25
+ userAgent,
26
+ baseUrl: `https://${host}/api/v3`
27
+ });
26
28
  };
27
29
  exports.createOctokit = createOctokit;
@@ -15,3 +15,4 @@ __exportStar(require("./createGitHub"), exports);
15
15
  __exportStar(require("./errors"), exports);
16
16
  __exportStar(require("./label"), exports);
17
17
  __exportStar(require("./pull-request"), exports);
18
+ __exportStar(require("./releases"), exports);
@@ -0,0 +1,110 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.PullRequestBodyCreator = void 0;
7
+ const package_json_1 = __importDefault(require("../../../../package.json"));
8
+ const file_1 = require("../../../file");
9
+ const json_1 = require("../../../json");
10
+ const package_json_2 = require("../../../package-json");
11
+ const metadata_1 = require("../metadata");
12
+ class PullRequestBodyCreator {
13
+ constructor({ releasesFetcher }) {
14
+ this.releasesFetcher = releasesFetcher;
15
+ }
16
+ async create(outdatedPackage) {
17
+ const gitRepo = await this.extractRepository(outdatedPackage);
18
+ const outdatedPackagesTable = this.createOutdatedPackagesTable({
19
+ outdatedPackage,
20
+ gitRepo
21
+ });
22
+ const metadataSection = this.createMetadataSection(outdatedPackage);
23
+ const footer = this.createFooter();
24
+ const body = `This PR updates these packages:
25
+
26
+ ${outdatedPackagesTable}
27
+
28
+ ---
29
+ ${metadataSection}
30
+
31
+ ---
32
+ ${footer}`;
33
+ if (gitRepo === undefined) {
34
+ return body;
35
+ }
36
+ const releaseNotesSection = await this.createReleaseNotesSection({
37
+ outdatedPackage,
38
+ gitRepo
39
+ });
40
+ if (releaseNotesSection === undefined) {
41
+ return body;
42
+ }
43
+ return `This PR updates these packages:
44
+
45
+ ${outdatedPackagesTable}
46
+
47
+ ${releaseNotesSection}
48
+
49
+ ---
50
+ ${metadataSection}
51
+
52
+ ---
53
+ ${footer}`;
54
+ }
55
+ async extractRepository(outdatedPackage) {
56
+ const packageJson = await (0, file_1.readFile)(`node_modules/${outdatedPackage.name}/package.json`);
57
+ const pkg = (0, package_json_2.parsePackageJson)(packageJson);
58
+ return (0, package_json_2.extractRepository)(pkg);
59
+ }
60
+ async createReleaseNotesSection({ outdatedPackage, gitRepo }) {
61
+ const releases = await this.releasesFetcher.fetch({
62
+ gitRepo,
63
+ from: outdatedPackage.currentVersion,
64
+ to: outdatedPackage.newVersion
65
+ });
66
+ if (releases.length === 0) {
67
+ return undefined;
68
+ }
69
+ const items = releases.map(release => `- [${release.tag_name}](${release.html_url})`);
70
+ return `## Release notes
71
+
72
+ ${items.join('\n')}`;
73
+ }
74
+ createOutdatedPackagesTable({ outdatedPackage, gitRepo }) {
75
+ const packageName = outdatedPackage.name;
76
+ const packageLink = `[${packageName}](https://www.npmjs.com/package/${packageName})`;
77
+ const repositoryLink = gitRepo !== undefined ? `[${gitRepo.owner}/${gitRepo.name}](${gitRepo.url.toString()})` : '-';
78
+ const level = outdatedPackage.level;
79
+ const currentVersion = outdatedPackage.currentVersion.version;
80
+ const currentVersionLink = `[\`${currentVersion}\`](https://www.npmjs.com/package/${packageName}/v/${currentVersion})`;
81
+ const newVersion = outdatedPackage.newVersion.version;
82
+ const newVersionLink = `[\`${newVersion}\`](https://www.npmjs.com/package/${packageName}/v/${newVersion})`;
83
+ const diffLink = `[diff](https://renovatebot.com/diffs/npm/${packageName}/${currentVersion}/${newVersion})`;
84
+ const version = `${currentVersionLink} -> ${newVersionLink} (${diffLink})`;
85
+ return `|Package|Repository|Level|Version|
86
+ |---|---|---|---|
87
+ |${packageLink}|${repositoryLink}|${level}|${version}|`;
88
+ }
89
+ createMetadataSection(outdatedPackage) {
90
+ const metadata = (0, metadata_1.createPullRequestMetadata)([outdatedPackage]);
91
+ const json = (0, json_1.toJSON)(metadata, { pretty: true });
92
+ return `<details>
93
+ <summary>Metadata</summary>
94
+
95
+ **Don't remove or edit this section because it will be used by npm-update-package.**
96
+
97
+ <div id="npm-update-package-metadata">
98
+
99
+ \`\`\`json
100
+ ${json}
101
+ \`\`\`
102
+
103
+ </div>
104
+ </details>`;
105
+ }
106
+ createFooter() {
107
+ return `This PR has been generated by [${package_json_1.default.name}](${package_json_1.default.homepage}) v${package_json_1.default.version}`;
108
+ }
109
+ }
110
+ exports.PullRequestBodyCreator = PullRequestBodyCreator;
@@ -1,20 +1,20 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.PullRequestCreator = void 0;
4
- const createPullRequestBody_1 = require("./createPullRequestBody");
5
4
  class PullRequestCreator {
6
- constructor({ github, gitRepo, githubRepo, pullRequestTitleCreator, logger, reviewers }) {
5
+ constructor({ github, gitRepo, githubRepo, pullRequestTitleCreator, pullRequestBodyCreator, logger, reviewers }) {
7
6
  this.github = github;
8
7
  this.gitRepo = gitRepo;
9
8
  this.githubRepo = githubRepo;
10
9
  this.pullRequestTitleCreator = pullRequestTitleCreator;
10
+ this.pullRequestBodyCreator = pullRequestBodyCreator;
11
11
  this.logger = logger;
12
12
  this.reviewers = reviewers;
13
13
  }
14
14
  async create({ outdatedPackage, branchName }) {
15
15
  const title = this.pullRequestTitleCreator.create(outdatedPackage);
16
16
  this.logger.debug(`title=${title}`);
17
- const body = await (0, createPullRequestBody_1.createPullRequestBody)(outdatedPackage);
17
+ const body = await this.pullRequestBodyCreator.create(outdatedPackage);
18
18
  this.logger.debug(`body=${body}`);
19
19
  const pullRequest = await this.github.createPullRequest({
20
20
  owner: this.gitRepo.owner,
@@ -10,5 +10,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
10
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
11
11
  };
12
12
  Object.defineProperty(exports, "__esModule", { value: true });
13
+ __exportStar(require("./PullRequestBodyCreator"), exports);
13
14
  __exportStar(require("./PullRequestCreator"), exports);
14
15
  __exportStar(require("./PullRequestTitleCreator"), exports);
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ReleasesFetcher = void 0;
4
+ const semver_1 = require("semver");
5
+ class ReleasesFetcher {
6
+ constructor(github) {
7
+ this.github = github;
8
+ }
9
+ async fetch({ gitRepo, from, to }) {
10
+ const releases = await this.github.fetchReleases({
11
+ owner: gitRepo.owner,
12
+ repo: gitRepo.name
13
+ });
14
+ return releases.filter(({ tag_name: version }) => (0, semver_1.gte)(version, from.version) && (0, semver_1.lte)(version, to.version));
15
+ }
16
+ }
17
+ exports.ReleasesFetcher = ReleasesFetcher;
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
11
+ };
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ __exportStar(require("./ReleasesFetcher"), exports);
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
11
+ };
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ __exportStar(require("./fetcher"), exports);
package/dist/src/main.js CHANGED
@@ -27,7 +27,7 @@ const main = async ({ options, logger }) => {
27
27
  const gitRepo = await git.getRepository();
28
28
  logger.debug(`gitRepo=${JSON.stringify(gitRepo)}`);
29
29
  const github = (0, github_1.createGitHub)({
30
- repository: gitRepo,
30
+ host: gitRepo.url.host,
31
31
  token: options.githubToken
32
32
  });
33
33
  const githubRepo = await github.fetchRepository({
@@ -61,11 +61,19 @@ const main = async ({ options, logger }) => {
61
61
  packageManager: options.packageManager
62
62
  });
63
63
  const pullRequestTitleCreator = new github_1.PullRequestTitleCreator(options.pullRequestTitle);
64
+ const githubWithoutToken = (0, github_1.createGitHub)({
65
+ host: 'github.com'
66
+ });
67
+ const releasesFetcher = new github_1.ReleasesFetcher(githubWithoutToken);
68
+ const pullRequestBodyCreator = new github_1.PullRequestBodyCreator({
69
+ releasesFetcher
70
+ });
64
71
  const pullRequestCreator = new github_1.PullRequestCreator({
65
72
  github,
66
73
  gitRepo,
67
74
  githubRepo,
68
75
  pullRequestTitleCreator,
76
+ pullRequestBodyCreator,
69
77
  logger,
70
78
  reviewers: options.reviewers
71
79
  });
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "npm-update-package",
3
- "version": "0.36.0",
3
+ "version": "0.39.0",
4
4
  "description": "CLI tool for creating pull requests to update npm packages",
5
5
  "scripts": {
6
6
  "build": "tsc --project tsconfig.build.json",
@@ -36,7 +36,7 @@
36
36
  "@types/parse-github-url": "1.0.0",
37
37
  "@types/semver": "7.3.9",
38
38
  "@typescript-eslint/eslint-plugin": "5.12.1",
39
- "eslint": "8.9.0",
39
+ "eslint": "8.10.0",
40
40
  "eslint-config-standard-with-typescript": "21.0.1",
41
41
  "eslint-plugin-import": "2.25.4",
42
42
  "eslint-plugin-jest": "26.1.1",
@@ -1,62 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.createPullRequestBody = void 0;
7
- const package_json_1 = __importDefault(require("../../../../package.json"));
8
- const file_1 = require("../../../file");
9
- const json_1 = require("../../../json");
10
- const package_json_2 = require("../../../package-json");
11
- const metadata_1 = require("../metadata");
12
- const createPullRequestBody = async (outdatedPackage) => {
13
- const packageJson = await (0, file_1.readFile)(`node_modules/${outdatedPackage.name}/package.json`);
14
- const pkg = (0, package_json_2.parsePackageJson)(packageJson);
15
- const repository = (0, package_json_2.extractRepository)(pkg);
16
- const outdatedPackagesTable = createOutdatedPackagesTable({
17
- outdatedPackage,
18
- repository
19
- });
20
- const metadataSection = createMetadataSection(outdatedPackage);
21
- return `This PR updates these packages:
22
-
23
- ${outdatedPackagesTable}
24
-
25
- ${metadataSection}
26
-
27
- ---
28
- This PR has been generated by [${package_json_1.default.name}](${package_json_1.default.homepage}) v${package_json_1.default.version}`;
29
- };
30
- exports.createPullRequestBody = createPullRequestBody;
31
- const createOutdatedPackagesTable = ({ outdatedPackage, repository }) => {
32
- const packageName = outdatedPackage.name;
33
- const packageLink = `[${packageName}](https://www.npmjs.com/package/${packageName})`;
34
- const repositoryLink = repository !== undefined ? `[${repository.owner}/${repository.name}](${repository.url.toString()})` : '-';
35
- const level = outdatedPackage.level;
36
- const currentVersion = outdatedPackage.currentVersion.version;
37
- const currentVersionLink = `[\`${currentVersion}\`](https://www.npmjs.com/package/${packageName}/v/${currentVersion})`;
38
- const newVersion = outdatedPackage.newVersion.version;
39
- const newVersionLink = `[\`${newVersion}\`](https://www.npmjs.com/package/${packageName}/v/${newVersion})`;
40
- const diffLink = `[diff](https://renovatebot.com/diffs/npm/${packageName}/${currentVersion}/${newVersion})`;
41
- const version = `${currentVersionLink} -> ${newVersionLink} (${diffLink})`;
42
- return `|Package|Repository|Level|Version|
43
- |---|---|---|---|
44
- |${packageLink}|${repositoryLink}|${level}|${version}|`;
45
- };
46
- const createMetadataSection = (outdatedPackage) => {
47
- const metadata = (0, metadata_1.createPullRequestMetadata)([outdatedPackage]);
48
- const json = (0, json_1.toJSON)(metadata, { pretty: true });
49
- return `<details>
50
- <summary>Metadata</summary>
51
-
52
- **Don't remove or edit this section because it will be used by npm-update-package.**
53
-
54
- <div id="npm-update-package-metadata">
55
-
56
- \`\`\`json
57
- ${json}
58
- \`\`\`
59
-
60
- </div>
61
- </details>`;
62
- };