one-way-git-sync 3.1.3 → 3.3.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
@@ -14,26 +14,30 @@ It provides three features:
14
14
 
15
15
  ### Initial Usage
16
16
 
17
- Since `one-way-git-sync` finds a sync commit from the commit history of the dest repo,
18
- you need to run `init` subcommand to add an initial sync commit
17
+ Because `one-way-git-sync` finds a sync commit from the commit history of the dest repo,
18
+ you need to run `init` subcommand to add an initial sync commit to the dest repo
19
19
  by replacing all the files of the dest repo with those of src repo at first.
20
20
  The sample command is as follows:
21
21
 
22
22
  ```
23
- yarn one-way-git-sync init \
24
- -d https://github.com/WillBooster/sample-of-one-way-git-sync \
23
+ yarn dlx one-way-git-sync init \
24
+ -d git@github.com:WillBooster/sample-of-one-way-git-sync.git \
25
25
  -p https://github.com/WillBooster/one-way-git-sync/commits/
26
26
  ```
27
27
 
28
+ If you have no permission to write `git@github.com:WillBooster/sample-of-one-way-git-sync.git`,
29
+ please try `https://oauth2:<GitHub Personal Access Token>@github.com/WillBooster/sample-of-one-way-git-sync.git`.
30
+ `<GitHub Personal Access Token>` should be like `ghp_...Gnm61dm4rh`.
31
+
28
32
  ### Usual Usage
29
33
 
30
34
  If the last commit in the dest repo is a sync commit,
31
- `one-way-git-sync` safely synchronize the dest repo with the src repo.
35
+ `one-way-git-sync` safely synchronizes the dest repo with the src repo.
32
36
  The sample command is as follows:
33
37
 
34
38
  ```
35
- yarn one-way-git-sync \
36
- -d https://github.com/WillBooster/sample-of-one-way-git-sync \
39
+ yarn dlx one-way-git-sync \
40
+ -d git@github.com:WillBooster/sample-of-one-way-git-sync.git \
37
41
  -p https://github.com/WillBooster/one-way-git-sync/commits/
38
42
  ```
39
43
 
@@ -47,11 +51,11 @@ The sample commands are as follows:
47
51
 
48
52
  1. `yarn one-way-git-sync` fails then you notice there exist conflict commits
49
53
  2. `cd one-way-git-sync`
50
- 3. `git remote add upstream https://github.com/WillBooster/sample-of-one-way-git-sync`
54
+ 3. `git remote add upstream git@github.com:WillBooster/sample-of-one-way-git-sync.git`
51
55
  4. `git merge --allow-unrelated-histories upstream/main`
52
56
  5. ```
53
- yarn one-way-git-sync --force \
54
- -d https://github.com/WillBooster/sample-of-one-way-git-sync \
57
+ yarn dlx one-way-git-sync --force \
58
+ -d git@github.com:WillBooster/sample-of-one-way-git-sync.git \
55
59
  -p https://github.com/WillBooster/one-way-git-sync/commits/
56
60
  ```
57
61
 
