@rosen-bridge/utils 2.0.1 → 3.0.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/CHANGELOG.md +12 -0
- package/dist/downloadRosenAssets.d.ts.map +1 -1
- package/dist/downloadRosenAssets.js +2 -2
- package/dist/downloadTssBinary.d.ts.map +1 -1
- package/dist/downloadTssBinary.js +2 -2
- package/dist/types/index.d.ts +1 -2
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +1 -1
- package/dist/utils/github.d.ts +19 -19
- package/dist/utils/github.d.ts.map +1 -1
- package/dist/utils/github.js +21 -21
- package/dist/utils/rosen.d.ts +5 -5
- package/dist/utils/rosen.d.ts.map +1 -1
- package/dist/utils/rosen.js +7 -7
- package/package.json +20 -23
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,17 @@
|
|
|
1
1
|
# @rosen-bridge/utils
|
|
2
2
|
|
|
3
|
+
## 3.0.0
|
|
4
|
+
|
|
5
|
+
### Major Changes
|
|
6
|
+
|
|
7
|
+
- Remove ArrayElement type to enforce type safety and avoid any
|
|
8
|
+
|
|
9
|
+
## 2.0.2
|
|
10
|
+
|
|
11
|
+
### Patch Changes
|
|
12
|
+
|
|
13
|
+
- Fix asset name regex to support `contracts` and `tokensMap`.
|
|
14
|
+
|
|
3
15
|
## 2.0.1
|
|
4
16
|
|
|
5
17
|
### Patch Changes
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"downloadRosenAssets.d.ts","sourceRoot":"","sources":["../lib/downloadRosenAssets.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"downloadRosenAssets.d.ts","sourceRoot":"","sources":["../lib/downloadRosenAssets.ts"],"names":[],"mappings":"AAYA;;;;;GAKG;AACH,QAAA,MAAM,mBAAmB,GACvB,WAAW,MAAM,EACjB,iBAAiB,MAAM,EACvB,SAAS;IACP,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,GAAG,CAAC,EAAE,MAAM,CAAC;CACd,kBA2CF,CAAC;AAEF,eAAe,mBAAmB,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import download from 'download';
|
|
2
|
+
import { RosenAssetsDownloadError } from './error';
|
|
2
3
|
import { findLatestRelease, findLatestStableRelease, getReleaseByTag, } from './utils/github';
|
|
3
4
|
import { isValidAssetName, truncateAssetName } from './utils/rosen';
|
|
4
|
-
import { RosenAssetsDownloadError } from './error';
|
|
5
5
|
const repo = 'contract';
|
|
6
6
|
/**
|
|
7
7
|
* Download all required Rosen assets (tokenMap and all chain address files) to a specific path
|
|
@@ -45,4 +45,4 @@ const downloadRosenAssets = async (chainType, destinationPath, config) => {
|
|
|
45
45
|
}
|
|
46
46
|
};
|
|
47
47
|
export default downloadRosenAssets;
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG93bmxvYWRSb3NlbkFzc2V0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL2xpYi9kb3dubG9hZFJvc2VuQXNzZXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sUUFBUSxNQUFNLFVBQVUsQ0FBQztBQUVoQyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDbkQsT0FBTyxFQUNMLGlCQUFpQixFQUNqQix1QkFBdUIsRUFDdkIsZUFBZSxHQUNoQixNQUFNLGdCQUFnQixDQUFDO0FBQ3hCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVwRSxNQUFNLElBQUksR0FBRyxVQUFVLENBQUM7QUFFeEI7Ozs7O0dBS0c7QUFDSCxNQUFNLG1CQUFtQixHQUFHLEtBQUssRUFDL0IsU0FBaUIsRUFDakIsZUFBdUIsRUFDdkIsTUFJQyxFQUNELEVBQUU7SUFDRixNQUFNLFVBQVUsR0FBRyxHQUFHLEVBQUU7UUFDdEIsSUFBSSxNQUFNLEVBQUUsR0FBRztZQUFFLE9BQU8sZUFBZSxDQUFDLElBQUksRUFBRSxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDMUQsSUFBSSxNQUFNLEVBQUUsa0JBQWtCO1lBQUUsT0FBTyxpQkFBaUIsQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDMUUsT0FBTyx1QkFBdUIsQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDbEQsQ0FBQyxDQUFDO0lBQ0YsSUFBSSxDQUFDO1FBQ0gsTUFBTSxPQUFPLEdBQUcsTUFBTSxVQUFVLEVBQUUsQ0FBQztRQUVuQyxJQUFJLE9BQU8sRUFBRSxDQUFDO1lBQ1osTUFBTSxPQUFPLENBQUMsR0FBRyxDQUFDO2dCQUNoQixHQUFHLENBQUMsT0FBTztvQkFDVCxPQUFPLENBQUMsTUFBTTt5QkFDWCxNQUFNLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLGdCQUFnQixDQUFDLFNBQVMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQzt5QkFDMUQsR0FBRyxDQUFDLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRSxDQUNuQixRQUFRLENBQUMsS0FBSyxDQUFDLG9CQUFvQixFQUFFLGVBQWUsRUFBRTt3QkFDcEQsUUFBUSxFQUFFLGlCQUFpQixDQUN6QixLQUFLLENBQUMsSUFBSSxFQUNWLFNBQVMsRUFDVCxPQUFPLENBQUMsUUFBUSxFQUNoQixNQUFNLEVBQUUsVUFBVSxDQUNuQjtxQkFDRixDQUFDLENBQ0gsQ0FBQzthQUNQLENBQUMsQ0FBQztRQUNMLENBQUM7YUFBTSxDQUFDO1lBQ04sT0FBTyxDQUFDLEtBQUssQ0FBQyx5QkFBeUIsU0FBUyxlQUFlLENBQUMsQ0FBQztZQUNqRSxJQUFJLENBQUMsTUFBTSxFQUFFLGtCQUFrQixFQUFFLENBQUM7Z0JBQ2hDLE9BQU8sQ0FBQyxLQUFLLENBQ1gsNEdBQTRHLENBQzdHLENBQUM7WUFDSixDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFBQyxPQUFPLEtBQUssRUFBRSxDQUFDO1FBQ2YsT0FBTyxDQUFDLEtBQUssQ0FDWCw0REFBNEQsS0FBSyxFQUFFLENBQ3BFLENBQUM7UUFDRixJQUFJLEtBQUssWUFBWSxLQUFLLEVBQUUsQ0FBQztZQUMzQixPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM3QixDQUFDO1FBQ0QsTUFBTSxJQUFJLHdCQUF3QixDQUFDLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQzNELENBQUM7QUFDSCxDQUFDLENBQUM7QUFFRixlQUFlLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGRvd25sb2FkIGZyb20gJ2Rvd25sb2FkJztcblxuaW1wb3J0IHsgUm9zZW5Bc3NldHNEb3dubG9hZEVycm9yIH0gZnJvbSAnLi9lcnJvcic7XG5pbXBvcnQge1xuICBmaW5kTGF0ZXN0UmVsZWFzZSxcbiAgZmluZExhdGVzdFN0YWJsZVJlbGVhc2UsXG4gIGdldFJlbGVhc2VCeVRhZyxcbn0gZnJvbSAnLi91dGlscy9naXRodWInO1xuaW1wb3J0IHsgaXNWYWxpZEFzc2V0TmFtZSwgdHJ1bmNhdGVBc3NldE5hbWUgfSBmcm9tICcuL3V0aWxzL3Jvc2VuJztcblxuY29uc3QgcmVwbyA9ICdjb250cmFjdCc7XG5cbi8qKlxuICogRG93bmxvYWQgYWxsIHJlcXVpcmVkIFJvc2VuIGFzc2V0cyAodG9rZW5NYXAgYW5kIGFsbCBjaGFpbiBhZGRyZXNzIGZpbGVzKSB0byBhIHNwZWNpZmljIHBhdGhcbiAqIEBwYXJhbSBjaGFpblR5cGUgY2hhaW4gdHlwZSAoZS5nLiBtYWlubmV0LCB0ZXN0bmV0LCBldGMuKVxuICogQHBhcmFtIGluY2x1ZGVQcmVyZWxlYXNlcyB3ZWF0aGVyIHRvIGluY2x1ZGUgcHJlcmVsZWFzZXMgaW50byBhY2NvdW50IHdoZW4gc2VhcmNoaW5nIGZvciBhIG1hdGNoaW5nIHJlbGVhc2UgaW4gR2l0SHViXG4gKiBAcGFyYW0gY29uZmlnIGNvbmZpZ3MgZm9yIGluY2x1ZGluZyBwcmVyZWxlYXNlcywgYWRkaW5nIG5hbWUgc3VmZml4LCBhbmQgZ2V0dGluZyBzcGVjaWZpYyByZWxlYXNlIGJ5IHRhZ1xuICovXG5jb25zdCBkb3dubG9hZFJvc2VuQXNzZXRzID0gYXN5bmMgKFxuICBjaGFpblR5cGU6IHN0cmluZyxcbiAgZGVzdGluYXRpb25QYXRoOiBzdHJpbmcsXG4gIGNvbmZpZz86IHtcbiAgICBpbmNsdWRlUHJlcmVsZWFzZXM/OiBib29sZWFuO1xuICAgIG5hbWVTdWZmaXg/OiBzdHJpbmc7XG4gICAgdGFnPzogc3RyaW5nO1xuICB9LFxuKSA9PiB7XG4gIGNvbnN0IGdldFJlbGVhc2UgPSAoKSA9PiB7XG4gICAgaWYgKGNvbmZpZz8udGFnKSByZXR1cm4gZ2V0UmVsZWFzZUJ5VGFnKHJlcG8sIGNvbmZpZy50YWcpO1xuICAgIGlmIChjb25maWc/LmluY2x1ZGVQcmVyZWxlYXNlcykgcmV0dXJuIGZpbmRMYXRlc3RSZWxlYXNlKHJlcG8sIGNoYWluVHlwZSk7XG4gICAgcmV0dXJuIGZpbmRMYXRlc3RTdGFibGVSZWxlYXNlKHJlcG8sIGNoYWluVHlwZSk7XG4gIH07XG4gIHRyeSB7XG4gICAgY29uc3QgcmVsZWFzZSA9IGF3YWl0IGdldFJlbGVhc2UoKTtcblxuICAgIGlmIChyZWxlYXNlKSB7XG4gICAgICBhd2FpdCBQcm9taXNlLmFsbChbXG4gICAgICAgIC4uLihyZWxlYXNlICYmXG4gICAgICAgICAgcmVsZWFzZS5hc3NldHNcbiAgICAgICAgICAgIC5maWx0ZXIoKGFzc2V0KSA9PiBpc1ZhbGlkQXNzZXROYW1lKGNoYWluVHlwZSkoYXNzZXQubmFtZSkpXG4gICAgICAgICAgICAubWFwKGFzeW5jIChhc3NldCkgPT5cbiAgICAgICAgICAgICAgZG93bmxvYWQoYXNzZXQuYnJvd3Nlcl9kb3dubG9hZF91cmwsIGRlc3RpbmF0aW9uUGF0aCwge1xuICAgICAgICAgICAgICAgIGZpbGVuYW1lOiB0cnVuY2F0ZUFzc2V0TmFtZShcbiAgICAgICAgICAgICAgICAgIGFzc2V0Lm5hbWUsXG4gICAgICAgICAgICAgICAgICBjaGFpblR5cGUsXG4gICAgICAgICAgICAgICAgICByZWxlYXNlLnRhZ19uYW1lLFxuICAgICAgICAgICAgICAgICAgY29uZmlnPy5uYW1lU3VmZml4LFxuICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgKSksXG4gICAgICBdKTtcbiAgICB9IGVsc2Uge1xuICAgICAgY29uc29sZS5lcnJvcihgTm8gcmVsZWFzZSBmb3VuZCBmb3IgWyR7Y2hhaW5UeXBlfV0gY2hhaW4gdHlwZS5gKTtcbiAgICAgIGlmICghY29uZmlnPy5pbmNsdWRlUHJlcmVsZWFzZXMpIHtcbiAgICAgICAgY29uc29sZS5lcnJvcihcbiAgICAgICAgICAnUGxlYXNlIG5vdGUgdGhhdCBgaW5jbHVkZVByZXJlbGVhc2VzYCBpcyBzZXQgdG8gZmFsc2UuIFRoZXJlIG1heSBiZSBzb21lIG1hdGNoaW5nIHJlbGVhc2VzIGluIHByZXJlbGVhc2VzLicsXG4gICAgICAgICk7XG4gICAgICB9XG4gICAgfVxuICB9IGNhdGNoIChlcnJvcikge1xuICAgIGNvbnNvbGUuZXJyb3IoXG4gICAgICBgQW4gZXJyb3Igb2NjdXJyZWQgd2hpbGUgdHJ5aW5nIHRvIGRvd25sb2FkIFJvc2VuIGFzc2V0czogJHtlcnJvcn1gLFxuICAgICk7XG4gICAgaWYgKGVycm9yIGluc3RhbmNlb2YgRXJyb3IpIHtcbiAgICAgIGNvbnNvbGUuZXJyb3IoZXJyb3Iuc3RhY2spO1xuICAgIH1cbiAgICB0aHJvdyBuZXcgUm9zZW5Bc3NldHNEb3dubG9hZEVycm9yKCcnLCB7IGNhdXNlOiBlcnJvciB9KTtcbiAgfVxufTtcblxuZXhwb3J0IGRlZmF1bHQgZG93bmxvYWRSb3NlbkFzc2V0cztcbiJdfQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"downloadTssBinary.d.ts","sourceRoot":"","sources":["../lib/downloadTssBinary.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"downloadTssBinary.d.ts","sourceRoot":"","sources":["../lib/downloadTssBinary.ts"],"names":[],"mappings":"AAYA;;;;GAIG;AACH,QAAA,MAAM,iBAAiB,GACrB,iBAAiB,MAAM,EACvB,QAAQ;IACN,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,OAAO,CAAC;IACf,kBAAkB,CAAC,EAAE,OAAO,CAAC;CAC9B,kBAiCF,CAAC;AAEF,OAAO,EAAE,iBAAiB,EAAE,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import download from 'download';
|
|
2
|
+
import { RosenAssetsDownloadError } from './error';
|
|
2
3
|
import { findLatestReleaseByPrefixTag, findLatestStableReleaseByPrefixTag, getReleaseByTag, } from './utils/github';
|
|
3
4
|
import { isValidOS } from './utils/rosen';
|
|
4
|
-
import { RosenAssetsDownloadError } from './error';
|
|
5
5
|
const repo = 'sign-protocols';
|
|
6
6
|
/**
|
|
7
7
|
* Download release asset by tag to a specific path
|
|
@@ -42,4 +42,4 @@ const downloadTssBinary = async (destinationPath, config) => {
|
|
|
42
42
|
}
|
|
43
43
|
};
|
|
44
44
|
export { downloadTssBinary };
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG93bmxvYWRUc3NCaW5hcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvZG93bmxvYWRUc3NCaW5hcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxRQUFRLE1BQU0sVUFBVSxDQUFDO0FBRWhDLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUNuRCxPQUFPLEVBQ0wsNEJBQTRCLEVBQzVCLGtDQUFrQyxFQUNsQyxlQUFlLEdBQ2hCLE1BQU0sZ0JBQWdCLENBQUM7QUFDeEIsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxQyxNQUFNLElBQUksR0FBRyxnQkFBZ0IsQ0FBQztBQUU5Qjs7OztHQUlHO0FBQ0gsTUFBTSxpQkFBaUIsR0FBRyxLQUFLLEVBQzdCLGVBQXVCLEVBQ3ZCLE1BS0MsRUFDRCxFQUFFO0lBQ0YsTUFBTSxVQUFVLEdBQUcsR0FBRyxFQUFFO1FBQ3RCLElBQUksTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ2pCLElBQUksTUFBTSxFQUFFLGtCQUFrQjtnQkFDNUIsT0FBTyw0QkFBNEIsQ0FBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDOztnQkFDbkQsT0FBTyxrQ0FBa0MsQ0FBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ25FLENBQUM7O1lBQU0sT0FBTyxlQUFlLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNsRCxDQUFDLENBQUM7SUFDRixJQUFJLENBQUM7UUFDSCxNQUFNLE9BQU8sR0FBRyxNQUFNLFVBQVUsRUFBRSxDQUFDO1FBRW5DLElBQUksT0FBTyxFQUFFLENBQUM7WUFDWixNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQUM7Z0JBQ2hCLEdBQUcsQ0FBQyxPQUFPO29CQUNULE9BQU8sQ0FBQyxNQUFNO3lCQUNYLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7eUJBQ3ZELEdBQUcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FDbkIsUUFBUSxDQUFDLEtBQUssQ0FBQyxvQkFBb0IsRUFBRSxlQUFlLENBQUMsQ0FDdEQsQ0FBQzthQUNQLENBQUMsQ0FBQztRQUNMLENBQUM7YUFBTSxDQUFDO1lBQ04sT0FBTyxDQUFDLEtBQUssQ0FBQyx5QkFBeUIsTUFBTSxDQUFDLE1BQU0sWUFBWSxDQUFDLENBQUM7UUFDcEUsQ0FBQztJQUNILENBQUM7SUFBQyxPQUFPLEtBQUssRUFBRSxDQUFDO1FBQ2YsT0FBTyxDQUFDLEtBQUssQ0FDWCw4REFBOEQsS0FBSyxFQUFFLENBQ3RFLENBQUM7UUFDRixJQUFJLEtBQUssWUFBWSxLQUFLLEVBQUUsQ0FBQztZQUMzQixPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM3QixDQUFDO1FBQ0QsTUFBTSxJQUFJLHdCQUF3QixDQUFDLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQzNELENBQUM7QUFDSCxDQUFDLENBQUM7QUFFRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBkb3dubG9hZCBmcm9tICdkb3dubG9hZCc7XG5cbmltcG9ydCB7IFJvc2VuQXNzZXRzRG93bmxvYWRFcnJvciB9IGZyb20gJy4vZXJyb3InO1xuaW1wb3J0IHtcbiAgZmluZExhdGVzdFJlbGVhc2VCeVByZWZpeFRhZyxcbiAgZmluZExhdGVzdFN0YWJsZVJlbGVhc2VCeVByZWZpeFRhZyxcbiAgZ2V0UmVsZWFzZUJ5VGFnLFxufSBmcm9tICcuL3V0aWxzL2dpdGh1Yic7XG5pbXBvcnQgeyBpc1ZhbGlkT1MgfSBmcm9tICcuL3V0aWxzL3Jvc2VuJztcblxuY29uc3QgcmVwbyA9ICdzaWduLXByb3RvY29scyc7XG5cbi8qKlxuICogRG93bmxvYWQgcmVsZWFzZSBhc3NldCBieSB0YWcgdG8gYSBzcGVjaWZpYyBwYXRoXG4gKiBAcGFyYW0gZGVzdGluYXRpb25QYXRoIHdoZXJlIHdyaXRlcyBmaWxlc1xuICogQHBhcmFtIGNvbmZpZyBjb25maWdzIGZvciBpbmNsdWRpbmcgcHJlcmVsZWFzZXMsIHNldCBvc05hbWUsIGdldHRpbmcgc3BlY2lmaWMgcmVsZWFzZSBieSB0YWcgb3IgYnkgcmVnZXggdGFnXG4gKi9cbmNvbnN0IGRvd25sb2FkVHNzQmluYXJ5ID0gYXN5bmMgKFxuICBkZXN0aW5hdGlvblBhdGg6IHN0cmluZyxcbiAgY29uZmlnOiB7XG4gICAgb3NOYW1lOiBzdHJpbmc7XG4gICAgdGFnOiBzdHJpbmc7XG4gICAgcmVnZXg6IGJvb2xlYW47XG4gICAgaW5jbHVkZVByZXJlbGVhc2VzPzogYm9vbGVhbjtcbiAgfSxcbikgPT4ge1xuICBjb25zdCBnZXRSZWxlYXNlID0gKCkgPT4ge1xuICAgIGlmIChjb25maWcucmVnZXgpIHtcbiAgICAgIGlmIChjb25maWc/LmluY2x1ZGVQcmVyZWxlYXNlcylcbiAgICAgICAgcmV0dXJuIGZpbmRMYXRlc3RSZWxlYXNlQnlQcmVmaXhUYWcocmVwbywgY29uZmlnLnRhZyk7XG4gICAgICBlbHNlIHJldHVybiBmaW5kTGF0ZXN0U3RhYmxlUmVsZWFzZUJ5UHJlZml4VGFnKHJlcG8sIGNvbmZpZy50YWcpO1xuICAgIH0gZWxzZSByZXR1cm4gZ2V0UmVsZWFzZUJ5VGFnKHJlcG8sIGNvbmZpZy50YWcpO1xuICB9O1xuICB0cnkge1xuICAgIGNvbnN0IHJlbGVhc2UgPSBhd2FpdCBnZXRSZWxlYXNlKCk7XG5cbiAgICBpZiAocmVsZWFzZSkge1xuICAgICAgYXdhaXQgUHJvbWlzZS5hbGwoW1xuICAgICAgICAuLi4ocmVsZWFzZSAmJlxuICAgICAgICAgIHJlbGVhc2UuYXNzZXRzXG4gICAgICAgICAgICAuZmlsdGVyKChhc3NldCkgPT4gaXNWYWxpZE9TKGNvbmZpZy5vc05hbWUpKGFzc2V0Lm5hbWUpKVxuICAgICAgICAgICAgLm1hcChhc3luYyAoYXNzZXQpID0+XG4gICAgICAgICAgICAgIGRvd25sb2FkKGFzc2V0LmJyb3dzZXJfZG93bmxvYWRfdXJsLCBkZXN0aW5hdGlvblBhdGgpLFxuICAgICAgICAgICAgKSksXG4gICAgICBdKTtcbiAgICB9IGVsc2Uge1xuICAgICAgY29uc29sZS5lcnJvcihgTm8gcmVsZWFzZSBmb3VuZCBmb3IgWyR7Y29uZmlnLm9zTmFtZX1dIE9TIG5hbWUuYCk7XG4gICAgfVxuICB9IGNhdGNoIChlcnJvcikge1xuICAgIGNvbnNvbGUuZXJyb3IoXG4gICAgICBgQW4gZXJyb3Igb2NjdXJyZWQgd2hpbGUgdHJ5aW5nIHRvIGRvd25sb2FkIHJlbGVhc2UgYXNzZXRzOiAke2Vycm9yfWAsXG4gICAgKTtcbiAgICBpZiAoZXJyb3IgaW5zdGFuY2VvZiBFcnJvcikge1xuICAgICAgY29uc29sZS5lcnJvcihlcnJvci5zdGFjayk7XG4gICAgfVxuICAgIHRocm93IG5ldyBSb3NlbkFzc2V0c0Rvd25sb2FkRXJyb3IoJycsIHsgY2F1c2U6IGVycm9yIH0pO1xuICB9XG59O1xuXG5leHBvcnQgeyBkb3dubG9hZFRzc0JpbmFyeSB9O1xuIl19
|
package/dist/types/index.d.ts
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { Octokit } from 'octokit';
|
|
2
|
-
export type ArrayElement<T extends any[]> = T extends (infer Element)[] ? Element : never;
|
|
3
2
|
type GithubReleases = Awaited<ReturnType<InstanceType<typeof Octokit>['rest']['repos']['listReleases']>>['data'];
|
|
4
|
-
export type GithubRelease =
|
|
3
|
+
export type GithubRelease = GithubReleases[number];
|
|
5
4
|
export type SupportedRepo = 'contract' | 'sign-protocols';
|
|
6
5
|
export {};
|
|
7
6
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../lib/types/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAElC,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../lib/types/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAElC,KAAK,cAAc,GAAG,OAAO,CAC3B,UAAU,CAAC,YAAY,CAAC,OAAO,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,cAAc,CAAC,CAAC,CAC1E,CAAC,MAAM,CAAC,CAAC;AAEV,MAAM,MAAM,aAAa,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;AAEnD,MAAM,MAAM,aAAa,GAAG,UAAU,GAAG,gBAAgB,CAAC"}
|
package/dist/types/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9jdG9raXQgfSBmcm9tICdvY3Rva2l0JztcblxudHlwZSBHaXRodWJSZWxlYXNlcyA9IEF3YWl0ZWQ8XG4gIFJldHVyblR5cGU8SW5zdGFuY2VUeXBlPHR5cGVvZiBPY3Rva2l0PlsncmVzdCddWydyZXBvcyddWydsaXN0UmVsZWFzZXMnXT5cbj5bJ2RhdGEnXTtcblxuZXhwb3J0IHR5cGUgR2l0aHViUmVsZWFzZSA9IEdpdGh1YlJlbGVhc2VzW251bWJlcl07XG5cbmV4cG9ydCB0eXBlIFN1cHBvcnRlZFJlcG8gPSAnY29udHJhY3QnIHwgJ3NpZ24tcHJvdG9jb2xzJztcbiJdfQ==
|
package/dist/utils/github.d.ts
CHANGED
|
@@ -2,8 +2,8 @@ import { GithubRelease, SupportedRepo } from '../types';
|
|
|
2
2
|
/**
|
|
3
3
|
* Fetch a page of releases from Github Api in each iteration until there are no
|
|
4
4
|
* more releases.
|
|
5
|
-
* @param repoName
|
|
6
|
-
* @param pageSize
|
|
5
|
+
* @param repoName GitHub repository name to fetch releases from
|
|
6
|
+
* @param pageSize number of releases fetched per page
|
|
7
7
|
*/
|
|
8
8
|
declare function fetchReleasesPage(repoName: SupportedRepo, pageSize?: number): AsyncGenerator<{
|
|
9
9
|
url: string;
|
|
@@ -33,8 +33,8 @@ declare function fetchReleasesPage(repoName: SupportedRepo, pageSize?: number):
|
|
|
33
33
|
/**
|
|
34
34
|
* Find the last release matching the predicate. If all releases are iterated and
|
|
35
35
|
* no matching release is found, return null.
|
|
36
|
-
* @param repoName
|
|
37
|
-
* @param predicate
|
|
36
|
+
* @param repoName GitHub repository name to search in
|
|
37
|
+
* @param predicate custom function to determine release matching
|
|
38
38
|
*/
|
|
39
39
|
declare const findLastRelease: (repoName: SupportedRepo, predicate?: (release: GithubRelease) => boolean) => Promise<{
|
|
40
40
|
url: string;
|
|
@@ -63,8 +63,8 @@ declare const findLastRelease: (repoName: SupportedRepo, predicate?: (release: G
|
|
|
63
63
|
} | null>;
|
|
64
64
|
/**
|
|
65
65
|
* get a GitHub release by its tag
|
|
66
|
-
* @param repoName
|
|
67
|
-
* @param tag
|
|
66
|
+
* @param repoName GitHub repository name
|
|
67
|
+
* @param tag exact tag of the release to fetch
|
|
68
68
|
*/
|
|
69
69
|
declare const getReleaseByTag: (repoName: SupportedRepo, tag: string) => Promise<{
|
|
70
70
|
url: string;
|
|
@@ -94,32 +94,32 @@ declare const getReleaseByTag: (repoName: SupportedRepo, tag: string) => Promise
|
|
|
94
94
|
/**
|
|
95
95
|
* Return a function which checks if a release has at least one asset for a
|
|
96
96
|
* specific chain type
|
|
97
|
-
* @param chainType
|
|
98
|
-
* @param release
|
|
97
|
+
* @param chainType chain type used to validate asset names
|
|
98
|
+
* @param release GitHub release whose assets will be checked
|
|
99
99
|
*/
|
|
100
100
|
declare const hasAssetForChainType: (chainType: string) => (release: GithubRelease) => boolean;
|
|
101
101
|
/**
|
|
102
102
|
* Return a function which checks if a release is a stable (that is, non-prerelease)
|
|
103
103
|
* and has some asset matching a specific chain type
|
|
104
|
-
* @param chainType
|
|
104
|
+
* @param chainType chain type to validate assets against
|
|
105
105
|
*/
|
|
106
106
|
declare const isStableReleaseForChainType: (chainType: string) => (release: GithubRelease) => boolean;
|
|
107
107
|
/**
|
|
108
108
|
* Return a function which checks if tagPrefix is matched with release tag_name
|
|
109
|
-
* @param tagPrefix
|
|
109
|
+
* @param tagPrefix prefix used to filter release tags
|
|
110
110
|
*/
|
|
111
111
|
declare const hasMatchedTagPrefix: (tagPrefix: string) => (release: GithubRelease) => boolean;
|
|
112
112
|
/**
|
|
113
113
|
* Return a function which checks if a release is a stable (that is, non-prerelease),
|
|
114
114
|
* and tagPrefix is matched with release tag_name
|
|
115
|
-
* @param tagPrefix
|
|
115
|
+
* @param tagPrefix tag prefix used for matching
|
|
116
116
|
*/
|
|
117
117
|
declare const isStableReleaseForRegexTagType: (tagPrefix: string) => (release: GithubRelease) => boolean;
|
|
118
118
|
/**
|
|
119
119
|
* Find latest release (prerelease or non-prerelease) having some asset matching
|
|
120
120
|
* a specific chain type
|
|
121
|
-
* @param repoName
|
|
122
|
-
* @param chainType
|
|
121
|
+
* @param repoName GitHub repository name
|
|
122
|
+
* @param chainType chain type to filter by
|
|
123
123
|
*/
|
|
124
124
|
declare const findLatestRelease: (repoName: SupportedRepo, chainType: string) => Promise<{
|
|
125
125
|
url: string;
|
|
@@ -149,8 +149,8 @@ declare const findLatestRelease: (repoName: SupportedRepo, chainType: string) =>
|
|
|
149
149
|
/**
|
|
150
150
|
* Find latest stable (that is, non-prerelease) release having some asset matching
|
|
151
151
|
* a specific chain type
|
|
152
|
-
* @param repoName
|
|
153
|
-
* @param chainType
|
|
152
|
+
* @param repoName GitHub repository name
|
|
153
|
+
* @param chainType chain type to filter by
|
|
154
154
|
*/
|
|
155
155
|
declare const findLatestStableRelease: (repoName: SupportedRepo, chainType: string) => Promise<{
|
|
156
156
|
url: string;
|
|
@@ -179,8 +179,8 @@ declare const findLatestStableRelease: (repoName: SupportedRepo, chainType: stri
|
|
|
179
179
|
} | null>;
|
|
180
180
|
/**
|
|
181
181
|
* Find the latest stable (that is, non-prerelease) release that tagPrefix is matched with release tag_name
|
|
182
|
-
* @param repoName
|
|
183
|
-
* @param
|
|
182
|
+
* @param repoName GitHub repository name
|
|
183
|
+
* @param chainType chain type to filter by
|
|
184
184
|
*/
|
|
185
185
|
declare const findLatestStableReleaseByPrefixTag: (repoName: SupportedRepo, tagPrefix: string) => Promise<{
|
|
186
186
|
url: string;
|
|
@@ -209,8 +209,8 @@ declare const findLatestStableReleaseByPrefixTag: (repoName: SupportedRepo, tagP
|
|
|
209
209
|
} | null>;
|
|
210
210
|
/**
|
|
211
211
|
* Find the latest release that tagPrefix is matched with release tag_name
|
|
212
|
-
* @param repoName
|
|
213
|
-
* @param tagPrefix
|
|
212
|
+
* @param repoName GitHub repository name
|
|
213
|
+
* @param tagPrefix prefix used for matching tag names
|
|
214
214
|
*/
|
|
215
215
|
declare const findLatestReleaseByPrefixTag: (repoName: SupportedRepo, tagPrefix: string) => Promise<{
|
|
216
216
|
url: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"github.d.ts","sourceRoot":"","sources":["../../lib/utils/github.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"github.d.ts","sourceRoot":"","sources":["../../lib/utils/github.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAGxD;;;;;GAKG;AACH,iBAAgB,iBAAiB,CAC/B,QAAQ,EAAE,aAAa,EACvB,QAAQ,SAAsC;;;;;;;;;;;;;;;;;YAuJoiq0B,sDAAsB;YAA8B,sDAAsB;;;;;gBAA0P,sDAAsB;oBAlI76q0B;AAED;;;;;GAKG;AACH,QAAA,MAAM,eAAe,GACnB,UAAU,aAAa,EAEvB,YAAW,CAAC,OAAO,EAAE,aAAa,KAAK,OAAoB;;;;;;;;;;;;;;;;;YAuHuhq0B,sDAAsB;YAA8B,sDAAsB;;;;;gBAA0P,sDAAsB;SA3G76q0B,CAAC;AAEF;;;;GAIG;AACH,QAAA,MAAM,eAAe,GAAU,UAAU,aAAa,EAAE,KAAK,MAAM;;;;;;;;;;;;;;;;;YAoGihq0B,sDAAsB;YAA8B,sDAAsB;;;;;gBAA0P,sDAAsB;EA3F76q0B,CAAC;AAEF;;;;;GAKG;AACH,QAAA,MAAM,oBAAoB,GAAI,WAAW,MAAM,MAAM,SAAS,aAAa,YACE,CAAC;AAE9E;;;;GAIG;AACH,QAAA,MAAM,2BAA2B,GAC9B,WAAW,MAAM,MAAM,SAAS,aAAa,YACmB,CAAC;AAEpE;;;GAGG;AACH,QAAA,MAAM,mBAAmB,GAAI,WAAW,MAAM,MAAM,SAAS,aAAa,YAGzE,CAAC;AAEF;;;;GAIG;AACH,QAAA,MAAM,8BAA8B,GACjC,WAAW,MAAM,MAAM,SAAS,aAAa,YACkB,CAAC;AAEnE;;;;;GAKG;AACH,QAAA,MAAM,iBAAiB,GAAU,UAAU,aAAa,EAAE,WAAW,MAAM;;;;;;;;;;;;;;;;;YA+Cygq0B,sDAAsB;YAA8B,sDAAsB;;;;;gBAA0P,sDAAsB;SA9Cl3q0B,CAAC;AAE7D;;;;;GAKG;AACH,QAAA,MAAM,uBAAuB,GAC3B,UAAU,aAAa,EACvB,WAAW,MAAM;;;;;;;;;;;;;;;;;YAoCikq0B,sDAAsB;YAA8B,sDAAsB;;;;;gBAA0P,sDAAsB;SAnCx2q0B,CAAC;AAEvE;;;;GAIG;AACH,QAAA,MAAM,kCAAkC,GACtC,UAAU,aAAa,EACvB,WAAW,MAAM;;;;;;;;;;;;;;;;;YA0Bikq0B,sDAAsB;YAA8B,sDAAsB;;;;;gBAA0P,sDAAsB;SAzBr2q0B,CAAC;AAE1E;;;;GAIG;AACH,QAAA,MAAM,4BAA4B,GAChC,UAAU,aAAa,EACvB,WAAW,MAAM;;;;;;;;;;;;;;;;;YAgBikq0B,sDAAsB;YAA8B,sDAAsB;;;;;gBAA0P,sDAAsB;SAfh3q0B,CAAC;AAE/D,OAAO,EACL,iBAAiB,EACjB,eAAe,EACf,iBAAiB,EACjB,uBAAuB,EACvB,kCAAkC,EAClC,4BAA4B,EAC5B,eAAe,EACf,oBAAoB,EACpB,2BAA2B,EAC3B,8BAA8B,EAC9B,mBAAmB,GACpB,CAAC"}
|
package/dist/utils/github.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { Octokit } from 'octokit';
|
|
2
|
-
import { isValidAssetName } from './rosen';
|
|
3
2
|
import { DEFAULT_RELEASES_FETCHING_PAGE_SIZE, ROSEN_BRIDGE_ORGANIZATION, } from '../constants';
|
|
3
|
+
import { isValidAssetName } from './rosen';
|
|
4
4
|
/**
|
|
5
5
|
* Fetch a page of releases from Github Api in each iteration until there are no
|
|
6
6
|
* more releases.
|
|
7
|
-
* @param repoName
|
|
8
|
-
* @param pageSize
|
|
7
|
+
* @param repoName GitHub repository name to fetch releases from
|
|
8
|
+
* @param pageSize number of releases fetched per page
|
|
9
9
|
*/
|
|
10
10
|
async function* fetchReleasesPage(repoName, pageSize = DEFAULT_RELEASES_FETCHING_PAGE_SIZE) {
|
|
11
11
|
const octokit = new Octokit();
|
|
@@ -29,8 +29,8 @@ async function* fetchReleasesPage(repoName, pageSize = DEFAULT_RELEASES_FETCHING
|
|
|
29
29
|
/**
|
|
30
30
|
* Find the last release matching the predicate. If all releases are iterated and
|
|
31
31
|
* no matching release is found, return null.
|
|
32
|
-
* @param repoName
|
|
33
|
-
* @param predicate
|
|
32
|
+
* @param repoName GitHub repository name to search in
|
|
33
|
+
* @param predicate custom function to determine release matching
|
|
34
34
|
*/
|
|
35
35
|
const findLastRelease = async (repoName, predicate = () => true) => {
|
|
36
36
|
const releasesPageIterator = fetchReleasesPage(repoName);
|
|
@@ -44,8 +44,8 @@ const findLastRelease = async (repoName, predicate = () => true) => {
|
|
|
44
44
|
};
|
|
45
45
|
/**
|
|
46
46
|
* get a GitHub release by its tag
|
|
47
|
-
* @param repoName
|
|
48
|
-
* @param tag
|
|
47
|
+
* @param repoName GitHub repository name
|
|
48
|
+
* @param tag exact tag of the release to fetch
|
|
49
49
|
*/
|
|
50
50
|
const getReleaseByTag = async (repoName, tag) => {
|
|
51
51
|
const octokit = new Octokit();
|
|
@@ -59,19 +59,19 @@ const getReleaseByTag = async (repoName, tag) => {
|
|
|
59
59
|
/**
|
|
60
60
|
* Return a function which checks if a release has at least one asset for a
|
|
61
61
|
* specific chain type
|
|
62
|
-
* @param chainType
|
|
63
|
-
* @param release
|
|
62
|
+
* @param chainType chain type used to validate asset names
|
|
63
|
+
* @param release GitHub release whose assets will be checked
|
|
64
64
|
*/
|
|
65
65
|
const hasAssetForChainType = (chainType) => (release) => release.assets.map((asset) => asset.name).some(isValidAssetName(chainType));
|
|
66
66
|
/**
|
|
67
67
|
* Return a function which checks if a release is a stable (that is, non-prerelease)
|
|
68
68
|
* and has some asset matching a specific chain type
|
|
69
|
-
* @param chainType
|
|
69
|
+
* @param chainType chain type to validate assets against
|
|
70
70
|
*/
|
|
71
71
|
const isStableReleaseForChainType = (chainType) => (release) => !release.prerelease && hasAssetForChainType(chainType)(release);
|
|
72
72
|
/**
|
|
73
73
|
* Return a function which checks if tagPrefix is matched with release tag_name
|
|
74
|
-
* @param tagPrefix
|
|
74
|
+
* @param tagPrefix prefix used to filter release tags
|
|
75
75
|
*/
|
|
76
76
|
const hasMatchedTagPrefix = (tagPrefix) => (release) => {
|
|
77
77
|
const regex = new RegExp(`^${tagPrefix}`);
|
|
@@ -80,34 +80,34 @@ const hasMatchedTagPrefix = (tagPrefix) => (release) => {
|
|
|
80
80
|
/**
|
|
81
81
|
* Return a function which checks if a release is a stable (that is, non-prerelease),
|
|
82
82
|
* and tagPrefix is matched with release tag_name
|
|
83
|
-
* @param tagPrefix
|
|
83
|
+
* @param tagPrefix tag prefix used for matching
|
|
84
84
|
*/
|
|
85
85
|
const isStableReleaseForRegexTagType = (tagPrefix) => (release) => !release.prerelease && hasMatchedTagPrefix(tagPrefix)(release);
|
|
86
86
|
/**
|
|
87
87
|
* Find latest release (prerelease or non-prerelease) having some asset matching
|
|
88
88
|
* a specific chain type
|
|
89
|
-
* @param repoName
|
|
90
|
-
* @param chainType
|
|
89
|
+
* @param repoName GitHub repository name
|
|
90
|
+
* @param chainType chain type to filter by
|
|
91
91
|
*/
|
|
92
92
|
const findLatestRelease = async (repoName, chainType) => findLastRelease(repoName, hasAssetForChainType(chainType));
|
|
93
93
|
/**
|
|
94
94
|
* Find latest stable (that is, non-prerelease) release having some asset matching
|
|
95
95
|
* a specific chain type
|
|
96
|
-
* @param repoName
|
|
97
|
-
* @param chainType
|
|
96
|
+
* @param repoName GitHub repository name
|
|
97
|
+
* @param chainType chain type to filter by
|
|
98
98
|
*/
|
|
99
99
|
const findLatestStableRelease = async (repoName, chainType) => findLastRelease(repoName, isStableReleaseForChainType(chainType));
|
|
100
100
|
/**
|
|
101
101
|
* Find the latest stable (that is, non-prerelease) release that tagPrefix is matched with release tag_name
|
|
102
|
-
* @param repoName
|
|
103
|
-
* @param
|
|
102
|
+
* @param repoName GitHub repository name
|
|
103
|
+
* @param chainType chain type to filter by
|
|
104
104
|
*/
|
|
105
105
|
const findLatestStableReleaseByPrefixTag = async (repoName, tagPrefix) => findLastRelease(repoName, isStableReleaseForRegexTagType(tagPrefix));
|
|
106
106
|
/**
|
|
107
107
|
* Find the latest release that tagPrefix is matched with release tag_name
|
|
108
|
-
* @param repoName
|
|
109
|
-
* @param tagPrefix
|
|
108
|
+
* @param repoName GitHub repository name
|
|
109
|
+
* @param tagPrefix prefix used for matching tag names
|
|
110
110
|
*/
|
|
111
111
|
const findLatestReleaseByPrefixTag = async (repoName, tagPrefix) => findLastRelease(repoName, hasMatchedTagPrefix(tagPrefix));
|
|
112
112
|
export { fetchReleasesPage, findLastRelease, findLatestRelease, findLatestStableRelease, findLatestStableReleaseByPrefixTag, findLatestReleaseByPrefixTag, getReleaseByTag, hasAssetForChainType, isStableReleaseForChainType, isStableReleaseForRegexTagType, hasMatchedTagPrefix, };
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"github.js","sourceRoot":"","sources":["../../lib/utils/github.ts"],"names":[],"mappings":"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","sourcesContent":["import { Octokit } from 'octokit';\n\nimport { isValidAssetName } from './rosen';\n\nimport {\n  DEFAULT_RELEASES_FETCHING_PAGE_SIZE,\n  ROSEN_BRIDGE_ORGANIZATION,\n} from '../constants';\n\nimport { GithubRelease, SupportedRepo } from '../types';\n\n/**\n * Fetch a page of releases from Github Api in each iteration until there are no\n * more releases.\n * @param repoName\n * @param pageSize\n */\nasync function* fetchReleasesPage(\n  repoName: SupportedRepo,\n  pageSize = DEFAULT_RELEASES_FETCHING_PAGE_SIZE,\n) {\n  const octokit = new Octokit();\n\n  let currentPage = 1;\n\n  while (true) {\n    const releasesPage = await octokit.rest.repos.listReleases({\n      owner: ROSEN_BRIDGE_ORGANIZATION,\n      repo: repoName,\n      per_page: pageSize,\n      page: currentPage,\n    });\n\n    if (releasesPage.data.length) {\n      yield releasesPage.data;\n      currentPage += 1;\n    } else {\n      return;\n    }\n  }\n}\n\n/**\n * Find the last release matching the predicate. If all releases are iterated and\n * no matching release is found, return null.\n * @param repoName\n * @param predicate\n */\nconst findLastRelease = async (\n  repoName: SupportedRepo,\n\n  predicate: (release: GithubRelease) => boolean = () => true,\n) => {\n  const releasesPageIterator = fetchReleasesPage(repoName);\n\n  for await (const releasesPage of releasesPageIterator) {\n    const foundRelease = releasesPage.find(predicate);\n\n    if (foundRelease) {\n      return foundRelease;\n    }\n  }\n  return null;\n};\n\n/**\n * get a GitHub release by its tag\n * @param repoName\n * @param tag\n */\nconst getReleaseByTag = async (repoName: SupportedRepo, tag: string) => {\n  const octokit = new Octokit();\n  const release = await octokit.rest.repos.getReleaseByTag({\n    owner: ROSEN_BRIDGE_ORGANIZATION,\n    repo: repoName,\n    tag,\n  });\n\n  return release.data;\n};\n\n/**\n * Return a function which checks if a release has at least one asset for a\n * specific chain type\n * @param chainType\n * @param release\n */\nconst hasAssetForChainType = (chainType: string) => (release: GithubRelease) =>\n  release.assets.map((asset) => asset.name).some(isValidAssetName(chainType));\n\n/**\n * Return a function which checks if a release is a stable (that is, non-prerelease)\n * and has some asset matching a specific chain type\n * @param chainType\n */\nconst isStableReleaseForChainType =\n  (chainType: string) => (release: GithubRelease) =>\n    !release.prerelease && hasAssetForChainType(chainType)(release);\n\n/**\n * Return a function which checks if tagPrefix is matched with release tag_name\n * @param tagPrefix\n */\nconst hasMatchedTagPrefix = (tagPrefix: string) => (release: GithubRelease) => {\n  const regex = new RegExp(`^${tagPrefix}`);\n  return regex.test(release.tag_name);\n};\n\n/**\n * Return a function which checks if a release is a stable (that is, non-prerelease),\n * and tagPrefix is matched with release tag_name\n * @param tagPrefix\n */\nconst isStableReleaseForRegexTagType =\n  (tagPrefix: string) => (release: GithubRelease) =>\n    !release.prerelease && hasMatchedTagPrefix(tagPrefix)(release);\n\n/**\n * Find latest release (prerelease or non-prerelease) having some asset matching\n * a specific chain type\n * @param repoName\n * @param chainType\n */\nconst findLatestRelease = async (repoName: SupportedRepo, chainType: string) =>\n  findLastRelease(repoName, hasAssetForChainType(chainType));\n\n/**\n * Find latest stable (that is, non-prerelease) release having some asset matching\n * a specific chain type\n * @param repoName\n * @param chainType\n */\nconst findLatestStableRelease = async (\n  repoName: SupportedRepo,\n  chainType: string,\n) => findLastRelease(repoName, isStableReleaseForChainType(chainType));\n\n/**\n * Find the latest stable (that is, non-prerelease) release that tagPrefix is matched with release tag_name\n * @param repoName\n * @param tagPrefix\n */\nconst findLatestStableReleaseByPrefixTag = async (\n  repoName: SupportedRepo,\n  tagPrefix: string,\n) => findLastRelease(repoName, isStableReleaseForRegexTagType(tagPrefix));\n\n/**\n * Find the latest release that tagPrefix is matched with release tag_name\n * @param repoName\n * @param tagPrefix\n */\nconst findLatestReleaseByPrefixTag = async (\n  repoName: SupportedRepo,\n  tagPrefix: string,\n) => findLastRelease(repoName, hasMatchedTagPrefix(tagPrefix));\n\nexport {\n  fetchReleasesPage,\n  findLastRelease,\n  findLatestRelease,\n  findLatestStableRelease,\n  findLatestStableReleaseByPrefixTag,\n  findLatestReleaseByPrefixTag,\n  getReleaseByTag,\n  hasAssetForChainType,\n  isStableReleaseForChainType,\n  isStableReleaseForRegexTagType,\n  hasMatchedTagPrefix,\n};\n"]}
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"github.js","sourceRoot":"","sources":["../../lib/utils/github.ts"],"names":[],"mappings":"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","sourcesContent":["import { Octokit } from 'octokit';\n\nimport {\n  DEFAULT_RELEASES_FETCHING_PAGE_SIZE,\n  ROSEN_BRIDGE_ORGANIZATION,\n} from '../constants';\nimport { GithubRelease, SupportedRepo } from '../types';\nimport { isValidAssetName } from './rosen';\n\n/**\n * Fetch a page of releases from Github Api in each iteration until there are no\n * more releases.\n * @param repoName GitHub repository name to fetch releases from\n * @param pageSize number of releases fetched per page\n */\nasync function* fetchReleasesPage(\n  repoName: SupportedRepo,\n  pageSize = DEFAULT_RELEASES_FETCHING_PAGE_SIZE,\n) {\n  const octokit = new Octokit();\n\n  let currentPage = 1;\n\n  while (true) {\n    const releasesPage = await octokit.rest.repos.listReleases({\n      owner: ROSEN_BRIDGE_ORGANIZATION,\n      repo: repoName,\n      per_page: pageSize,\n      page: currentPage,\n    });\n\n    if (releasesPage.data.length) {\n      yield releasesPage.data;\n      currentPage += 1;\n    } else {\n      return;\n    }\n  }\n}\n\n/**\n * Find the last release matching the predicate. If all releases are iterated and\n * no matching release is found, return null.\n * @param repoName GitHub repository name to search in\n * @param predicate custom function to determine release matching\n */\nconst findLastRelease = async (\n  repoName: SupportedRepo,\n\n  predicate: (release: GithubRelease) => boolean = () => true,\n) => {\n  const releasesPageIterator = fetchReleasesPage(repoName);\n\n  for await (const releasesPage of releasesPageIterator) {\n    const foundRelease = releasesPage.find(predicate);\n\n    if (foundRelease) {\n      return foundRelease;\n    }\n  }\n  return null;\n};\n\n/**\n * get a GitHub release by its tag\n * @param repoName GitHub repository name\n * @param tag exact tag of the release to fetch\n */\nconst getReleaseByTag = async (repoName: SupportedRepo, tag: string) => {\n  const octokit = new Octokit();\n  const release = await octokit.rest.repos.getReleaseByTag({\n    owner: ROSEN_BRIDGE_ORGANIZATION,\n    repo: repoName,\n    tag,\n  });\n\n  return release.data;\n};\n\n/**\n * Return a function which checks if a release has at least one asset for a\n * specific chain type\n * @param chainType chain type used to validate asset names\n * @param release GitHub release whose assets will be checked\n */\nconst hasAssetForChainType = (chainType: string) => (release: GithubRelease) =>\n  release.assets.map((asset) => asset.name).some(isValidAssetName(chainType));\n\n/**\n * Return a function which checks if a release is a stable (that is, non-prerelease)\n * and has some asset matching a specific chain type\n * @param chainType chain type to validate assets against\n */\nconst isStableReleaseForChainType =\n  (chainType: string) => (release: GithubRelease) =>\n    !release.prerelease && hasAssetForChainType(chainType)(release);\n\n/**\n * Return a function which checks if tagPrefix is matched with release tag_name\n * @param tagPrefix prefix used to filter release tags\n */\nconst hasMatchedTagPrefix = (tagPrefix: string) => (release: GithubRelease) => {\n  const regex = new RegExp(`^${tagPrefix}`);\n  return regex.test(release.tag_name);\n};\n\n/**\n * Return a function which checks if a release is a stable (that is, non-prerelease),\n * and tagPrefix is matched with release tag_name\n * @param tagPrefix tag prefix used for matching\n */\nconst isStableReleaseForRegexTagType =\n  (tagPrefix: string) => (release: GithubRelease) =>\n    !release.prerelease && hasMatchedTagPrefix(tagPrefix)(release);\n\n/**\n * Find latest release (prerelease or non-prerelease) having some asset matching\n * a specific chain type\n * @param repoName GitHub repository name\n * @param chainType chain type to filter by\n */\nconst findLatestRelease = async (repoName: SupportedRepo, chainType: string) =>\n  findLastRelease(repoName, hasAssetForChainType(chainType));\n\n/**\n * Find latest stable (that is, non-prerelease) release having some asset matching\n * a specific chain type\n * @param repoName GitHub repository name\n * @param chainType chain type to filter by\n */\nconst findLatestStableRelease = async (\n  repoName: SupportedRepo,\n  chainType: string,\n) => findLastRelease(repoName, isStableReleaseForChainType(chainType));\n\n/**\n * Find the latest stable (that is, non-prerelease) release that tagPrefix is matched with release tag_name\n * @param repoName GitHub repository name\n * @param chainType chain type to filter by\n */\nconst findLatestStableReleaseByPrefixTag = async (\n  repoName: SupportedRepo,\n  tagPrefix: string,\n) => findLastRelease(repoName, isStableReleaseForRegexTagType(tagPrefix));\n\n/**\n * Find the latest release that tagPrefix is matched with release tag_name\n * @param repoName GitHub repository name\n * @param tagPrefix prefix used for matching tag names\n */\nconst findLatestReleaseByPrefixTag = async (\n  repoName: SupportedRepo,\n  tagPrefix: string,\n) => findLastRelease(repoName, hasMatchedTagPrefix(tagPrefix));\n\nexport {\n  fetchReleasesPage,\n  findLastRelease,\n  findLatestRelease,\n  findLatestStableRelease,\n  findLatestStableReleaseByPrefixTag,\n  findLatestReleaseByPrefixTag,\n  getReleaseByTag,\n  hasAssetForChainType,\n  isStableReleaseForChainType,\n  isStableReleaseForRegexTagType,\n  hasMatchedTagPrefix,\n};\n"]}
|
package/dist/utils/rosen.d.ts
CHANGED
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Check if an asset name is a valid Rosen asset name and matches a specific
|
|
3
3
|
* chain type
|
|
4
|
-
* @param chainType
|
|
4
|
+
* @param chainType chain type of the asset (e.g., mainnet, testnet)
|
|
5
5
|
*/
|
|
6
6
|
export declare const isValidAssetName: (chainType: string) => (assetName: string) => boolean;
|
|
7
7
|
/**
|
|
8
8
|
* Check if an OS name is a valid supported tss OS
|
|
9
|
-
* @param OSName
|
|
9
|
+
* @param OSName operating system name to match in release assets (e.g., linux, macOS, windows)
|
|
10
10
|
*/
|
|
11
11
|
export declare const isValidOS: (OSName: string) => (releaseAssetName: string) => boolean;
|
|
12
12
|
/**
|
|
13
13
|
* Remove chain type and tag from the asset name and optionally replaces them
|
|
14
14
|
* with a suffix
|
|
15
|
-
* @param assetName
|
|
16
|
-
* @param chainType
|
|
17
|
-
* @param releaseName
|
|
15
|
+
* @param assetName full asset file name from the release
|
|
16
|
+
* @param chainType chain type used in the asset file name
|
|
17
|
+
* @param releaseName release tag used in naming the asset
|
|
18
18
|
* @param alternativeSuffix a suffix which will be added before `.json` (if provided)
|
|
19
19
|
*/
|
|
20
20
|
export declare const truncateAssetName: (assetName: string, chainType: string, releaseName: string, alternativeSuffix?: string) => string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rosen.d.ts","sourceRoot":"","sources":["../../lib/utils/rosen.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,eAAO,MAAM,gBAAgB,GAAI,WAAW,MAAM,MAAM,WAAW,MAAM,
|
|
1
|
+
{"version":3,"file":"rosen.d.ts","sourceRoot":"","sources":["../../lib/utils/rosen.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,eAAO,MAAM,gBAAgB,GAAI,WAAW,MAAM,MAAM,WAAW,MAAM,YACC,CAAC;AAE3E;;;GAGG;AACH,eAAO,MAAM,SAAS,GAAI,QAAQ,MAAM,MAAM,kBAAkB,MAAM,YACJ,CAAC;AAEnE;;;;;;;GAOG;AACH,eAAO,MAAM,iBAAiB,GAC5B,WAAW,MAAM,EACjB,WAAW,MAAM,EACjB,aAAa,MAAM,EACnB,oBAAoB,MAAM,WAM3B,CAAC"}
|
package/dist/utils/rosen.js
CHANGED
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Check if an asset name is a valid Rosen asset name and matches a specific
|
|
3
3
|
* chain type
|
|
4
|
-
* @param chainType
|
|
4
|
+
* @param chainType chain type of the asset (e.g., mainnet, testnet)
|
|
5
5
|
*/
|
|
6
|
-
export const isValidAssetName = (chainType) => (assetName) => new RegExp(`(contracts
|
|
6
|
+
export const isValidAssetName = (chainType) => (assetName) => new RegExp(`(contracts|tokensMap)-${chainType}-.+.json`).test(assetName);
|
|
7
7
|
/**
|
|
8
8
|
* Check if an OS name is a valid supported tss OS
|
|
9
|
-
* @param OSName
|
|
9
|
+
* @param OSName operating system name to match in release assets (e.g., linux, macOS, windows)
|
|
10
10
|
*/
|
|
11
11
|
export const isValidOS = (OSName) => (releaseAssetName) => new RegExp(`(rosenTss-${OSName}-.+).zip`).test(releaseAssetName);
|
|
12
12
|
/**
|
|
13
13
|
* Remove chain type and tag from the asset name and optionally replaces them
|
|
14
14
|
* with a suffix
|
|
15
|
-
* @param assetName
|
|
16
|
-
* @param chainType
|
|
17
|
-
* @param releaseName
|
|
15
|
+
* @param assetName full asset file name from the release
|
|
16
|
+
* @param chainType chain type used in the asset file name
|
|
17
|
+
* @param releaseName release tag used in naming the asset
|
|
18
18
|
* @param alternativeSuffix a suffix which will be added before `.json` (if provided)
|
|
19
19
|
*/
|
|
20
20
|
export const truncateAssetName = (assetName, chainType, releaseName, alternativeSuffix) => {
|
|
@@ -23,4 +23,4 @@ export const truncateAssetName = (assetName, chainType, releaseName, alternative
|
|
|
23
23
|
? `${name}-${alternativeSuffix}.json`
|
|
24
24
|
: `${name}.json`;
|
|
25
25
|
};
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9zZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvdXRpbHMvcm9zZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNILE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLENBQUMsU0FBaUIsRUFBRSxFQUFFLENBQUMsQ0FBQyxTQUFpQixFQUFFLEVBQUUsQ0FDM0UsSUFBSSxNQUFNLENBQUMseUJBQXlCLFNBQVMsVUFBVSxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRTNFOzs7R0FHRztBQUNILE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBRyxDQUFDLE1BQWMsRUFBRSxFQUFFLENBQUMsQ0FBQyxnQkFBd0IsRUFBRSxFQUFFLENBQ3hFLElBQUksTUFBTSxDQUFDLGFBQWEsTUFBTSxVQUFVLENBQUMsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztBQUVuRTs7Ozs7OztHQU9HO0FBQ0gsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsQ0FDL0IsU0FBaUIsRUFDakIsU0FBaUIsRUFDakIsV0FBbUIsRUFDbkIsaUJBQTBCLEVBQzFCLEVBQUU7SUFDRixNQUFNLElBQUksR0FBRyxTQUFTLENBQUMsT0FBTyxDQUFDLElBQUksU0FBUyxJQUFJLFdBQVcsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3hFLE9BQU8saUJBQWlCO1FBQ3RCLENBQUMsQ0FBQyxHQUFHLElBQUksSUFBSSxpQkFBaUIsT0FBTztRQUNyQyxDQUFDLENBQUMsR0FBRyxJQUFJLE9BQU8sQ0FBQztBQUNyQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENoZWNrIGlmIGFuIGFzc2V0IG5hbWUgaXMgYSB2YWxpZCBSb3NlbiBhc3NldCBuYW1lIGFuZCBtYXRjaGVzIGEgc3BlY2lmaWNcbiAqIGNoYWluIHR5cGVcbiAqIEBwYXJhbSBjaGFpblR5cGUgY2hhaW4gdHlwZSBvZiB0aGUgYXNzZXQgKGUuZy4sIG1haW5uZXQsIHRlc3RuZXQpXG4gKi9cbmV4cG9ydCBjb25zdCBpc1ZhbGlkQXNzZXROYW1lID0gKGNoYWluVHlwZTogc3RyaW5nKSA9PiAoYXNzZXROYW1lOiBzdHJpbmcpID0+XG4gIG5ldyBSZWdFeHAoYChjb250cmFjdHN8dG9rZW5zTWFwKS0ke2NoYWluVHlwZX0tLisuanNvbmApLnRlc3QoYXNzZXROYW1lKTtcblxuLyoqXG4gKiBDaGVjayBpZiBhbiBPUyBuYW1lIGlzIGEgdmFsaWQgc3VwcG9ydGVkIHRzcyBPU1xuICogQHBhcmFtIE9TTmFtZSBvcGVyYXRpbmcgc3lzdGVtIG5hbWUgdG8gbWF0Y2ggaW4gcmVsZWFzZSBhc3NldHMgKGUuZy4sIGxpbnV4LCBtYWNPUywgd2luZG93cylcbiAqL1xuZXhwb3J0IGNvbnN0IGlzVmFsaWRPUyA9IChPU05hbWU6IHN0cmluZykgPT4gKHJlbGVhc2VBc3NldE5hbWU6IHN0cmluZykgPT5cbiAgbmV3IFJlZ0V4cChgKHJvc2VuVHNzLSR7T1NOYW1lfS0uKykuemlwYCkudGVzdChyZWxlYXNlQXNzZXROYW1lKTtcblxuLyoqXG4gKiBSZW1vdmUgY2hhaW4gdHlwZSBhbmQgdGFnIGZyb20gdGhlIGFzc2V0IG5hbWUgYW5kIG9wdGlvbmFsbHkgcmVwbGFjZXMgdGhlbVxuICogd2l0aCBhIHN1ZmZpeFxuICogQHBhcmFtIGFzc2V0TmFtZSBmdWxsIGFzc2V0IGZpbGUgbmFtZSBmcm9tIHRoZSByZWxlYXNlXG4gKiBAcGFyYW0gY2hhaW5UeXBlIGNoYWluIHR5cGUgdXNlZCBpbiB0aGUgYXNzZXQgZmlsZSBuYW1lXG4gKiBAcGFyYW0gcmVsZWFzZU5hbWUgcmVsZWFzZSB0YWcgdXNlZCBpbiBuYW1pbmcgdGhlIGFzc2V0XG4gKiBAcGFyYW0gYWx0ZXJuYXRpdmVTdWZmaXggYSBzdWZmaXggd2hpY2ggd2lsbCBiZSBhZGRlZCBiZWZvcmUgYC5qc29uYCAoaWYgcHJvdmlkZWQpXG4gKi9cbmV4cG9ydCBjb25zdCB0cnVuY2F0ZUFzc2V0TmFtZSA9IChcbiAgYXNzZXROYW1lOiBzdHJpbmcsXG4gIGNoYWluVHlwZTogc3RyaW5nLFxuICByZWxlYXNlTmFtZTogc3RyaW5nLFxuICBhbHRlcm5hdGl2ZVN1ZmZpeD86IHN0cmluZyxcbikgPT4ge1xuICBjb25zdCBuYW1lID0gYXNzZXROYW1lLnJlcGxhY2UoYC0ke2NoYWluVHlwZX0tJHtyZWxlYXNlTmFtZX0uanNvbmAsICcnKTtcbiAgcmV0dXJuIGFsdGVybmF0aXZlU3VmZml4XG4gICAgPyBgJHtuYW1lfS0ke2FsdGVybmF0aXZlU3VmZml4fS5qc29uYFxuICAgIDogYCR7bmFtZX0uanNvbmA7XG59O1xuIl19
|
package/package.json
CHANGED
|
@@ -1,7 +1,10 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@rosen-bridge/utils",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "3.0.0",
|
|
4
4
|
"description": "Misc utility functions used inside Rosen bridge projects",
|
|
5
|
+
"keywords": [
|
|
6
|
+
"rosen"
|
|
7
|
+
],
|
|
5
8
|
"repository": {
|
|
6
9
|
"type": "git",
|
|
7
10
|
"url": "git+https://github.com/rosen-bridge/utils.git"
|
|
@@ -11,40 +14,34 @@
|
|
|
11
14
|
"type": "module",
|
|
12
15
|
"main": "dist/index.js",
|
|
13
16
|
"types": "dist/index.d.ts",
|
|
17
|
+
"directories": {
|
|
18
|
+
"lib": "lib",
|
|
19
|
+
"test": "tests"
|
|
20
|
+
},
|
|
14
21
|
"files": [
|
|
15
22
|
"dist",
|
|
16
23
|
"CHANGELOG.md"
|
|
17
24
|
],
|
|
18
25
|
"scripts": {
|
|
19
|
-
"
|
|
20
|
-
"
|
|
26
|
+
"build": "tsc --build tsconfig.build.json",
|
|
27
|
+
"coverage": "npm run test -- --coverage",
|
|
21
28
|
"lint": "eslint --fix . && npm run prettify",
|
|
22
29
|
"lint:check": "eslint . && npm run prettify:check",
|
|
23
|
-
"
|
|
24
|
-
"
|
|
25
|
-
"
|
|
26
|
-
"
|
|
27
|
-
"
|
|
28
|
-
},
|
|
29
|
-
"devDependencies": {
|
|
30
|
-
"@babel/preset-env": "^7.19.0",
|
|
31
|
-
"@types/download": "^8.0.2",
|
|
32
|
-
"@types/jest": "^29.1.2",
|
|
33
|
-
"jest": "^29.2.0",
|
|
34
|
-
"ts-jest": "^29.0.3"
|
|
35
|
-
},
|
|
36
|
-
"directories": {
|
|
37
|
-
"lib": "lib",
|
|
38
|
-
"test": "tests"
|
|
30
|
+
"prettify": "prettier --write . --ignore-path ../../.gitignore",
|
|
31
|
+
"prettify:check": "prettier --check . --ignore-path ../../.gitignore",
|
|
32
|
+
"release": "npm run test && npm run build && npm publish --access public",
|
|
33
|
+
"test": "NODE_OPTIONS='--import tsx' vitest",
|
|
34
|
+
"type-check": "tsc --noEmit"
|
|
39
35
|
},
|
|
40
|
-
"keywords": [
|
|
41
|
-
"rosen"
|
|
42
|
-
],
|
|
43
36
|
"dependencies": {
|
|
44
37
|
"download": "^8.0.0",
|
|
45
38
|
"octokit": "^2.0.14"
|
|
46
39
|
},
|
|
40
|
+
"devDependencies": {
|
|
41
|
+
"@types/download": "^8.0.2"
|
|
42
|
+
},
|
|
47
43
|
"engines": {
|
|
48
|
-
"node": ">=22.18.0"
|
|
44
|
+
"node": ">=22.18.0",
|
|
45
|
+
"npm": "11.6.2"
|
|
49
46
|
}
|
|
50
47
|
}
|