@rosen-bridge/utils 1.0.0 → 2.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +12 -0
- package/dist/downloadRosenAssets.js +1 -1
- package/dist/downloadTssBinary.js +1 -1
- package/dist/utils/github.d.ts.map +1 -1
- package/dist/utils/github.js +1 -1
- package/dist/utils/rosen.js +1 -1
- package/package.json +19 -11
- package/.eslintignore +0 -1
- package/babel.config.json +0 -3
- package/jest.config.json +0 -7
- package/lib/constants.ts +0 -2
- package/lib/downloadRosenAssets.ts +0 -72
- package/lib/downloadTssBinary.ts +0 -61
- package/lib/error.ts +0 -3
- package/lib/index.ts +0 -4
- package/lib/types/index.ts +0 -13
- package/lib/utils/github.ts +0 -169
- package/lib/utils/rosen.ts +0 -34
- package/tests/data/octokit.data.ts +0 -210
- package/tests/downloadRosenAssets.spec.ts +0 -200
- package/tests/downloadTssBinary.spec.ts +0 -153
- package/tests/mocks/octokit.mock.ts +0 -41
- package/tests/setup.ts +0 -1
- package/tests/utils/github.spec.ts +0 -409
- package/tests/utils/rosen.spec.ts +0 -197
- package/tsconfig.build.json +0 -8
- package/tsconfig.build.tsbuildinfo +0 -1
- package/tsconfig.json +0 -8
package/CHANGELOG.md
CHANGED
|
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG93bmxvYWRSb3NlbkFzc2V0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL2xpYi9kb3dubG9hZFJvc2VuQXNzZXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sUUFBUSxNQUFNLFVBQVUsQ0FBQztBQUVoQyxPQUFPLEVBQ0wsaUJBQWlCLEVBQ2pCLHVCQUF1QixFQUN2QixlQUFlLEdBQ2hCLE1BQU0sZ0JBQWdCLENBQUM7QUFDeEIsT0FBTyxFQUFFLGdCQUFnQixFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXBFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUVuRCxNQUFNLElBQUksR0FBRyxVQUFVLENBQUM7QUFFeEI7Ozs7O0dBS0c7QUFDSCxNQUFNLG1CQUFtQixHQUFHLEtBQUssRUFDL0IsU0FBaUIsRUFDakIsZUFBdUIsRUFDdkIsTUFJQyxFQUNELEVBQUU7SUFDRixNQUFNLFVBQVUsR0FBRyxHQUFHLEVBQUU7UUFDdEIsSUFBSSxNQUFNLEVBQUUsR0FBRztZQUFFLE9BQU8sZUFBZSxDQUFDLElBQUksRUFBRSxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDMUQsSUFBSSxNQUFNLEVBQUUsa0JBQWtCO1lBQUUsT0FBTyxpQkFBaUIsQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDMUUsT0FBTyx1QkFBdUIsQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDbEQsQ0FBQyxDQUFDO0lBQ0YsSUFBSSxDQUFDO1FBQ0gsTUFBTSxPQUFPLEdBQUcsTUFBTSxVQUFVLEVBQUUsQ0FBQztRQUVuQyxJQUFJLE9BQU8sRUFBRSxDQUFDO1lBQ1osTUFBTSxPQUFPLENBQUMsR0FBRyxDQUFDO2dCQUNoQixHQUFHLENBQUMsT0FBTztvQkFDVCxPQUFPLENBQUMsTUFBTTt5QkFDWCxNQUFNLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLGdCQUFnQixDQUFDLFNBQVMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQzt5QkFDMUQsR0FBRyxDQUFDLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRSxDQUNuQixRQUFRLENBQUMsS0FBSyxDQUFDLG9CQUFvQixFQUFFLGVBQWUsRUFBRTt3QkFDcEQsUUFBUSxFQUFFLGlCQUFpQixDQUN6QixLQUFLLENBQUMsSUFBSSxFQUNWLFNBQVMsRUFDVCxPQUFPLENBQUMsUUFBUSxFQUNoQixNQUFNLEVBQUUsVUFBVSxDQUNuQjtxQkFDRixDQUFDLENBQ0gsQ0FBQzthQUNQLENBQUMsQ0FBQztRQUNMLENBQUM7YUFBTSxDQUFDO1lBQ04sT0FBTyxDQUFDLEtBQUssQ0FBQyx5QkFBeUIsU0FBUyxlQUFlLENBQUMsQ0FBQztZQUNqRSxJQUFJLENBQUMsTUFBTSxFQUFFLGtCQUFrQixFQUFFLENBQUM7Z0JBQ2hDLE9BQU8sQ0FBQyxLQUFLLENBQ1gsNEdBQTRHLENBQzdHLENBQUM7WUFDSixDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFBQyxPQUFPLEtBQUssRUFBRSxDQUFDO1FBQ2YsT0FBTyxDQUFDLEtBQUssQ0FDWCw0REFBNEQsS0FBSyxFQUFFLENBQ3BFLENBQUM7UUFDRixJQUFJLEtBQUssWUFBWSxLQUFLLEVBQUUsQ0FBQztZQUMzQixPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM3QixDQUFDO1FBQ0QsTUFBTSxJQUFJLHdCQUF3QixDQUFDLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQzNELENBQUM7QUFDSCxDQUFDLENBQUM7QUFFRixlQUFlLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGRvd25sb2FkIGZyb20gJ2Rvd25sb2FkJztcblxuaW1wb3J0IHtcbiAgZmluZExhdGVzdFJlbGVhc2UsXG4gIGZpbmRMYXRlc3RTdGFibGVSZWxlYXNlLFxuICBnZXRSZWxlYXNlQnlUYWcsXG59IGZyb20gJy4vdXRpbHMvZ2l0aHViJztcbmltcG9ydCB7IGlzVmFsaWRBc3NldE5hbWUsIHRydW5jYXRlQXNzZXROYW1lIH0gZnJvbSAnLi91dGlscy9yb3Nlbic7XG5cbmltcG9ydCB7IFJvc2VuQXNzZXRzRG93bmxvYWRFcnJvciB9IGZyb20gJy4vZXJyb3InO1xuXG5jb25zdCByZXBvID0gJ2NvbnRyYWN0JztcblxuLyoqXG4gKiBEb3dubG9hZCBhbGwgcmVxdWlyZWQgUm9zZW4gYXNzZXRzICh0b2tlbk1hcCBhbmQgYWxsIGNoYWluIGFkZHJlc3MgZmlsZXMpIHRvIGEgc3BlY2lmaWMgcGF0aFxuICogQHBhcmFtIGNoYWluVHlwZSBjaGFpbiB0eXBlIChlLmcuIG1haW5uZXQsIHRlc3RuZXQsIGV0Yy4pXG4gKiBAcGFyYW0gaW5jbHVkZVByZXJlbGVhc2VzIHdlYXRoZXIgdG8gaW5jbHVkZSBwcmVyZWxlYXNlcyBpbnRvIGFjY291bnQgd2hlbiBzZWFyY2hpbmcgZm9yIGEgbWF0Y2hpbmcgcmVsZWFzZSBpbiBHaXRIdWJcbiAqIEBwYXJhbSBjb25maWcgY29uZmlncyBmb3IgaW5jbHVkaW5nIHByZXJlbGVhc2VzLCBhZGRpbmcgbmFtZSBzdWZmaXgsIGFuZCBnZXR0aW5nIHNwZWNpZmljIHJlbGVhc2UgYnkgdGFnXG4gKi9cbmNvbnN0IGRvd25sb2FkUm9zZW5Bc3NldHMgPSBhc3luYyAoXG4gIGNoYWluVHlwZTogc3RyaW5nLFxuICBkZXN0aW5hdGlvblBhdGg6IHN0cmluZyxcbiAgY29uZmlnPzoge1xuICAgIGluY2x1ZGVQcmVyZWxlYXNlcz86IGJvb2xlYW47XG4gICAgbmFtZVN1ZmZpeD86IHN0cmluZztcbiAgICB0YWc/
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG93bmxvYWRSb3NlbkFzc2V0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL2xpYi9kb3dubG9hZFJvc2VuQXNzZXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sUUFBUSxNQUFNLFVBQVUsQ0FBQztBQUVoQyxPQUFPLEVBQ0wsaUJBQWlCLEVBQ2pCLHVCQUF1QixFQUN2QixlQUFlLEdBQ2hCLE1BQU0sZ0JBQWdCLENBQUM7QUFDeEIsT0FBTyxFQUFFLGdCQUFnQixFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXBFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUVuRCxNQUFNLElBQUksR0FBRyxVQUFVLENBQUM7QUFFeEI7Ozs7O0dBS0c7QUFDSCxNQUFNLG1CQUFtQixHQUFHLEtBQUssRUFDL0IsU0FBaUIsRUFDakIsZUFBdUIsRUFDdkIsTUFJQyxFQUNELEVBQUU7SUFDRixNQUFNLFVBQVUsR0FBRyxHQUFHLEVBQUU7UUFDdEIsSUFBSSxNQUFNLEVBQUUsR0FBRztZQUFFLE9BQU8sZUFBZSxDQUFDLElBQUksRUFBRSxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDMUQsSUFBSSxNQUFNLEVBQUUsa0JBQWtCO1lBQUUsT0FBTyxpQkFBaUIsQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDMUUsT0FBTyx1QkFBdUIsQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDbEQsQ0FBQyxDQUFDO0lBQ0YsSUFBSSxDQUFDO1FBQ0gsTUFBTSxPQUFPLEdBQUcsTUFBTSxVQUFVLEVBQUUsQ0FBQztRQUVuQyxJQUFJLE9BQU8sRUFBRSxDQUFDO1lBQ1osTUFBTSxPQUFPLENBQUMsR0FBRyxDQUFDO2dCQUNoQixHQUFHLENBQUMsT0FBTztvQkFDVCxPQUFPLENBQUMsTUFBTTt5QkFDWCxNQUFNLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLGdCQUFnQixDQUFDLFNBQVMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQzt5QkFDMUQsR0FBRyxDQUFDLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRSxDQUNuQixRQUFRLENBQUMsS0FBSyxDQUFDLG9CQUFvQixFQUFFLGVBQWUsRUFBRTt3QkFDcEQsUUFBUSxFQUFFLGlCQUFpQixDQUN6QixLQUFLLENBQUMsSUFBSSxFQUNWLFNBQVMsRUFDVCxPQUFPLENBQUMsUUFBUSxFQUNoQixNQUFNLEVBQUUsVUFBVSxDQUNuQjtxQkFDRixDQUFDLENBQ0gsQ0FBQzthQUNQLENBQUMsQ0FBQztRQUNMLENBQUM7YUFBTSxDQUFDO1lBQ04sT0FBTyxDQUFDLEtBQUssQ0FBQyx5QkFBeUIsU0FBUyxlQUFlLENBQUMsQ0FBQztZQUNqRSxJQUFJLENBQUMsTUFBTSxFQUFFLGtCQUFrQixFQUFFLENBQUM7Z0JBQ2hDLE9BQU8sQ0FBQyxLQUFLLENBQ1gsNEdBQTRHLENBQzdHLENBQUM7WUFDSixDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFBQyxPQUFPLEtBQUssRUFBRSxDQUFDO1FBQ2YsT0FBTyxDQUFDLEtBQUssQ0FDWCw0REFBNEQsS0FBSyxFQUFFLENBQ3BFLENBQUM7UUFDRixJQUFJLEtBQUssWUFBWSxLQUFLLEVBQUUsQ0FBQztZQUMzQixPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM3QixDQUFDO1FBQ0QsTUFBTSxJQUFJLHdCQUF3QixDQUFDLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQzNELENBQUM7QUFDSCxDQUFDLENBQUM7QUFFRixlQUFlLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGRvd25sb2FkIGZyb20gJ2Rvd25sb2FkJztcblxuaW1wb3J0IHtcbiAgZmluZExhdGVzdFJlbGVhc2UsXG4gIGZpbmRMYXRlc3RTdGFibGVSZWxlYXNlLFxuICBnZXRSZWxlYXNlQnlUYWcsXG59IGZyb20gJy4vdXRpbHMvZ2l0aHViJztcbmltcG9ydCB7IGlzVmFsaWRBc3NldE5hbWUsIHRydW5jYXRlQXNzZXROYW1lIH0gZnJvbSAnLi91dGlscy9yb3Nlbic7XG5cbmltcG9ydCB7IFJvc2VuQXNzZXRzRG93bmxvYWRFcnJvciB9IGZyb20gJy4vZXJyb3InO1xuXG5jb25zdCByZXBvID0gJ2NvbnRyYWN0JztcblxuLyoqXG4gKiBEb3dubG9hZCBhbGwgcmVxdWlyZWQgUm9zZW4gYXNzZXRzICh0b2tlbk1hcCBhbmQgYWxsIGNoYWluIGFkZHJlc3MgZmlsZXMpIHRvIGEgc3BlY2lmaWMgcGF0aFxuICogQHBhcmFtIGNoYWluVHlwZSBjaGFpbiB0eXBlIChlLmcuIG1haW5uZXQsIHRlc3RuZXQsIGV0Yy4pXG4gKiBAcGFyYW0gaW5jbHVkZVByZXJlbGVhc2VzIHdlYXRoZXIgdG8gaW5jbHVkZSBwcmVyZWxlYXNlcyBpbnRvIGFjY291bnQgd2hlbiBzZWFyY2hpbmcgZm9yIGEgbWF0Y2hpbmcgcmVsZWFzZSBpbiBHaXRIdWJcbiAqIEBwYXJhbSBjb25maWcgY29uZmlncyBmb3IgaW5jbHVkaW5nIHByZXJlbGVhc2VzLCBhZGRpbmcgbmFtZSBzdWZmaXgsIGFuZCBnZXR0aW5nIHNwZWNpZmljIHJlbGVhc2UgYnkgdGFnXG4gKi9cbmNvbnN0IGRvd25sb2FkUm9zZW5Bc3NldHMgPSBhc3luYyAoXG4gIGNoYWluVHlwZTogc3RyaW5nLFxuICBkZXN0aW5hdGlvblBhdGg6IHN0cmluZyxcbiAgY29uZmlnPzoge1xuICAgIGluY2x1ZGVQcmVyZWxlYXNlcz86IGJvb2xlYW47XG4gICAgbmFtZVN1ZmZpeD86IHN0cmluZztcbiAgICB0YWc/OiBzdHJpbmc7XG4gIH0sXG4pID0+IHtcbiAgY29uc3QgZ2V0UmVsZWFzZSA9ICgpID0+IHtcbiAgICBpZiAoY29uZmlnPy50YWcpIHJldHVybiBnZXRSZWxlYXNlQnlUYWcocmVwbywgY29uZmlnLnRhZyk7XG4gICAgaWYgKGNvbmZpZz8uaW5jbHVkZVByZXJlbGVhc2VzKSByZXR1cm4gZmluZExhdGVzdFJlbGVhc2UocmVwbywgY2hhaW5UeXBlKTtcbiAgICByZXR1cm4gZmluZExhdGVzdFN0YWJsZVJlbGVhc2UocmVwbywgY2hhaW5UeXBlKTtcbiAgfTtcbiAgdHJ5IHtcbiAgICBjb25zdCByZWxlYXNlID0gYXdhaXQgZ2V0UmVsZWFzZSgpO1xuXG4gICAgaWYgKHJlbGVhc2UpIHtcbiAgICAgIGF3YWl0IFByb21pc2UuYWxsKFtcbiAgICAgICAgLi4uKHJlbGVhc2UgJiZcbiAgICAgICAgICByZWxlYXNlLmFzc2V0c1xuICAgICAgICAgICAgLmZpbHRlcigoYXNzZXQpID0+IGlzVmFsaWRBc3NldE5hbWUoY2hhaW5UeXBlKShhc3NldC5uYW1lKSlcbiAgICAgICAgICAgIC5tYXAoYXN5bmMgKGFzc2V0KSA9PlxuICAgICAgICAgICAgICBkb3dubG9hZChhc3NldC5icm93c2VyX2Rvd25sb2FkX3VybCwgZGVzdGluYXRpb25QYXRoLCB7XG4gICAgICAgICAgICAgICAgZmlsZW5hbWU6IHRydW5jYXRlQXNzZXROYW1lKFxuICAgICAgICAgICAgICAgICAgYXNzZXQubmFtZSxcbiAgICAgICAgICAgICAgICAgIGNoYWluVHlwZSxcbiAgICAgICAgICAgICAgICAgIHJlbGVhc2UudGFnX25hbWUsXG4gICAgICAgICAgICAgICAgICBjb25maWc/Lm5hbWVTdWZmaXgsXG4gICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgfSksXG4gICAgICAgICAgICApKSxcbiAgICAgIF0pO1xuICAgIH0gZWxzZSB7XG4gICAgICBjb25zb2xlLmVycm9yKGBObyByZWxlYXNlIGZvdW5kIGZvciBbJHtjaGFpblR5cGV9XSBjaGFpbiB0eXBlLmApO1xuICAgICAgaWYgKCFjb25maWc/LmluY2x1ZGVQcmVyZWxlYXNlcykge1xuICAgICAgICBjb25zb2xlLmVycm9yKFxuICAgICAgICAgICdQbGVhc2Ugbm90ZSB0aGF0IGBpbmNsdWRlUHJlcmVsZWFzZXNgIGlzIHNldCB0byBmYWxzZS4gVGhlcmUgbWF5IGJlIHNvbWUgbWF0Y2hpbmcgcmVsZWFzZXMgaW4gcHJlcmVsZWFzZXMuJyxcbiAgICAgICAgKTtcbiAgICAgIH1cbiAgICB9XG4gIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgY29uc29sZS5lcnJvcihcbiAgICAgIGBBbiBlcnJvciBvY2N1cnJlZCB3aGlsZSB0cnlpbmcgdG8gZG93bmxvYWQgUm9zZW4gYXNzZXRzOiAke2Vycm9yfWAsXG4gICAgKTtcbiAgICBpZiAoZXJyb3IgaW5zdGFuY2VvZiBFcnJvcikge1xuICAgICAgY29uc29sZS5lcnJvcihlcnJvci5zdGFjayk7XG4gICAgfVxuICAgIHRocm93IG5ldyBSb3NlbkFzc2V0c0Rvd25sb2FkRXJyb3IoJycsIHsgY2F1c2U6IGVycm9yIH0pO1xuICB9XG59O1xuXG5leHBvcnQgZGVmYXVsdCBkb3dubG9hZFJvc2VuQXNzZXRzO1xuIl19
|
|
@@ -42,4 +42,4 @@ const downloadTssBinary = async (destinationPath, config) => {
|
|
|
42
42
|
}
|
|
43
43
|
};
|
|
44
44
|
export { downloadTssBinary };
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG93bmxvYWRUc3NCaW5hcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvZG93bmxvYWRUc3NCaW5hcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxRQUFRLE1BQU0sVUFBVSxDQUFDO0FBRWhDLE9BQU8sRUFDTCw0QkFBNEIsRUFDNUIsa0NBQWtDLEVBQ2xDLGVBQWUsR0FDaEIsTUFBTSxnQkFBZ0IsQ0FBQztBQUN4QixPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTFDLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUVuRCxNQUFNLElBQUksR0FBRyxnQkFBZ0IsQ0FBQztBQUU5Qjs7OztHQUlHO0FBQ0gsTUFBTSxpQkFBaUIsR0FBRyxLQUFLLEVBQzdCLGVBQXVCLEVBQ3ZCLE1BS0MsRUFDRCxFQUFFO0lBQ0YsTUFBTSxVQUFVLEdBQUcsR0FBRyxFQUFFO1FBQ3RCLElBQUksTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ2pCLElBQUksTUFBTSxFQUFFLGtCQUFrQjtnQkFDNUIsT0FBTyw0QkFBNEIsQ0FBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDOztnQkFDbkQsT0FBTyxrQ0FBa0MsQ0FBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ25FLENBQUM7O1lBQU0sT0FBTyxlQUFlLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNsRCxDQUFDLENBQUM7SUFDRixJQUFJLENBQUM7UUFDSCxNQUFNLE9BQU8sR0FBRyxNQUFNLFVBQVUsRUFBRSxDQUFDO1FBRW5DLElBQUksT0FBTyxFQUFFLENBQUM7WUFDWixNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQUM7Z0JBQ2hCLEdBQUcsQ0FBQyxPQUFPO29CQUNULE9BQU8sQ0FBQyxNQUFNO3lCQUNYLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7eUJBQ3ZELEdBQUcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FDbkIsUUFBUSxDQUFDLEtBQUssQ0FBQyxvQkFBb0IsRUFBRSxlQUFlLENBQUMsQ0FDdEQsQ0FBQzthQUNQLENBQUMsQ0FBQztRQUNMLENBQUM7YUFBTSxDQUFDO1lBQ04sT0FBTyxDQUFDLEtBQUssQ0FBQyx5QkFBeUIsTUFBTSxDQUFDLE1BQU0sWUFBWSxDQUFDLENBQUM7UUFDcEUsQ0FBQztJQUNILENBQUM7SUFBQyxPQUFPLEtBQUssRUFBRSxDQUFDO1FBQ2YsT0FBTyxDQUFDLEtBQUssQ0FDWCw4REFBOEQsS0FBSyxFQUFFLENBQ3RFLENBQUM7UUFDRixJQUFJLEtBQUssWUFBWSxLQUFLLEVBQUUsQ0FBQztZQUMzQixPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM3QixDQUFDO1FBQ0QsTUFBTSxJQUFJLHdCQUF3QixDQUFDLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQzNELENBQUM7QUFDSCxDQUFDLENBQUM7QUFFRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBkb3dubG9hZCBmcm9tICdkb3dubG9hZCc7XG5cbmltcG9ydCB7XG4gIGZpbmRMYXRlc3RSZWxlYXNlQnlQcmVmaXhUYWcsXG4gIGZpbmRMYXRlc3RTdGFibGVSZWxlYXNlQnlQcmVmaXhUYWcsXG4gIGdldFJlbGVhc2VCeVRhZyxcbn0gZnJvbSAnLi91dGlscy9naXRodWInO1xuaW1wb3J0IHsgaXNWYWxpZE9TIH0gZnJvbSAnLi91dGlscy9yb3Nlbic7XG5cbmltcG9ydCB7IFJvc2VuQXNzZXRzRG93bmxvYWRFcnJvciB9IGZyb20gJy4vZXJyb3InO1xuXG5jb25zdCByZXBvID0gJ3NpZ24tcHJvdG9jb2xzJztcblxuLyoqXG4gKiBEb3dubG9hZCByZWxlYXNlIGFzc2V0IGJ5IHRhZyB0byBhIHNwZWNpZmljIHBhdGhcbiAqIEBwYXJhbSBkZXN0aW5hdGlvblBhdGggd2hlcmUgd3JpdGVzIGZpbGVzXG4gKiBAcGFyYW0gY29uZmlnIGNvbmZpZ3MgZm9yIGluY2x1ZGluZyBwcmVyZWxlYXNlcywgc2V0IG9zTmFtZSwgZ2V0dGluZyBzcGVjaWZpYyByZWxlYXNlIGJ5IHRhZyBvciBieSByZWdleCB0YWdcbiAqL1xuY29uc3QgZG93bmxvYWRUc3NCaW5hcnkgPSBhc3luYyAoXG4gIGRlc3RpbmF0aW9uUGF0aDogc3RyaW5nLFxuICBjb25maWc6IHtcbiAgICBvc05hbWU6IHN0cmluZztcbiAgICB0YWc6IHN0cmluZztcbiAgICByZWdleDogYm9vbGVhbjtcbiAgICBpbmNsdWRlUHJlcmVsZWFzZXM/
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG93bmxvYWRUc3NCaW5hcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvZG93bmxvYWRUc3NCaW5hcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxRQUFRLE1BQU0sVUFBVSxDQUFDO0FBRWhDLE9BQU8sRUFDTCw0QkFBNEIsRUFDNUIsa0NBQWtDLEVBQ2xDLGVBQWUsR0FDaEIsTUFBTSxnQkFBZ0IsQ0FBQztBQUN4QixPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTFDLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUVuRCxNQUFNLElBQUksR0FBRyxnQkFBZ0IsQ0FBQztBQUU5Qjs7OztHQUlHO0FBQ0gsTUFBTSxpQkFBaUIsR0FBRyxLQUFLLEVBQzdCLGVBQXVCLEVBQ3ZCLE1BS0MsRUFDRCxFQUFFO0lBQ0YsTUFBTSxVQUFVLEdBQUcsR0FBRyxFQUFFO1FBQ3RCLElBQUksTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ2pCLElBQUksTUFBTSxFQUFFLGtCQUFrQjtnQkFDNUIsT0FBTyw0QkFBNEIsQ0FBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDOztnQkFDbkQsT0FBTyxrQ0FBa0MsQ0FBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ25FLENBQUM7O1lBQU0sT0FBTyxlQUFlLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNsRCxDQUFDLENBQUM7SUFDRixJQUFJLENBQUM7UUFDSCxNQUFNLE9BQU8sR0FBRyxNQUFNLFVBQVUsRUFBRSxDQUFDO1FBRW5DLElBQUksT0FBTyxFQUFFLENBQUM7WUFDWixNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQUM7Z0JBQ2hCLEdBQUcsQ0FBQyxPQUFPO29CQUNULE9BQU8sQ0FBQyxNQUFNO3lCQUNYLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7eUJBQ3ZELEdBQUcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FDbkIsUUFBUSxDQUFDLEtBQUssQ0FBQyxvQkFBb0IsRUFBRSxlQUFlLENBQUMsQ0FDdEQsQ0FBQzthQUNQLENBQUMsQ0FBQztRQUNMLENBQUM7YUFBTSxDQUFDO1lBQ04sT0FBTyxDQUFDLEtBQUssQ0FBQyx5QkFBeUIsTUFBTSxDQUFDLE1BQU0sWUFBWSxDQUFDLENBQUM7UUFDcEUsQ0FBQztJQUNILENBQUM7SUFBQyxPQUFPLEtBQUssRUFBRSxDQUFDO1FBQ2YsT0FBTyxDQUFDLEtBQUssQ0FDWCw4REFBOEQsS0FBSyxFQUFFLENBQ3RFLENBQUM7UUFDRixJQUFJLEtBQUssWUFBWSxLQUFLLEVBQUUsQ0FBQztZQUMzQixPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM3QixDQUFDO1FBQ0QsTUFBTSxJQUFJLHdCQUF3QixDQUFDLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQzNELENBQUM7QUFDSCxDQUFDLENBQUM7QUFFRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBkb3dubG9hZCBmcm9tICdkb3dubG9hZCc7XG5cbmltcG9ydCB7XG4gIGZpbmRMYXRlc3RSZWxlYXNlQnlQcmVmaXhUYWcsXG4gIGZpbmRMYXRlc3RTdGFibGVSZWxlYXNlQnlQcmVmaXhUYWcsXG4gIGdldFJlbGVhc2VCeVRhZyxcbn0gZnJvbSAnLi91dGlscy9naXRodWInO1xuaW1wb3J0IHsgaXNWYWxpZE9TIH0gZnJvbSAnLi91dGlscy9yb3Nlbic7XG5cbmltcG9ydCB7IFJvc2VuQXNzZXRzRG93bmxvYWRFcnJvciB9IGZyb20gJy4vZXJyb3InO1xuXG5jb25zdCByZXBvID0gJ3NpZ24tcHJvdG9jb2xzJztcblxuLyoqXG4gKiBEb3dubG9hZCByZWxlYXNlIGFzc2V0IGJ5IHRhZyB0byBhIHNwZWNpZmljIHBhdGhcbiAqIEBwYXJhbSBkZXN0aW5hdGlvblBhdGggd2hlcmUgd3JpdGVzIGZpbGVzXG4gKiBAcGFyYW0gY29uZmlnIGNvbmZpZ3MgZm9yIGluY2x1ZGluZyBwcmVyZWxlYXNlcywgc2V0IG9zTmFtZSwgZ2V0dGluZyBzcGVjaWZpYyByZWxlYXNlIGJ5IHRhZyBvciBieSByZWdleCB0YWdcbiAqL1xuY29uc3QgZG93bmxvYWRUc3NCaW5hcnkgPSBhc3luYyAoXG4gIGRlc3RpbmF0aW9uUGF0aDogc3RyaW5nLFxuICBjb25maWc6IHtcbiAgICBvc05hbWU6IHN0cmluZztcbiAgICB0YWc6IHN0cmluZztcbiAgICByZWdleDogYm9vbGVhbjtcbiAgICBpbmNsdWRlUHJlcmVsZWFzZXM/OiBib29sZWFuO1xuICB9LFxuKSA9PiB7XG4gIGNvbnN0IGdldFJlbGVhc2UgPSAoKSA9PiB7XG4gICAgaWYgKGNvbmZpZy5yZWdleCkge1xuICAgICAgaWYgKGNvbmZpZz8uaW5jbHVkZVByZXJlbGVhc2VzKVxuICAgICAgICByZXR1cm4gZmluZExhdGVzdFJlbGVhc2VCeVByZWZpeFRhZyhyZXBvLCBjb25maWcudGFnKTtcbiAgICAgIGVsc2UgcmV0dXJuIGZpbmRMYXRlc3RTdGFibGVSZWxlYXNlQnlQcmVmaXhUYWcocmVwbywgY29uZmlnLnRhZyk7XG4gICAgfSBlbHNlIHJldHVybiBnZXRSZWxlYXNlQnlUYWcocmVwbywgY29uZmlnLnRhZyk7XG4gIH07XG4gIHRyeSB7XG4gICAgY29uc3QgcmVsZWFzZSA9IGF3YWl0IGdldFJlbGVhc2UoKTtcblxuICAgIGlmIChyZWxlYXNlKSB7XG4gICAgICBhd2FpdCBQcm9taXNlLmFsbChbXG4gICAgICAgIC4uLihyZWxlYXNlICYmXG4gICAgICAgICAgcmVsZWFzZS5hc3NldHNcbiAgICAgICAgICAgIC5maWx0ZXIoKGFzc2V0KSA9PiBpc1ZhbGlkT1MoY29uZmlnLm9zTmFtZSkoYXNzZXQubmFtZSkpXG4gICAgICAgICAgICAubWFwKGFzeW5jIChhc3NldCkgPT5cbiAgICAgICAgICAgICAgZG93bmxvYWQoYXNzZXQuYnJvd3Nlcl9kb3dubG9hZF91cmwsIGRlc3RpbmF0aW9uUGF0aCksXG4gICAgICAgICAgICApKSxcbiAgICAgIF0pO1xuICAgIH0gZWxzZSB7XG4gICAgICBjb25zb2xlLmVycm9yKGBObyByZWxlYXNlIGZvdW5kIGZvciBbJHtjb25maWcub3NOYW1lfV0gT1MgbmFtZS5gKTtcbiAgICB9XG4gIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgY29uc29sZS5lcnJvcihcbiAgICAgIGBBbiBlcnJvciBvY2N1cnJlZCB3aGlsZSB0cnlpbmcgdG8gZG93bmxvYWQgcmVsZWFzZSBhc3NldHM6ICR7ZXJyb3J9YCxcbiAgICApO1xuICAgIGlmIChlcnJvciBpbnN0YW5jZW9mIEVycm9yKSB7XG4gICAgICBjb25zb2xlLmVycm9yKGVycm9yLnN0YWNrKTtcbiAgICB9XG4gICAgdGhyb3cgbmV3IFJvc2VuQXNzZXRzRG93bmxvYWRFcnJvcignJywgeyBjYXVzZTogZXJyb3IgfSk7XG4gIH1cbn07XG5cbmV4cG9ydCB7IGRvd25sb2FkVHNzQmluYXJ5IH07XG4iXX0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"github.d.ts","sourceRoot":"","sources":["../../lib/utils/github.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAExD;;;;;GAKG;AACH,iBAAgB,iBAAiB,CAC/B,QAAQ,EAAE,aAAa,EACvB,QAAQ,SAAsC;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"github.d.ts","sourceRoot":"","sources":["../../lib/utils/github.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAExD;;;;;GAKG;AACH,iBAAgB,iBAAiB,CAC/B,QAAQ,EAAE,aAAa,EACvB,QAAQ,SAAsC;;;;;;;;;;;;;;;;;YAuJgor0B,sDAAsB;YAA8B,sDAAsB;;;;;gBAA0P,sDAAsB;oBAlIzgs0B;AAED;;;;;GAKG;AACH,QAAA,MAAM,eAAe,GACnB,UAAU,aAAa,EAEvB,YAAW,CAAC,OAAO,EAAE,aAAa,KAAK,OAAoB;;;;;;;;;;;;;;;;;YAuHmnr0B,sDAAsB;YAA8B,sDAAsB;;;;;gBAA0P,sDAAsB;SA3Gzgs0B,CAAC;AAEF;;;;GAIG;AACH,QAAA,MAAM,eAAe,GAAU,UAAU,aAAa,EAAE,KAAK,MAAM;;;;;;;;;;;;;;;;;YAoG6mr0B,sDAAsB;YAA8B,sDAAsB;;;;;gBAA0P,sDAAsB;EA3Fzgs0B,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+Cqmr0B,sDAAsB;YAA8B,sDAAsB;;;;;gBAA0P,sDAAsB;SA9C98r0B,CAAC;AAE7D;;;;;GAKG;AACH,QAAA,MAAM,uBAAuB,GAC3B,UAAU,aAAa,EACvB,WAAW,MAAM;;;;;;;;;;;;;;;;;YAoC6pr0B,sDAAsB;YAA8B,sDAAsB;;;;;gBAA0P,sDAAsB;SAnCp8r0B,CAAC;AAEvE;;;;GAIG;AACH,QAAA,MAAM,kCAAkC,GACtC,UAAU,aAAa,EACvB,WAAW,MAAM;;;;;;;;;;;;;;;;;YA0B6pr0B,sDAAsB;YAA8B,sDAAsB;;;;;gBAA0P,sDAAsB;SAzBj8r0B,CAAC;AAE1E;;;;GAIG;AACH,QAAA,MAAM,4BAA4B,GAChC,UAAU,aAAa,EACvB,WAAW,MAAM;;;;;;;;;;;;;;;;;YAgB6pr0B,sDAAsB;YAA8B,sDAAsB;;;;;gBAA0P,sDAAsB;SAf58r0B,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
|
@@ -110,4 +110,4 @@ const findLatestStableReleaseByPrefixTag = async (repoName, tagPrefix) => findLa
|
|
|
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  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 { 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"]}
|
package/dist/utils/rosen.js
CHANGED
|
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9zZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvdXRpbHMvcm9zZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNILE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLENBQUMsU0FBaUIsRUFBRSxFQUFFLENBQUMsQ0FBQyxTQUFpQixFQUFFLEVBQUUsQ0FDM0UsSUFBSSxNQUFNLENBQUMsNEJBQTRCLFNBQVMsVUFBVSxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRTlFOzs7R0FHRztBQUNILE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBRyxDQUFDLE1BQWMsRUFBRSxFQUFFLENBQUMsQ0FBQyxnQkFBd0IsRUFBRSxFQUFFLENBQ3hFLElBQUksTUFBTSxDQUFDLGFBQWEsTUFBTSxVQUFVLENBQUMsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztBQUVuRTs7Ozs7OztHQU9HO0FBQ0gsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsQ0FDL0IsU0FBaUIsRUFDakIsU0FBaUIsRUFDakIsV0FBbUIsRUFDbkIsaUJBQTBCLEVBQzFCLEVBQUU7SUFDRixNQUFNLElBQUksR0FBRyxTQUFTLENBQUMsT0FBTyxDQUFDLElBQUksU0FBUyxJQUFJLFdBQVcsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3hFLE9BQU8saUJBQWlCO1FBQ3RCLENBQUMsQ0FBQyxHQUFHLElBQUksSUFBSSxpQkFBaUIsT0FBTztRQUNyQyxDQUFDLENBQUMsR0FBRyxJQUFJLE9BQU8sQ0FBQztBQUNyQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENoZWNrIGlmIGFuIGFzc2V0IG5hbWUgaXMgYSB2YWxpZCBSb3NlbiBhc3NldCBuYW1lIGFuZCBtYXRjaGVzIGEgc3BlY2lmaWNcbiAqIGNoYWluIHR5cGVcbiAqIEBwYXJhbSBjaGFpblR5cGVcbiAqL1xuZXhwb3J0IGNvbnN0IGlzVmFsaWRBc3NldE5hbWUgPSAoY2hhaW5UeXBlOiBzdHJpbmcpID0+IChhc3NldE5hbWU6IHN0cmluZykgPT5cbiAgbmV3IFJlZ0V4cChgKGNvbnRyYWN0cy0uK3x0b2tlbnNNYXApLSR7Y2hhaW5UeXBlfS0uKy5qc29uYCkudGVzdChhc3NldE5hbWUpO1xuXG4vKipcbiAqIENoZWNrIGlmIGFuIE9TIG5hbWUgaXMgYSB2YWxpZCBzdXBwb3J0ZWQgdHNzIE9TXG4gKiBAcGFyYW0gT1NOYW1lXG4gKi9cbmV4cG9ydCBjb25zdCBpc1ZhbGlkT1MgPSAoT1NOYW1lOiBzdHJpbmcpID0+IChyZWxlYXNlQXNzZXROYW1lOiBzdHJpbmcpID0+XG4gIG5ldyBSZWdFeHAoYChyb3NlblRzcy0ke09TTmFtZX0tLispLnppcGApLnRlc3QocmVsZWFzZUFzc2V0TmFtZSk7XG5cbi8qKlxuICogUmVtb3ZlIGNoYWluIHR5cGUgYW5kIHRhZyBmcm9tIHRoZSBhc3NldCBuYW1lIGFuZCBvcHRpb25hbGx5IHJlcGxhY2VzIHRoZW1cbiAqIHdpdGggYSBzdWZmaXhcbiAqIEBwYXJhbSBhc3NldE5hbWVcbiAqIEBwYXJhbSBjaGFpblR5cGVcbiAqIEBwYXJhbSByZWxlYXNlTmFtZVxuICogQHBhcmFtIGFsdGVybmF0aXZlU3VmZml4IGEgc3VmZml4IHdoaWNoIHdpbGwgYmUgYWRkZWQgYmVmb3JlIGAuanNvbmAgKGlmIHByb3ZpZGVkKVxuICovXG5leHBvcnQgY29uc3QgdHJ1bmNhdGVBc3NldE5hbWUgPSAoXG4gIGFzc2V0TmFtZTogc3RyaW5nLFxuICBjaGFpblR5cGU6IHN0cmluZyxcbiAgcmVsZWFzZU5hbWU6IHN0cmluZyxcbiAgYWx0ZXJuYXRpdmVTdWZmaXg/
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9zZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvdXRpbHMvcm9zZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNILE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLENBQUMsU0FBaUIsRUFBRSxFQUFFLENBQUMsQ0FBQyxTQUFpQixFQUFFLEVBQUUsQ0FDM0UsSUFBSSxNQUFNLENBQUMsNEJBQTRCLFNBQVMsVUFBVSxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRTlFOzs7R0FHRztBQUNILE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBRyxDQUFDLE1BQWMsRUFBRSxFQUFFLENBQUMsQ0FBQyxnQkFBd0IsRUFBRSxFQUFFLENBQ3hFLElBQUksTUFBTSxDQUFDLGFBQWEsTUFBTSxVQUFVLENBQUMsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztBQUVuRTs7Ozs7OztHQU9HO0FBQ0gsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsQ0FDL0IsU0FBaUIsRUFDakIsU0FBaUIsRUFDakIsV0FBbUIsRUFDbkIsaUJBQTBCLEVBQzFCLEVBQUU7SUFDRixNQUFNLElBQUksR0FBRyxTQUFTLENBQUMsT0FBTyxDQUFDLElBQUksU0FBUyxJQUFJLFdBQVcsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3hFLE9BQU8saUJBQWlCO1FBQ3RCLENBQUMsQ0FBQyxHQUFHLElBQUksSUFBSSxpQkFBaUIsT0FBTztRQUNyQyxDQUFDLENBQUMsR0FBRyxJQUFJLE9BQU8sQ0FBQztBQUNyQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENoZWNrIGlmIGFuIGFzc2V0IG5hbWUgaXMgYSB2YWxpZCBSb3NlbiBhc3NldCBuYW1lIGFuZCBtYXRjaGVzIGEgc3BlY2lmaWNcbiAqIGNoYWluIHR5cGVcbiAqIEBwYXJhbSBjaGFpblR5cGVcbiAqL1xuZXhwb3J0IGNvbnN0IGlzVmFsaWRBc3NldE5hbWUgPSAoY2hhaW5UeXBlOiBzdHJpbmcpID0+IChhc3NldE5hbWU6IHN0cmluZykgPT5cbiAgbmV3IFJlZ0V4cChgKGNvbnRyYWN0cy0uK3x0b2tlbnNNYXApLSR7Y2hhaW5UeXBlfS0uKy5qc29uYCkudGVzdChhc3NldE5hbWUpO1xuXG4vKipcbiAqIENoZWNrIGlmIGFuIE9TIG5hbWUgaXMgYSB2YWxpZCBzdXBwb3J0ZWQgdHNzIE9TXG4gKiBAcGFyYW0gT1NOYW1lXG4gKi9cbmV4cG9ydCBjb25zdCBpc1ZhbGlkT1MgPSAoT1NOYW1lOiBzdHJpbmcpID0+IChyZWxlYXNlQXNzZXROYW1lOiBzdHJpbmcpID0+XG4gIG5ldyBSZWdFeHAoYChyb3NlblRzcy0ke09TTmFtZX0tLispLnppcGApLnRlc3QocmVsZWFzZUFzc2V0TmFtZSk7XG5cbi8qKlxuICogUmVtb3ZlIGNoYWluIHR5cGUgYW5kIHRhZyBmcm9tIHRoZSBhc3NldCBuYW1lIGFuZCBvcHRpb25hbGx5IHJlcGxhY2VzIHRoZW1cbiAqIHdpdGggYSBzdWZmaXhcbiAqIEBwYXJhbSBhc3NldE5hbWVcbiAqIEBwYXJhbSBjaGFpblR5cGVcbiAqIEBwYXJhbSByZWxlYXNlTmFtZVxuICogQHBhcmFtIGFsdGVybmF0aXZlU3VmZml4IGEgc3VmZml4IHdoaWNoIHdpbGwgYmUgYWRkZWQgYmVmb3JlIGAuanNvbmAgKGlmIHByb3ZpZGVkKVxuICovXG5leHBvcnQgY29uc3QgdHJ1bmNhdGVBc3NldE5hbWUgPSAoXG4gIGFzc2V0TmFtZTogc3RyaW5nLFxuICBjaGFpblR5cGU6IHN0cmluZyxcbiAgcmVsZWFzZU5hbWU6IHN0cmluZyxcbiAgYWx0ZXJuYXRpdmVTdWZmaXg/OiBzdHJpbmcsXG4pID0+IHtcbiAgY29uc3QgbmFtZSA9IGFzc2V0TmFtZS5yZXBsYWNlKGAtJHtjaGFpblR5cGV9LSR7cmVsZWFzZU5hbWV9Lmpzb25gLCAnJyk7XG4gIHJldHVybiBhbHRlcm5hdGl2ZVN1ZmZpeFxuICAgID8gYCR7bmFtZX0tJHthbHRlcm5hdGl2ZVN1ZmZpeH0uanNvbmBcbiAgICA6IGAke25hbWV9Lmpzb25gO1xufTtcbiJdfQ==
|
package/package.json
CHANGED
|
@@ -1,32 +1,37 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@rosen-bridge/utils",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "2.0.1",
|
|
4
4
|
"description": "Misc utility functions used inside Rosen bridge projects",
|
|
5
|
+
"repository": {
|
|
6
|
+
"type": "git",
|
|
7
|
+
"url": "git+https://github.com/rosen-bridge/utils.git"
|
|
8
|
+
},
|
|
9
|
+
"license": "MIT",
|
|
10
|
+
"author": "Rosen Team",
|
|
11
|
+
"type": "module",
|
|
5
12
|
"main": "dist/index.js",
|
|
6
13
|
"types": "dist/index.d.ts",
|
|
7
|
-
"
|
|
14
|
+
"files": [
|
|
15
|
+
"dist",
|
|
16
|
+
"CHANGELOG.md"
|
|
17
|
+
],
|
|
8
18
|
"scripts": {
|
|
9
|
-
"prettify": "prettier --write . --ignore-path
|
|
19
|
+
"prettify": "prettier --write . --ignore-path ../../.gitignore",
|
|
20
|
+
"prettify:check": "prettier --check . --ignore-path ../../.gitignore",
|
|
10
21
|
"lint": "eslint --fix . && npm run prettify",
|
|
22
|
+
"lint:check": "eslint . && npm run prettify:check",
|
|
11
23
|
"build": "tsc --build tsconfig.build.json",
|
|
12
24
|
"type-check": "tsc --noEmit",
|
|
13
25
|
"test": "jest --runInBand",
|
|
14
26
|
"coverage": "jest --coverage --runInBand",
|
|
15
27
|
"release": "npm run test && npm run build && npm publish --access public"
|
|
16
28
|
},
|
|
17
|
-
"repository": {
|
|
18
|
-
"type": "git",
|
|
19
|
-
"url": "git+https://github.com/rosen-bridge/utils.git"
|
|
20
|
-
},
|
|
21
|
-
"license": "MIT",
|
|
22
29
|
"devDependencies": {
|
|
23
30
|
"@babel/preset-env": "^7.19.0",
|
|
24
31
|
"@types/download": "^8.0.2",
|
|
25
32
|
"@types/jest": "^29.1.2",
|
|
26
|
-
"@types/node": "^20.11.0",
|
|
27
33
|
"jest": "^29.2.0",
|
|
28
|
-
"ts-jest": "^29.0.3"
|
|
29
|
-
"typescript": "^5.8.3"
|
|
34
|
+
"ts-jest": "^29.0.3"
|
|
30
35
|
},
|
|
31
36
|
"directories": {
|
|
32
37
|
"lib": "lib",
|
|
@@ -38,5 +43,8 @@
|
|
|
38
43
|
"dependencies": {
|
|
39
44
|
"download": "^8.0.0",
|
|
40
45
|
"octokit": "^2.0.14"
|
|
46
|
+
},
|
|
47
|
+
"engines": {
|
|
48
|
+
"node": ">=22.18.0"
|
|
41
49
|
}
|
|
42
50
|
}
|
package/.eslintignore
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
dist
|
package/babel.config.json
DELETED
package/jest.config.json
DELETED
package/lib/constants.ts
DELETED
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
import download from 'download';
|
|
2
|
-
|
|
3
|
-
import {
|
|
4
|
-
findLatestRelease,
|
|
5
|
-
findLatestStableRelease,
|
|
6
|
-
getReleaseByTag,
|
|
7
|
-
} from './utils/github';
|
|
8
|
-
import { isValidAssetName, truncateAssetName } from './utils/rosen';
|
|
9
|
-
|
|
10
|
-
import { RosenAssetsDownloadError } from './error';
|
|
11
|
-
|
|
12
|
-
const repo = 'contract';
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* Download all required Rosen assets (tokenMap and all chain address files) to a specific path
|
|
16
|
-
* @param chainType chain type (e.g. mainnet, testnet, etc.)
|
|
17
|
-
* @param includePrereleases weather to include prereleases into account when searching for a matching release in GitHub
|
|
18
|
-
* @param config configs for including prereleases, adding name suffix, and getting specific release by tag
|
|
19
|
-
*/
|
|
20
|
-
const downloadRosenAssets = async (
|
|
21
|
-
chainType: string,
|
|
22
|
-
destinationPath: string,
|
|
23
|
-
config?: {
|
|
24
|
-
includePrereleases?: boolean;
|
|
25
|
-
nameSuffix?: string;
|
|
26
|
-
tag?: string;
|
|
27
|
-
}
|
|
28
|
-
) => {
|
|
29
|
-
const getRelease = () => {
|
|
30
|
-
if (config?.tag) return getReleaseByTag(repo, config.tag);
|
|
31
|
-
if (config?.includePrereleases) return findLatestRelease(repo, chainType);
|
|
32
|
-
return findLatestStableRelease(repo, chainType);
|
|
33
|
-
};
|
|
34
|
-
try {
|
|
35
|
-
const release = await getRelease();
|
|
36
|
-
|
|
37
|
-
if (release) {
|
|
38
|
-
await Promise.all([
|
|
39
|
-
...(release &&
|
|
40
|
-
release.assets
|
|
41
|
-
.filter((asset) => isValidAssetName(chainType)(asset.name))
|
|
42
|
-
.map(async (asset) =>
|
|
43
|
-
download(asset.browser_download_url, destinationPath, {
|
|
44
|
-
filename: truncateAssetName(
|
|
45
|
-
asset.name,
|
|
46
|
-
chainType,
|
|
47
|
-
release.tag_name,
|
|
48
|
-
config?.nameSuffix
|
|
49
|
-
),
|
|
50
|
-
})
|
|
51
|
-
)),
|
|
52
|
-
]);
|
|
53
|
-
} else {
|
|
54
|
-
console.error(`No release found for [${chainType}] chain type.`);
|
|
55
|
-
if (!config?.includePrereleases) {
|
|
56
|
-
console.error(
|
|
57
|
-
'Please note that `includePrereleases` is set to false. There may be some matching releases in prereleases.'
|
|
58
|
-
);
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
} catch (error) {
|
|
62
|
-
console.error(
|
|
63
|
-
`An error occurred while trying to download Rosen assets: ${error}`
|
|
64
|
-
);
|
|
65
|
-
if (error instanceof Error) {
|
|
66
|
-
console.error(error.stack);
|
|
67
|
-
}
|
|
68
|
-
throw new RosenAssetsDownloadError('', { cause: error });
|
|
69
|
-
}
|
|
70
|
-
};
|
|
71
|
-
|
|
72
|
-
export default downloadRosenAssets;
|
package/lib/downloadTssBinary.ts
DELETED
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
import download from 'download';
|
|
2
|
-
|
|
3
|
-
import {
|
|
4
|
-
findLatestReleaseByPrefixTag,
|
|
5
|
-
findLatestStableReleaseByPrefixTag,
|
|
6
|
-
getReleaseByTag,
|
|
7
|
-
} from './utils/github';
|
|
8
|
-
import { isValidOS } from './utils/rosen';
|
|
9
|
-
|
|
10
|
-
import { RosenAssetsDownloadError } from './error';
|
|
11
|
-
|
|
12
|
-
const repo = 'sign-protocols';
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* Download release asset by tag to a specific path
|
|
16
|
-
* @param destinationPath where writes files
|
|
17
|
-
* @param config configs for including prereleases, set osName, getting specific release by tag or by regex tag
|
|
18
|
-
*/
|
|
19
|
-
const downloadTssBinary = async (
|
|
20
|
-
destinationPath: string,
|
|
21
|
-
config: {
|
|
22
|
-
osName: string;
|
|
23
|
-
tag: string;
|
|
24
|
-
regex: boolean;
|
|
25
|
-
includePrereleases?: boolean;
|
|
26
|
-
}
|
|
27
|
-
) => {
|
|
28
|
-
const getRelease = () => {
|
|
29
|
-
if (config.regex) {
|
|
30
|
-
if (config?.includePrereleases)
|
|
31
|
-
return findLatestReleaseByPrefixTag(repo, config.tag);
|
|
32
|
-
else return findLatestStableReleaseByPrefixTag(repo, config.tag);
|
|
33
|
-
} else return getReleaseByTag(repo, config.tag);
|
|
34
|
-
};
|
|
35
|
-
try {
|
|
36
|
-
const release = await getRelease();
|
|
37
|
-
|
|
38
|
-
if (release) {
|
|
39
|
-
await Promise.all([
|
|
40
|
-
...(release &&
|
|
41
|
-
release.assets
|
|
42
|
-
.filter((asset) => isValidOS(config.osName)(asset.name))
|
|
43
|
-
.map(async (asset) =>
|
|
44
|
-
download(asset.browser_download_url, destinationPath)
|
|
45
|
-
)),
|
|
46
|
-
]);
|
|
47
|
-
} else {
|
|
48
|
-
console.error(`No release found for [${config.osName}] OS name.`);
|
|
49
|
-
}
|
|
50
|
-
} catch (error) {
|
|
51
|
-
console.error(
|
|
52
|
-
`An error occurred while trying to download release assets: ${error}`
|
|
53
|
-
);
|
|
54
|
-
if (error instanceof Error) {
|
|
55
|
-
console.error(error.stack);
|
|
56
|
-
}
|
|
57
|
-
throw new RosenAssetsDownloadError('', { cause: error });
|
|
58
|
-
}
|
|
59
|
-
};
|
|
60
|
-
|
|
61
|
-
export { downloadTssBinary };
|
package/lib/error.ts
DELETED
package/lib/index.ts
DELETED
package/lib/types/index.ts
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { Octokit } from 'octokit';
|
|
2
|
-
|
|
3
|
-
export type ArrayElement<T extends any[]> = T extends (infer Element)[]
|
|
4
|
-
? Element
|
|
5
|
-
: never;
|
|
6
|
-
|
|
7
|
-
type GithubReleases = Awaited<
|
|
8
|
-
ReturnType<InstanceType<typeof Octokit>['rest']['repos']['listReleases']>
|
|
9
|
-
>['data'];
|
|
10
|
-
|
|
11
|
-
export type GithubRelease = ArrayElement<GithubReleases>;
|
|
12
|
-
|
|
13
|
-
export type SupportedRepo = 'contract' | 'sign-protocols';
|
package/lib/utils/github.ts
DELETED
|
@@ -1,169 +0,0 @@
|
|
|
1
|
-
import { Octokit } from 'octokit';
|
|
2
|
-
|
|
3
|
-
import { isValidAssetName } from './rosen';
|
|
4
|
-
|
|
5
|
-
import {
|
|
6
|
-
DEFAULT_RELEASES_FETCHING_PAGE_SIZE,
|
|
7
|
-
ROSEN_BRIDGE_ORGANIZATION,
|
|
8
|
-
} from '../constants';
|
|
9
|
-
|
|
10
|
-
import { GithubRelease, SupportedRepo } from '../types';
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* Fetch a page of releases from Github Api in each iteration until there are no
|
|
14
|
-
* more releases.
|
|
15
|
-
* @param repoName
|
|
16
|
-
* @param pageSize
|
|
17
|
-
*/
|
|
18
|
-
async function* fetchReleasesPage(
|
|
19
|
-
repoName: SupportedRepo,
|
|
20
|
-
pageSize = DEFAULT_RELEASES_FETCHING_PAGE_SIZE
|
|
21
|
-
) {
|
|
22
|
-
const octokit = new Octokit();
|
|
23
|
-
|
|
24
|
-
let currentPage = 1;
|
|
25
|
-
|
|
26
|
-
while (true) {
|
|
27
|
-
const releasesPage = await octokit.rest.repos.listReleases({
|
|
28
|
-
owner: ROSEN_BRIDGE_ORGANIZATION,
|
|
29
|
-
repo: repoName,
|
|
30
|
-
per_page: pageSize,
|
|
31
|
-
page: currentPage,
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
if (releasesPage.data.length) {
|
|
35
|
-
yield releasesPage.data;
|
|
36
|
-
currentPage += 1;
|
|
37
|
-
} else {
|
|
38
|
-
return;
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* Find the last release matching the predicate. If all releases are iterated and
|
|
45
|
-
* no matching release is found, return null.
|
|
46
|
-
* @param repoName
|
|
47
|
-
* @param predicate
|
|
48
|
-
*/
|
|
49
|
-
const findLastRelease = async (
|
|
50
|
-
repoName: SupportedRepo,
|
|
51
|
-
predicate: (release: GithubRelease) => boolean = () => true
|
|
52
|
-
) => {
|
|
53
|
-
const releasesPageIterator = fetchReleasesPage(repoName);
|
|
54
|
-
|
|
55
|
-
for await (const releasesPage of releasesPageIterator) {
|
|
56
|
-
const foundRelease = releasesPage.find(predicate);
|
|
57
|
-
|
|
58
|
-
if (foundRelease) {
|
|
59
|
-
return foundRelease;
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
return null;
|
|
63
|
-
};
|
|
64
|
-
|
|
65
|
-
/**
|
|
66
|
-
* get a GitHub release by its tag
|
|
67
|
-
* @param repoName
|
|
68
|
-
* @param tag
|
|
69
|
-
*/
|
|
70
|
-
const getReleaseByTag = async (repoName: SupportedRepo, tag: string) => {
|
|
71
|
-
const octokit = new Octokit();
|
|
72
|
-
const release = await octokit.rest.repos.getReleaseByTag({
|
|
73
|
-
owner: ROSEN_BRIDGE_ORGANIZATION,
|
|
74
|
-
repo: repoName,
|
|
75
|
-
tag,
|
|
76
|
-
});
|
|
77
|
-
|
|
78
|
-
return release.data;
|
|
79
|
-
};
|
|
80
|
-
|
|
81
|
-
/**
|
|
82
|
-
* Return a function which checks if a release has at least one asset for a
|
|
83
|
-
* specific chain type
|
|
84
|
-
* @param chainType
|
|
85
|
-
* @param release
|
|
86
|
-
*/
|
|
87
|
-
const hasAssetForChainType = (chainType: string) => (release: GithubRelease) =>
|
|
88
|
-
release.assets.map((asset) => asset.name).some(isValidAssetName(chainType));
|
|
89
|
-
|
|
90
|
-
/**
|
|
91
|
-
* Return a function which checks if a release is a stable (that is, non-prerelease)
|
|
92
|
-
* and has some asset matching a specific chain type
|
|
93
|
-
* @param chainType
|
|
94
|
-
*/
|
|
95
|
-
const isStableReleaseForChainType =
|
|
96
|
-
(chainType: string) => (release: GithubRelease) =>
|
|
97
|
-
!release.prerelease && hasAssetForChainType(chainType)(release);
|
|
98
|
-
|
|
99
|
-
/**
|
|
100
|
-
* Return a function which checks if tagPrefix is matched with release tag_name
|
|
101
|
-
* @param tagPrefix
|
|
102
|
-
*/
|
|
103
|
-
const hasMatchedTagPrefix = (tagPrefix: string) => (release: GithubRelease) => {
|
|
104
|
-
const regex = new RegExp(`^${tagPrefix}`);
|
|
105
|
-
return regex.test(release.tag_name);
|
|
106
|
-
};
|
|
107
|
-
|
|
108
|
-
/**
|
|
109
|
-
* Return a function which checks if a release is a stable (that is, non-prerelease),
|
|
110
|
-
* and tagPrefix is matched with release tag_name
|
|
111
|
-
* @param tagPrefix
|
|
112
|
-
*/
|
|
113
|
-
const isStableReleaseForRegexTagType =
|
|
114
|
-
(tagPrefix: string) => (release: GithubRelease) =>
|
|
115
|
-
!release.prerelease && hasMatchedTagPrefix(tagPrefix)(release);
|
|
116
|
-
|
|
117
|
-
/**
|
|
118
|
-
* Find latest release (prerelease or non-prerelease) having some asset matching
|
|
119
|
-
* a specific chain type
|
|
120
|
-
* @param repoName
|
|
121
|
-
* @param chainType
|
|
122
|
-
*/
|
|
123
|
-
const findLatestRelease = async (repoName: SupportedRepo, chainType: string) =>
|
|
124
|
-
findLastRelease(repoName, hasAssetForChainType(chainType));
|
|
125
|
-
|
|
126
|
-
/**
|
|
127
|
-
* Find latest stable (that is, non-prerelease) release having some asset matching
|
|
128
|
-
* a specific chain type
|
|
129
|
-
* @param repoName
|
|
130
|
-
* @param chainType
|
|
131
|
-
*/
|
|
132
|
-
const findLatestStableRelease = async (
|
|
133
|
-
repoName: SupportedRepo,
|
|
134
|
-
chainType: string
|
|
135
|
-
) => findLastRelease(repoName, isStableReleaseForChainType(chainType));
|
|
136
|
-
|
|
137
|
-
/**
|
|
138
|
-
* Find the latest stable (that is, non-prerelease) release that tagPrefix is matched with release tag_name
|
|
139
|
-
* @param repoName
|
|
140
|
-
* @param tagPrefix
|
|
141
|
-
*/
|
|
142
|
-
const findLatestStableReleaseByPrefixTag = async (
|
|
143
|
-
repoName: SupportedRepo,
|
|
144
|
-
tagPrefix: string
|
|
145
|
-
) => findLastRelease(repoName, isStableReleaseForRegexTagType(tagPrefix));
|
|
146
|
-
|
|
147
|
-
/**
|
|
148
|
-
* Find the latest release that tagPrefix is matched with release tag_name
|
|
149
|
-
* @param repoName
|
|
150
|
-
* @param tagPrefix
|
|
151
|
-
*/
|
|
152
|
-
const findLatestReleaseByPrefixTag = async (
|
|
153
|
-
repoName: SupportedRepo,
|
|
154
|
-
tagPrefix: string
|
|
155
|
-
) => findLastRelease(repoName, hasMatchedTagPrefix(tagPrefix));
|
|
156
|
-
|
|
157
|
-
export {
|
|
158
|
-
fetchReleasesPage,
|
|
159
|
-
findLastRelease,
|
|
160
|
-
findLatestRelease,
|
|
161
|
-
findLatestStableRelease,
|
|
162
|
-
findLatestStableReleaseByPrefixTag,
|
|
163
|
-
findLatestReleaseByPrefixTag,
|
|
164
|
-
getReleaseByTag,
|
|
165
|
-
hasAssetForChainType,
|
|
166
|
-
isStableReleaseForChainType,
|
|
167
|
-
isStableReleaseForRegexTagType,
|
|
168
|
-
hasMatchedTagPrefix,
|
|
169
|
-
};
|
package/lib/utils/rosen.ts
DELETED
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Check if an asset name is a valid Rosen asset name and matches a specific
|
|
3
|
-
* chain type
|
|
4
|
-
* @param chainType
|
|
5
|
-
*/
|
|
6
|
-
export const isValidAssetName = (chainType: string) => (assetName: string) =>
|
|
7
|
-
new RegExp(`(contracts-.+|tokensMap)-${chainType}-.+.json`).test(assetName);
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* Check if an OS name is a valid supported tss OS
|
|
11
|
-
* @param OSName
|
|
12
|
-
*/
|
|
13
|
-
export const isValidOS = (OSName: string) => (releaseAssetName: string) =>
|
|
14
|
-
new RegExp(`(rosenTss-${OSName}-.+).zip`).test(releaseAssetName);
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* Remove chain type and tag from the asset name and optionally replaces them
|
|
18
|
-
* with a suffix
|
|
19
|
-
* @param assetName
|
|
20
|
-
* @param chainType
|
|
21
|
-
* @param releaseName
|
|
22
|
-
* @param alternativeSuffix a suffix which will be added before `.json` (if provided)
|
|
23
|
-
*/
|
|
24
|
-
export const truncateAssetName = (
|
|
25
|
-
assetName: string,
|
|
26
|
-
chainType: string,
|
|
27
|
-
releaseName: string,
|
|
28
|
-
alternativeSuffix?: string
|
|
29
|
-
) => {
|
|
30
|
-
const name = assetName.replace(`-${chainType}-${releaseName}.json`, '');
|
|
31
|
-
return alternativeSuffix
|
|
32
|
-
? `${name}-${alternativeSuffix}.json`
|
|
33
|
-
: `${name}.json`;
|
|
34
|
-
};
|