package/dist/index.js ADDED
@@ -0,0 +1,285 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var helpers = require('yargs/helpers');
6
+ var yargs = require('yargs/yargs');
7
+ var child_process = require('child_process');
8
+ var fsp = require('fs/promises');
9
+ var path = require('path');
10
+ var fse = require('fs-extra');
11
+ var micromatch = require('micromatch');
12
+ var simpleGit = require('simple-git');
13
+ var winston = require('winston');
14
+
15
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
16
+
17
+ var yargs__default = /*#__PURE__*/_interopDefaultLegacy(yargs);
18
+ var child_process__default = /*#__PURE__*/_interopDefaultLegacy(child_process);
19
+ var fsp__default = /*#__PURE__*/_interopDefaultLegacy(fsp);
20
+ var path__default = /*#__PURE__*/_interopDefaultLegacy(path);
21
+ var fse__default = /*#__PURE__*/_interopDefaultLegacy(fse);
22
+ var micromatch__default = /*#__PURE__*/_interopDefaultLegacy(micromatch);
23
+ var simpleGit__default = /*#__PURE__*/_interopDefaultLegacy(simpleGit);
24
+
25
+ const logger = winston.createLogger({
26
+ transports: [new winston.transports.Console({
27
+ format: winston.format.cli({
28
+ colors: {
29
+ error: 'red'
30
+ }
31
+ })
32
+ })]
33
+ });
34
+
35
+ const syncDirPath = path__default["default"].join('node_modules', '.temp', 'sync-git-repo');
36
+ async function sync(opts, init) {
37
+ await fsp__default["default"].mkdir(syncDirPath, {
38
+ recursive: true
39
+ });
40
+ const dirPath = await fsp__default["default"].mkdtemp(path__default["default"].join(syncDirPath, 'repo-'));
41
+ const ret = await syncCore(dirPath, opts, init);
42
+ await fsp__default["default"].rm(dirPath, {
43
+ recursive: true,
44
+ force: true
45
+ });
46
+ process.exit(ret ? 0 : 1);
47
+ }
48
+
49
+ async function syncCore(destRepoPath, opts, init) {
50
+ var _srcLog$latest, _opts$prefix;
51
+
52
+ const cloneOpts = {
53
+ '--single-branch': undefined
54
+ };
55
+
56
+ if (!opts.force) {
57
+ cloneOpts['--depth'] = 1;
58
+ }
59
+
60
+ if (opts.branch) {
61
+ cloneOpts['--branch'] = opts.branch;
62
+ }
63
+
64
+ try {
65
+ await simpleGit__default["default"]().clone(opts.dest, destRepoPath, cloneOpts);
66
+ } catch (e) {
67
+ if (!init) throw e;
68
+ delete cloneOpts['--single-branch'];
69
+ await simpleGit__default["default"]().clone(opts.dest, destRepoPath, cloneOpts);
70
+ simpleGit__default["default"](destRepoPath).checkout(['-b', opts.branch]);
71
+ }
72
+
73
+ logger.verbose(`Cloned a destination repo on ${destRepoPath}`);
74
+ const dstGit = simpleGit__default["default"](destRepoPath);
75
+ const dstLog = await dstGit.log();
76
+ let from;
77
+
78
+ if (!init) {
79
+ from = extractCommitHash(dstLog);
80
+
81
+ if (!from) {
82
+ logger.error('No valid commit in destination repo');
83
+ return false;
84
+ }
85
+
86
+ logger.verbose(`Extracted a valid commit: ${from}`);
87
+ }
88
+
89
+ const srcGit = simpleGit__default["default"]();
90
+ let srcLog;
91
+
92
+ try {
93
+ // '--first-parent' hides children commits of merge commits
94
+ srcLog = await srcGit.log(from ? {
95
+ from,
96
+ to: 'HEAD',
97
+ '--first-parent': undefined
98
+ } : undefined);
99
+ } catch (e) {
100
+ logger.error(`Failed to get source commit history: ${e.stack}`);
101
+ return false;
102
+ }
103
+
104
+ const latestHash = (_srcLog$latest = srcLog.latest) === null || _srcLog$latest === void 0 ? void 0 : _srcLog$latest.hash;
105
+
106
+ if (!latestHash) {
107
+ logger.info('No synchronizable commit');
108
+ return true;
109
+ }
110
+
111
+ const [destFiles, srcFiles] = await Promise.all([fsp__default["default"].readdir(destRepoPath), fsp__default["default"].readdir('.')]);
112
+
113
+ for (const destFile of micromatch__default["default"].not(destFiles, opts['ignore-patterns'])) {
114
+ await fsp__default["default"].rm(path__default["default"].join(destRepoPath, destFile), {
115
+ recursive: true,
116
+ force: true
117
+ });
118
+ }
119
+
120
+ for (const srcFile of micromatch__default["default"].not(srcFiles, opts['ignore-patterns'])) {
121
+ fse__default["default"].copySync(srcFile, path__default["default"].join(destRepoPath, srcFile));
122
+ }
123
+
124
+ await dstGit.add('-A');
125
+ let srcTag = '';
126
+
127
+ if (opts['tag-hash'] || opts['tag-version']) {
128
+ // e.g. `--abbrev=0` changes `v1.31.5-2-gcdde507` to `v1.31.5`
129
+ const describeCommand = `git describe --tags --always ${opts['tag-version'] ? '--abbrev=0' : ''}`;
130
+ srcTag = child_process__default["default"].execSync(describeCommand).toString().trim();
131
+ }
132
+
133
+ let prefix = (_opts$prefix = opts.prefix) !== null && _opts$prefix !== void 0 ? _opts$prefix : '';
134
+
135
+ if (prefix && !prefix.endsWith('/')) {
136
+ prefix += '/';
137
+ }
138
+
139
+ const link = `${prefix}${latestHash}`;
140
+ const title = srcTag ? `sync ${srcTag} (${link})` : `sync ${link}`;
141
+ const body = init ? `Initialize one-way-git-sync by replacing all the files with those of ${opts.dest}` : srcLog.all.map(l => `* ${l.message}`).join('\n\n');
142
+
143
+ try {
144
+ await dstGit.commit(`${title}\n\n${body}`);
145
+ logger.verbose(`Created a commit: ${title}`);
146
+ logger.verbose(` with body: ${body}`);
147
+ } catch (e) {
148
+ logger.error(`Failed to commit changes: ${e.stack}\`);`);
149
+ return false;
150
+ }
151
+
152
+ const destTag = srcTag || opts.tag;
153
+
154
+ if (destTag) {
155
+ try {
156
+ await dstGit.addTag(destTag);
157
+ logger.verbose(`Created a tag: ${destTag}`);
158
+ } catch (e) {
159
+ logger.error(`Failed to commit changes: ${e.stack}\`);`);
160
+ return false;
161
+ }
162
+ }
163
+
164
+ if (opts.dry) {
165
+ logger.verbose('Finished dry run');
166
+ return true;
167
+ }
168
+
169
+ try {
170
+ await dstGit.push();
171
+
172
+ if (destTag) {
173
+ await dstGit.push({
174
+ '--tags': null
175
+ });
176
+ }
177
+ } catch (e) {
178
+ logger.error(`Failed to push the commit: ${e.stack}`);
179
+ return false;
180
+ }
181
+
182
+ logger.verbose('Pushed the commit');
183
+ return true;
184
+ }
185
+
186
+ function extractCommitHash(logResult) {
187
+ if (logResult.all.length === 0) {
188
+ logger.error('No commit history');
189
+ return;
190
+ }
191
+
192
+ for (const log of logResult.all) {
193
+ const [head, ...words] = log.message.replace(/[()]/g, '').split(/[\s/]/);
194
+
195
+ if (head === 'sync' && words.length) {
196
+ return words[words.length - 1];
197
+ }
198
+ }
199
+
200
+ logger.error(`No sync commit: ${logResult.all[0].message}`);
201
+ return;
202
+ }
203
+
204
+ const initCommand = {
205
+ command: 'init',
206
+ describe: 'Initialize a destination git repository',
207
+
208
+ async handler(argv) {
209
+ await sync(argv, true);
210
+ }
211
+
212
+ };
213
+
214
+ const syncCommand = {
215
+ command: 'sync',
216
+ describe: 'Synchronize a destination git repository with a source git repository',
217
+
218
+ async handler(argv) {
219
+ await sync(argv, false);
220
+ }
221
+
222
+ };
223
+
224
+ const yargsOptions = {
225
+ dest: {
226
+ type: 'string',
227
+ alias: 'd',
228
+ describe: 'A URL of a destination git repository.',
229
+ demand: true
230
+ },
231
+ prefix: {
232
+ type: 'string',
233
+ alias: 'p',
234
+ describe: `A prefix of a commit hash used to generate a commit title, e.g. 'sync <prefix>/<hash>'.
235
+ A typical value is like 'https://github.com/WillBooster/one-way-git-sync/commits'`
236
+ },
237
+ branch: {
238
+ type: 'string',
239
+ alias: 'b',
240
+ describe: 'Specify branch of destination repo.'
241
+ },
242
+ tag: {
243
+ type: 'string',
244
+ alias: 't',
245
+ describe: 'Specify tag to be created in destination repo.'
246
+ },
247
+ 'tag-hash': {
248
+ type: 'boolean',
249
+ describe: 'Create version+hash tag (e.g. v1.31.5-2-gcdde507). It should be a unique tag.'
250
+ },
251
+ 'tag-version': {
252
+ type: 'boolean',
253
+ describe: 'Create version tag (e.g. v1.31.5). It could be a non-unique tag.'
254
+ },
255
+ 'ignore-patterns': {
256
+ type: 'string',
257
+ alias: 'i',
258
+ describe: `Exclude the files whose path matches one of the given patterns.
259
+ The patterns are processed by micromatch (https://github.com/micromatch/micromatch).
260
+ You may specify the option multiple times. Default value is ['.git', '.github', 'node_modules']`,
261
+ default: ['.git', '.github', 'node_modules']
262
+ },
263
+ dry: {
264
+ type: 'boolean',
265
+ describe: 'Enable dry-run mode.'
266
+ },
267
+ force: {
268
+ type: 'boolean',
269
+ describe: 'Force to overwrite the destination git repository.'
270
+ },
271
+ verbose: {
272
+ type: 'boolean',
273
+ alias: 'v',
274
+ describe: 'Show details logs.'
275
+ }
276
+ };
277
+
278
+ async function cli(argv) {
279
+ await yargs__default["default"](helpers.hideBin(argv)).options(yargsOptions).middleware(argv => {
280
+ logger.level = argv.verbose ? 'verbose' : 'info';
281
+ }).command(initCommand).command(syncCommand).argv;
282
+ }
283
+
284
+ exports.cli = cli;
285
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../src/logger.ts","../src/index.ts","../src/initCommand.ts","../src/syncCommand.ts","../src/yargsOptions.ts","../src/cli.ts"],"sourcesContent":["import { createLogger, format, transports } from 'winston';\n\nexport const logger = createLogger({\n transports: [\n new transports.Console({\n format: format.cli({ colors: { error: 'red' } }),\n }),\n ],\n});\n","import child_process from 'child_process';\nimport fsp from 'fs/promises';\nimport path from 'path';\n\nimport fse from 'fs-extra';\nimport micromatch from 'micromatch';\nimport type { LogResult, TaskOptions } from 'simple-git';\nimport simpleGit, { SimpleGit } from 'simple-git';\nimport { InferredOptionTypes } from 'yargs';\n\nimport { logger } from './logger';\nimport { yargsOptions } from './yargsOptions';\n\nconst syncDirPath = path.join('node_modules', '.temp', 'sync-git-repo');\n\nexport async function sync(opts: InferredOptionTypes<typeof yargsOptions>, init: boolean): Promise<void> {\n await fsp.mkdir(syncDirPath, { recursive: true });\n const dirPath = await fsp.mkdtemp(path.join(syncDirPath, 'repo-'));\n const ret = await syncCore(dirPath, opts, init);\n await fsp.rm(dirPath, { recursive: true, force: true });\n process.exit(ret ? 0 : 1);\n}\n\nasync function syncCore(\n destRepoPath: string,\n opts: InferredOptionTypes<typeof yargsOptions>,\n init: boolean\n): Promise<boolean> {\n const cloneOpts: Record<string, any> = { '--single-branch': undefined };\n if (!opts.force) {\n cloneOpts['--depth'] = 1;\n }\n if (opts.branch) {\n cloneOpts['--branch'] = opts.branch;\n }\n try {\n await simpleGit().clone(opts.dest, destRepoPath, cloneOpts);\n } catch (e) {\n if (!init) throw e;\n\n delete cloneOpts['--single-branch'];\n await simpleGit().clone(opts.dest, destRepoPath, cloneOpts);\n simpleGit(destRepoPath).checkout(['-b', opts.branch] as TaskOptions);\n }\n logger.verbose(`Cloned a destination repo on ${destRepoPath}`);\n\n const dstGit: SimpleGit = simpleGit(destRepoPath);\n const dstLog = await dstGit.log();\n\n let from: string | undefined;\n if (!init) {\n from = extractCommitHash(dstLog);\n if (!from) {\n logger.error('No valid commit in destination repo');\n return false;\n }\n logger.verbose(`Extracted a valid commit: ${from}`);\n }\n\n const srcGit: SimpleGit = simpleGit();\n let srcLog: LogResult;\n try {\n // '--first-parent' hides children commits of merge commits\n srcLog = await srcGit.log(from ? { from, to: 'HEAD', '--first-parent': undefined } : undefined);\n } catch (e) {\n logger.error(`Failed to get source commit history: ${(e as Error).stack}`);\n return false;\n }\n\n const latestHash = srcLog.latest?.hash;\n if (!latestHash) {\n logger.info('No synchronizable commit');\n return true;\n }\n\n const [destFiles, srcFiles] = await Promise.all([fsp.readdir(destRepoPath), fsp.readdir('.')]);\n for (const destFile of micromatch.not(destFiles, opts['ignore-patterns'])) {\n await fsp.rm(path.join(destRepoPath, destFile), { recursive: true, force: true });\n }\n for (const srcFile of micromatch.not(srcFiles, opts['ignore-patterns'])) {\n fse.copySync(srcFile, path.join(destRepoPath, srcFile));\n }\n await dstGit.add('-A');\n\n let srcTag = '';\n if (opts['tag-hash'] || opts['tag-version']) {\n // e.g. `--abbrev=0` changes `v1.31.5-2-gcdde507` to `v1.31.5`\n const describeCommand = `git describe --tags --always ${opts['tag-version'] ? '--abbrev=0' : ''}`;\n srcTag = child_process.execSync(describeCommand).toString().trim();\n }\n let prefix = opts.prefix ?? '';\n if (prefix && !prefix.endsWith('/')) {\n prefix += '/';\n }\n const link = `${prefix}${latestHash}`;\n const title = srcTag ? `sync ${srcTag} (${link})` : `sync ${link}`;\n const body = init\n ? `Initialize one-way-git-sync by replacing all the files with those of ${opts.dest}`\n : srcLog.all.map((l) => `* ${l.message}`).join('\\n\\n');\n try {\n await dstGit.commit(`${title}\\n\\n${body}`);\n logger.verbose(`Created a commit: ${title}`);\n logger.verbose(` with body: ${body}`);\n } catch (e) {\n logger.error(`Failed to commit changes: ${(e as Error).stack}\\`);`);\n return false;\n }\n\n const destTag = srcTag || opts.tag;\n if (destTag) {\n try {\n await dstGit.addTag(destTag);\n logger.verbose(`Created a tag: ${destTag}`);\n } catch (e) {\n logger.error(`Failed to commit changes: ${(e as Error).stack}\\`);`);\n return false;\n }\n }\n\n if (opts.dry) {\n logger.verbose('Finished dry run');\n return true;\n }\n\n try {\n await dstGit.push();\n if (destTag) {\n await dstGit.push({ '--tags': null });\n }\n } catch (e) {\n logger.error(`Failed to push the commit: ${(e as Error).stack}`);\n return false;\n }\n\n logger.verbose('Pushed the commit');\n return true;\n}\n\nfunction extractCommitHash(logResult: LogResult): string | undefined {\n if (logResult.all.length === 0) {\n logger.error('No commit history');\n return;\n }\n\n for (const log of logResult.all) {\n const [head, ...words] = log.message.replace(/[()]/g, '').split(/[\\s/]/);\n if (head === 'sync' && words.length) {\n return words[words.length - 1];\n }\n }\n logger.error(`No sync commit: ${logResult.all[0].message}`);\n return;\n}\n","import type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { yargsOptions } from './yargsOptions';\n\nimport { sync } from './index';\n\nexport const initCommand: CommandModule<unknown, InferredOptionTypes<typeof yargsOptions>> = {\n command: 'init',\n describe: 'Initialize a destination git repository',\n async handler(argv) {\n await sync(argv, true);\n },\n};\n","import type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { yargsOptions } from './yargsOptions';\n\nimport { sync } from './index';\n\nexport const syncCommand: CommandModule<unknown, InferredOptionTypes<typeof yargsOptions>> = {\n command: 'sync',\n describe: 'Synchronize a destination git repository with a source git repository',\n async handler(argv) {\n await sync(argv, false);\n },\n};\n","export const yargsOptions = {\n dest: {\n type: 'string',\n alias: 'd',\n describe: 'A URL of a destination git repository.',\n demand: true,\n },\n prefix: {\n type: 'string',\n alias: 'p',\n describe: `A prefix of a commit hash used to generate a commit title, e.g. 'sync <prefix>/<hash>'.\n A typical value is like 'https://github.com/WillBooster/one-way-git-sync/commits'`,\n },\n branch: {\n type: 'string',\n alias: 'b',\n describe: 'Specify branch of destination repo.',\n },\n tag: {\n type: 'string',\n alias: 't',\n describe: 'Specify tag to be created in destination repo.',\n },\n 'tag-hash': {\n type: 'boolean',\n describe: 'Create version+hash tag (e.g. v1.31.5-2-gcdde507). It should be a unique tag.',\n },\n 'tag-version': {\n type: 'boolean',\n describe: 'Create version tag (e.g. v1.31.5). It could be a non-unique tag.',\n },\n 'ignore-patterns': {\n type: 'string',\n alias: 'i',\n describe: `Exclude the files whose path matches one of the given patterns.\n The patterns are processed by micromatch (https://github.com/micromatch/micromatch).\n You may specify the option multiple times. Default value is ['.git', '.github', 'node_modules']`,\n default: ['.git', '.github', 'node_modules'],\n },\n dry: {\n type: 'boolean',\n describe: 'Enable dry-run mode.',\n },\n force: {\n type: 'boolean',\n describe: 'Force to overwrite the destination git repository.',\n },\n verbose: {\n type: 'boolean',\n alias: 'v',\n describe: 'Show details logs.',\n },\n} as const;\n","import { hideBin } from 'yargs/helpers';\nimport yargs from 'yargs/yargs';\n\nimport { initCommand } from './initCommand';\nimport { logger } from './logger';\nimport { syncCommand } from './syncCommand';\nimport { yargsOptions } from './yargsOptions';\n\nexport async function cli(argv: string[]): Promise<void> {\n await yargs(hideBin(argv))\n .options(yargsOptions)\n .middleware((argv) => {\n logger.level = argv.verbose ? 'verbose' : 'info';\n })\n .command(initCommand)\n .command(syncCommand).argv;\n}\n"],"names":["logger","createLogger","transports","Console","format","cli","colors","error","syncDirPath","path","join","sync","opts","init","fsp","mkdir","recursive","dirPath","mkdtemp","ret","syncCore","rm","force","process","exit","destRepoPath","cloneOpts","undefined","branch","simpleGit","clone","dest","e","checkout","verbose","dstGit","dstLog","log","from","extractCommitHash","srcGit","srcLog","to","stack","latestHash","latest","hash","info","destFiles","srcFiles","Promise","all","readdir","destFile","micromatch","not","srcFile","fse","copySync","add","srcTag","describeCommand","child_process","execSync","toString","trim","prefix","endsWith","link","title","body","map","l","message","commit","destTag","tag","addTag","dry","push","logResult","length","head","words","replace","split","initCommand","command","describe","handler","argv","syncCommand","yargsOptions","type","alias","demand","default","yargs","hideBin","options","middleware","level"],"mappings":"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"}
package/package.json CHANGED
@@ -5,7 +5,7 @@
5
5
  "git",
6
6
  "sync"
7
7
  ],
8
- "repository": "git@github.com:WillBooster/one-way-git-sync.git",
8
+ "repository": "github:WillBooster/one-way-git-sync",
9
9
  "license": "Apache-2.0",
10
10
  "author": "WillBooster Inc.",
11
11
  "bin": "./bin/index.js",
@@ -20,9 +20,10 @@
20
20
  "_postinstall": "husky install",
21
21
  "lint": "eslint --color \"./{src,__tests__}/**/*.{cjs,js,jsx,mjs,ts,tsx}\"",
22
22
  "lint-fix": "yarn lint --fix",
23
- "prepublishOnly": "pinst --disable",
23
+ "prepack": "pinst --disable",
24
+ "postpack": "pinst --enable",
24
25
  "prettify": "prettier --color --write \"**/{.*/,}*.{cjs,css,htm,html,js,json,json5,jsx,md,mjs,scss,ts,tsx,vue,yaml,yml}\" \"!**/test-fixtures/**\"",
25
- "postpublish": "pinst --enable",
26
+ "release": "yarn build && semantic-release",
26
27
  "start": "babel-node -x .js,.jsx,.es6,.es,.ts -- src/start.ts",
27
28
  "start-prod": "yarn build && yarn one-way-git-sync",
28
29
  "typecheck": "tsc --noEmit --Pretty"
@@ -33,12 +34,13 @@
33
34
  },
34
35
  "dependencies": {
35
36
  "fs-extra": "10.0.0",
36
- "simple-git": "2.48.0",
37
- "winston": "3.5.1",
37
+ "micromatch": "4.0.4",
38
+ "simple-git": "3.2.6",
39
+ "winston": "3.6.0",
38
40
  "yargs": "17.3.1"
39
41
  },
40
42
  "devDependencies": {
41
- "@babel/core": "7.17.2",
43
+ "@babel/core": "7.17.5",
42
44
  "@babel/helper-plugin-utils": "7.16.7",
43
45
  "@babel/node": "7.16.8",
44
46
  "@babel/plugin-proposal-class-properties": "7.16.7",
@@ -53,37 +55,33 @@
53
55
  "@types/micromatch": "4.0.2",
54
56
  "@types/semantic-release": "17.2.3",
55
57
  "@types/yargs": "17.0.8",
56
- "@typescript-eslint/eslint-plugin": "5.12.0",
57
- "@typescript-eslint/parser": "5.12.0",
58
+ "@typescript-eslint/eslint-plugin": "5.12.1",
59
+ "@typescript-eslint/parser": "5.12.1",
58
60
  "@willbooster/eslint-config-ts": "9.0.0",
59
61
  "@willbooster/prettier-config": "9.0.0",
60
62
  "@willbooster/renovate-config": "9.2.0",
61
63
  "babel-plugin-transform-remove-console": "6.9.4",
62
- "babel-plugin-unassert": "3.2.0",
63
- "babel-preset-power-assert": "3.0.0",
64
64
  "conventional-changelog-conventionalcommits": "4.6.3",
65
- "core-js": "3.21.0",
65
+ "core-js": "3.21.1",
66
66
  "eslint": "8.9.0",
67
- "eslint-config-prettier": "8.3.0",
67
+ "eslint-config-prettier": "8.4.0",
68
68
  "eslint-import-resolver-typescript": "2.5.0",
69
69
  "eslint-plugin-import": "2.25.4",
70
70
  "eslint-plugin-sort-class-members": "1.14.1",
71
71
  "eslint-plugin-sort-destructure-keys": "1.4.0",
72
72
  "husky": "7.0.4",
73
73
  "lint-staged": "12.3.4",
74
- "micromatch": "4.0.4",
75
- "pinst": "2.1.6",
76
- "power-assert": "1.6.1",
74
+ "pinst": "3.0.0",
77
75
  "prettier": "2.5.1",
78
- "rollup": "2.67.2",
76
+ "rollup": "2.67.3",
79
77
  "rollup-plugin-node-externals": "4.0.0",
80
- "semantic-release": "18.0.1",
78
+ "semantic-release": "19.0.2",
81
79
  "sort-package-json": "1.54.0",
82
80
  "typescript": "4.5.5"
83
81
  },
84
82
  "engines": {
85
83
  "node": ">=14"
86
84
  },
87
- "packageManager": "yarn@3.2.0-rc.15",
88
- "version": "3.1.3"
85
+ "packageManager": "yarn@3.2.0",
86
+ "version": "3.3.1"
89
87
  }