cnpmcore 0.0.2 → 1.2.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/History.md +19 -0
- package/LICENSE +1 -1
- package/README.md +13 -4
- package/dist/app/common/AbstractService.d.ts +5 -0
- package/dist/app/{port/type/BaseController.js → common/AbstractService.js} +11 -9
- package/dist/app/common/FileUtil.d.ts +15 -0
- package/dist/app/common/FileUtil.js +77 -0
- package/dist/app/common/PackageUtil.d.ts +9 -0
- package/dist/app/common/PackageUtil.js +38 -16
- package/dist/app/common/SyncUtil.d.ts +2 -0
- package/dist/app/common/SyncUtil.js +17 -0
- package/dist/app/common/UserUtil.d.ts +5 -0
- package/dist/app/common/UserUtil.js +72 -0
- package/dist/app/common/adapter/BugVersionStore.d.ts +7 -0
- package/dist/app/common/adapter/BugVersionStore.js +28 -0
- package/dist/app/common/adapter/CacheAdapter.d.ts +13 -0
- package/dist/app/common/adapter/CacheAdapter.js +78 -0
- package/dist/app/common/adapter/NFSAdapter.d.ts +16 -0
- package/dist/app/common/adapter/NFSAdapter.js +62 -22
- package/dist/app/common/adapter/NPMRegistry.d.ts +78 -0
- package/dist/app/common/adapter/NPMRegistry.js +98 -0
- package/dist/app/common/adapter/QueueAdapter.d.ts +7 -0
- package/dist/app/common/adapter/QueueAdapter.js +37 -0
- package/dist/app/common/adapter/binary/AbstractBinary.d.ts +33 -0
- package/dist/app/common/adapter/binary/AbstractBinary.js +76 -0
- package/dist/app/common/adapter/binary/ApiBinary.d.ts +8 -0
- package/dist/app/common/adapter/binary/ApiBinary.js +31 -0
- package/dist/app/common/adapter/binary/BucketBinary.d.ts +5 -0
- package/dist/app/common/adapter/binary/BucketBinary.js +77 -0
- package/dist/app/common/adapter/binary/CypressBinary.d.ts +5 -0
- package/dist/app/common/adapter/binary/CypressBinary.js +63 -0
- package/dist/app/common/adapter/binary/ElectronBinary.d.ts +5 -0
- package/dist/app/common/adapter/binary/ElectronBinary.js +44 -0
- package/dist/app/common/adapter/binary/GithubBinary.d.ts +7 -0
- package/dist/app/common/adapter/binary/GithubBinary.js +93 -0
- package/dist/app/common/adapter/binary/ImageminBinary.d.ts +5 -0
- package/dist/app/common/adapter/binary/ImageminBinary.js +96 -0
- package/dist/app/common/adapter/binary/NodeBinary.d.ts +4 -0
- package/dist/app/common/adapter/binary/NodeBinary.js +41 -0
- package/dist/app/common/adapter/binary/NodePreGypBinary.d.ts +5 -0
- package/dist/app/common/adapter/binary/NodePreGypBinary.js +136 -0
- package/dist/app/common/adapter/binary/NwjsBinary.d.ts +6 -0
- package/dist/app/common/adapter/binary/NwjsBinary.js +47 -0
- package/dist/app/common/adapter/binary/PlaywrightBinary.d.ts +5 -0
- package/dist/app/common/adapter/binary/PlaywrightBinary.js +214 -0
- package/dist/app/common/adapter/binary/PuppeteerBinary.d.ts +6 -0
- package/dist/app/common/adapter/binary/PuppeteerBinary.js +125 -0
- package/dist/app/common/adapter/binary/SqlcipherBinary.d.ts +5 -0
- package/dist/app/common/adapter/binary/SqlcipherBinary.js +78 -0
- package/dist/app/common/aop/AsyncTimer.d.ts +9 -0
- package/dist/app/common/aop/AsyncTimer.js +36 -0
- package/dist/app/common/constants.d.ts +2 -0
- package/dist/app/common/constants.js +6 -0
- package/dist/app/common/dayjs.d.ts +2 -0
- package/dist/app/common/dayjs.js +10 -0
- package/dist/app/common/enum/Task.d.ts +12 -0
- package/dist/app/common/enum/Task.js +18 -0
- package/dist/app/common/enum/User.d.ts +5 -0
- package/dist/app/common/enum/User.js +10 -0
- package/dist/app/common/typing.d.ts +28 -0
- package/dist/app/common/typing.js +3 -0
- package/dist/app/core/entity/Binary.d.ts +28 -0
- package/dist/app/core/entity/Binary.js +29 -0
- package/dist/app/core/entity/BugVersion.d.ts +14 -0
- package/dist/app/core/entity/BugVersion.js +43 -0
- package/dist/app/core/entity/Change.d.ts +17 -0
- package/dist/app/core/entity/Change.js +20 -0
- package/dist/app/core/entity/Dist.d.ts +21 -0
- package/dist/app/core/entity/Dist.js +1 -2
- package/dist/app/core/entity/Entity.d.ts +11 -0
- package/dist/app/core/entity/Entity.js +3 -3
- package/dist/app/core/entity/Package.d.ts +45 -0
- package/dist/app/core/entity/Package.js +33 -25
- package/dist/app/core/entity/PackageTag.d.ts +17 -0
- package/dist/app/core/entity/PackageVersion.d.ts +26 -0
- package/dist/app/core/entity/PackageVersionBlock.d.ts +17 -0
- package/dist/app/core/entity/PackageVersionBlock.js +20 -0
- package/dist/app/core/entity/PackageVersionManifest.d.ts +17 -0
- package/dist/app/core/entity/PackageVersionManifest.js +20 -0
- package/dist/app/core/entity/Task.d.ts +43 -0
- package/dist/app/core/entity/Task.js +94 -0
- package/dist/app/core/entity/Token.d.ts +24 -0
- package/dist/app/core/entity/Token.js +23 -0
- package/dist/app/core/entity/User.d.ts +25 -0
- package/dist/app/core/entity/User.js +24 -0
- package/dist/app/core/event/BugVersionFixHandler.d.ts +6 -0
- package/dist/app/core/event/BugVersionFixHandler.js +42 -0
- package/dist/app/core/event/CacheCleaner.d.ts +38 -0
- package/dist/app/core/event/CacheCleaner.js +119 -0
- package/dist/app/core/event/ChangesStream.d.ts +32 -0
- package/dist/app/core/event/ChangesStream.js +106 -0
- package/dist/app/core/event/StoreManifest.d.ts +11 -0
- package/dist/app/core/event/StoreManifest.js +54 -0
- package/dist/app/core/event/index.d.ts +27 -0
- package/dist/app/core/event/index.js +11 -3
- package/dist/app/core/service/BinarySyncerService.d.ts +23 -0
- package/dist/app/core/service/BinarySyncerService.js +281 -0
- package/dist/app/core/service/BugVersionService.d.ts +11 -0
- package/dist/app/core/service/BugVersionService.js +86 -0
- package/dist/app/core/service/CacheService.d.ts +33 -0
- package/dist/app/core/service/CacheService.js +75 -0
- package/dist/app/core/service/ChangesStreamService.d.ts +11 -0
- package/dist/app/core/service/ChangesStreamService.js +186 -0
- package/dist/app/core/service/PackageManagerService.d.ts +83 -0
- package/dist/app/core/service/PackageManagerService.js +675 -78
- package/dist/app/core/service/PackageSyncerService.d.ts +24 -0
- package/dist/app/core/service/PackageSyncerService.js +667 -0
- package/dist/app/core/service/TaskService.d.ts +22 -0
- package/dist/app/core/service/TaskService.js +142 -0
- package/dist/app/core/service/UserService.d.ts +36 -0
- package/dist/app/core/service/UserService.js +120 -0
- package/dist/app/core/util/EntityUtil.d.ts +8 -0
- package/dist/app/core/util/EntityUtil.js +3 -3
- package/dist/app/infra/NFSClientAdapter.d.ts +18 -0
- package/dist/app/infra/NFSClientAdapter.js +74 -0
- package/dist/app/infra/package.json +6 -0
- package/dist/app/port/UserRoleManager.d.ts +24 -0
- package/dist/app/port/UserRoleManager.js +146 -0
- package/dist/app/port/controller/AbstractController.d.ts +32 -0
- package/dist/app/port/controller/AbstractController.js +112 -0
- package/dist/app/port/controller/BinarySyncController.d.ts +36 -0
- package/dist/app/port/controller/BinarySyncController.js +123 -0
- package/dist/app/port/controller/ChangesStreamController.d.ts +13 -0
- package/dist/app/port/controller/ChangesStreamController.js +53 -0
- package/dist/app/port/controller/DownloadController.d.ts +18 -0
- package/dist/app/port/controller/DownloadController.js +134 -0
- package/dist/app/port/controller/HomeController.d.ts +37 -0
- package/dist/app/port/controller/HomeController.js +72 -0
- package/dist/app/port/controller/PackageBlockController.d.ts +24 -0
- package/dist/app/port/controller/PackageBlockController.js +108 -0
- package/dist/app/port/controller/PackageSyncController.d.ts +35 -0
- package/dist/app/port/controller/PackageSyncController.js +205 -0
- package/dist/app/port/controller/PackageTagController.d.ts +12 -0
- package/dist/app/port/controller/PackageTagController.js +88 -0
- package/dist/app/port/controller/TokenController.d.ts +38 -0
- package/dist/app/port/controller/TokenController.js +125 -0
- package/dist/app/port/controller/UserController.d.ts +39 -0
- package/dist/app/port/controller/UserController.js +223 -0
- package/dist/app/port/controller/package/DownloadPackageVersionTar.d.ts +9 -0
- package/dist/app/port/controller/package/DownloadPackageVersionTar.js +82 -0
- package/dist/app/port/controller/package/RemovePackageVersionController.d.ts +8 -0
- package/dist/app/port/controller/package/RemovePackageVersionController.js +56 -0
- package/dist/app/port/controller/package/SavePackageVersionController.d.ts +48 -0
- package/dist/app/port/controller/package/SavePackageVersionController.js +221 -0
- package/dist/app/port/controller/package/ShowPackageController.d.ts +8 -0
- package/dist/app/port/controller/package/ShowPackageController.js +99 -0
- package/dist/app/port/controller/package/ShowPackageVersionController.d.ts +6 -0
- package/dist/app/port/controller/package/ShowPackageVersionController.js +55 -0
- package/dist/app/port/controller/package/UpdatePackageController.d.ts +17 -0
- package/dist/app/port/controller/package/UpdatePackageController.js +68 -0
- package/dist/app/port/middleware/AlwaysAuth.d.ts +2 -0
- package/dist/app/port/middleware/AlwaysAuth.js +17 -0
- package/dist/app/port/middleware/ErrorHandler.d.ts +2 -0
- package/dist/app/port/middleware/ErrorHandler.js +27 -5
- package/dist/app/port/middleware/Tracing.d.ts +2 -0
- package/dist/app/port/middleware/Tracing.js +22 -0
- package/dist/app/port/middleware/index.d.ts +2 -0
- package/dist/app/port/middleware/index.js +22 -0
- package/dist/app/port/typebox.d.ts +29 -0
- package/dist/app/port/typebox.js +71 -0
- package/dist/app/repository/AbstractRepository.d.ts +4 -0
- package/dist/app/repository/AbstractRepository.js +17 -0
- package/dist/app/repository/BinaryRepository.d.ts +7 -0
- package/dist/app/repository/BinaryRepository.js +45 -0
- package/dist/app/repository/ChangeRepository.d.ts +8 -0
- package/dist/app/repository/ChangeRepository.js +31 -0
- package/dist/app/repository/DistRepository.d.ts +15 -0
- package/dist/app/repository/DistRepository.js +69 -0
- package/dist/app/repository/PackageRepository.d.ts +39 -0
- package/dist/app/repository/PackageRepository.js +223 -36
- package/dist/app/repository/PackageVersionBlockRepository.d.ts +10 -0
- package/dist/app/repository/PackageVersionBlockRepository.js +51 -0
- package/dist/app/repository/PackageVersionDownloadRepository.d.ts +7 -0
- package/dist/app/repository/PackageVersionDownloadRepository.js +77 -0
- package/dist/app/repository/TaskRepository.d.ts +10 -0
- package/dist/app/repository/TaskRepository.js +82 -0
- package/dist/app/repository/UserRepository.d.ts +15 -0
- package/dist/app/repository/UserRepository.js +81 -0
- package/dist/app/repository/model/Binary.d.ts +13 -0
- package/dist/app/repository/model/Binary.js +53 -0
- package/dist/app/repository/model/Change.d.ts +10 -0
- package/dist/app/repository/model/Change.js +44 -0
- package/dist/app/repository/model/Dist.d.ts +12 -0
- package/dist/app/repository/model/Dist.js +10 -13
- package/dist/app/repository/model/HistoryTask.d.ts +18 -0
- package/dist/app/repository/model/HistoryTask.js +65 -0
- package/dist/app/repository/model/Maintainer.d.ts +8 -0
- package/dist/app/repository/model/Maintainer.js +36 -0
- package/dist/app/repository/model/Package.d.ts +13 -0
- package/dist/app/repository/model/Package.js +18 -9
- package/dist/app/repository/model/PackageDep.d.ts +11 -0
- package/dist/app/repository/model/PackageDep.js +9 -9
- package/dist/app/repository/model/PackageTag.d.ts +10 -0
- package/dist/app/repository/model/PackageTag.js +9 -9
- package/dist/app/repository/model/PackageVersion.d.ts +14 -0
- package/dist/app/repository/model/PackageVersion.js +9 -9
- package/dist/app/repository/model/PackageVersionBlock.d.ts +10 -0
- package/dist/app/repository/model/PackageVersionBlock.js +44 -0
- package/dist/app/repository/model/PackageVersionDownload.d.ts +40 -0
- package/dist/app/repository/model/PackageVersionDownload.js +132 -0
- package/dist/app/repository/model/PackageVersionManifest.d.ts +10 -0
- package/dist/app/repository/model/PackageVersionManifest.js +46 -0
- package/dist/app/repository/model/Task.d.ts +18 -0
- package/dist/app/repository/model/Task.js +65 -0
- package/dist/app/repository/model/Token.d.ts +13 -0
- package/dist/app/repository/model/Token.js +55 -0
- package/dist/app/repository/model/User.d.ts +14 -0
- package/dist/app/repository/model/User.js +56 -0
- package/dist/app/repository/util/EntityProperty.d.ts +1 -0
- package/dist/app/repository/util/ModelConvertor.d.ts +7 -0
- package/dist/app/repository/util/ModelConvertor.js +35 -2
- package/dist/app/repository/util/ModelConvertorUtil.d.ts +8 -0
- package/dist/app/schedule/ChangesStreamWorker.d.ts +8 -0
- package/dist/app/schedule/ChangesStreamWorker.js +27 -0
- package/dist/app/schedule/CheckRecentlyUpdatedPackages.d.ts +8 -0
- package/dist/app/schedule/CheckRecentlyUpdatedPackages.js +66 -0
- package/dist/app/schedule/CleanTempDir.d.ts +8 -0
- package/dist/app/schedule/CleanTempDir.js +48 -0
- package/dist/app/schedule/CreateSyncBinaryTask.d.ts +8 -0
- package/dist/app/schedule/CreateSyncBinaryTask.js +34 -0
- package/dist/app/schedule/SavePackageVersionDownloadCounter.d.ts +8 -0
- package/dist/app/schedule/SavePackageVersionDownloadCounter.js +21 -0
- package/dist/app/schedule/SyncBinaryWorker.d.ts +8 -0
- package/dist/app/schedule/SyncBinaryWorker.js +30 -0
- package/dist/app/schedule/SyncPackageWorker.d.ts +8 -0
- package/dist/app/schedule/SyncPackageWorker.js +44 -0
- package/dist/app/schedule/TaskTimeoutHandler.d.ts +9 -0
- package/dist/app/schedule/TaskTimeoutHandler.js +27 -0
- package/dist/app/schedule/UpdateTotalData.d.ts +9 -0
- package/dist/app/schedule/UpdateTotalData.js +103 -0
- package/dist/app.d.ts +11 -0
- package/dist/app.js +22 -0
- package/dist/config/binaries.d.ts +38 -0
- package/dist/config/binaries.js +810 -0
- package/dist/config/config.default.d.ts +3 -0
- package/dist/config/config.default.js +128 -9
- package/dist/config/config.unittest.d.ts +3 -0
- package/dist/config/config.unittest.js +18 -0
- package/dist/config/plugin.d.ts +3 -0
- package/dist/config/plugin.js +19 -3
- package/package.json +76 -21
- package/dist/app/common/adapter/NFSClientAdapter.js +0 -43
- package/dist/app/port/controller/PackageController.js +0 -273
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.UserRoleManager = void 0;
|
|
10
|
+
const tegg_1 = require("@eggjs/tegg");
|
|
11
|
+
const egg_errors_1 = require("egg-errors");
|
|
12
|
+
const UserUtil_1 = require("../common/UserUtil");
|
|
13
|
+
let UserRoleManager = class UserRoleManager {
|
|
14
|
+
constructor() {
|
|
15
|
+
this.handleAuthorized = false;
|
|
16
|
+
}
|
|
17
|
+
// {
|
|
18
|
+
// 'user-agent': 'npm/8.1.2 node/v16.13.1 darwin arm64 workspaces/false',
|
|
19
|
+
// 'npm-command': 'adduser',
|
|
20
|
+
// authorization: 'Bearer 379f84d8-ba98-480b-909e-a8260af3a3ee',
|
|
21
|
+
// 'content-type': 'application/json',
|
|
22
|
+
// accept: '*/*',
|
|
23
|
+
// 'content-length': '166',
|
|
24
|
+
// 'accept-encoding': 'gzip,deflate',
|
|
25
|
+
// host: 'localhost:7001',
|
|
26
|
+
// connection: 'keep-alive'
|
|
27
|
+
// }
|
|
28
|
+
async getAuthorizedUserAndToken(ctx) {
|
|
29
|
+
if (this.handleAuthorized) {
|
|
30
|
+
if (!this.currentAuthorizedUser)
|
|
31
|
+
return null;
|
|
32
|
+
return {
|
|
33
|
+
token: this.currentAuthorizedToken,
|
|
34
|
+
user: this.currentAuthorizedUser,
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
this.handleAuthorized = true;
|
|
38
|
+
const authorization = ctx.get('authorization');
|
|
39
|
+
if (!authorization)
|
|
40
|
+
return null;
|
|
41
|
+
const matchs = /^Bearer ([\w\.]+?)$/.exec(authorization);
|
|
42
|
+
if (!matchs)
|
|
43
|
+
return null;
|
|
44
|
+
const tokenValue = matchs[1];
|
|
45
|
+
const tokenKey = (0, UserUtil_1.sha512)(tokenValue);
|
|
46
|
+
const authorizedUserAndToken = await this.userRepository.findUserAndTokenByTokenKey(tokenKey);
|
|
47
|
+
if (authorizedUserAndToken) {
|
|
48
|
+
this.currentAuthorizedToken = authorizedUserAndToken.token;
|
|
49
|
+
this.currentAuthorizedUser = authorizedUserAndToken.user;
|
|
50
|
+
ctx.userId = authorizedUserAndToken.user.userId;
|
|
51
|
+
}
|
|
52
|
+
return authorizedUserAndToken;
|
|
53
|
+
}
|
|
54
|
+
async requiredAuthorizedUser(ctx, role) {
|
|
55
|
+
const authorizedUserAndToken = await this.getAuthorizedUserAndToken(ctx);
|
|
56
|
+
if (!authorizedUserAndToken) {
|
|
57
|
+
const authorization = ctx.get('authorization');
|
|
58
|
+
const message = authorization ? 'Invalid token' : 'Login first';
|
|
59
|
+
throw new egg_errors_1.UnauthorizedError(message);
|
|
60
|
+
}
|
|
61
|
+
const { user, token } = authorizedUserAndToken;
|
|
62
|
+
if (role === 'publish') {
|
|
63
|
+
if (token.isReadonly) {
|
|
64
|
+
throw new egg_errors_1.ForbiddenError(`Read-only Token "${token.tokenMark}" can't publish`);
|
|
65
|
+
}
|
|
66
|
+
// only support npm >= 7.0.0 allow publish action
|
|
67
|
+
// user-agent: "npm/6.14.12 node/v10.24.1 darwin x64"
|
|
68
|
+
const m = /npm\/(\w{1,1000}\.)/.exec(ctx.get('user-agent'));
|
|
69
|
+
if (!m) {
|
|
70
|
+
throw new egg_errors_1.ForbiddenError('Only allow npm client to access');
|
|
71
|
+
}
|
|
72
|
+
const major = parseInt(m[1]);
|
|
73
|
+
if (major < 7) {
|
|
74
|
+
throw new egg_errors_1.ForbiddenError('Only allow npm@>=7.0.0 client to access');
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
if (role === 'setting') {
|
|
78
|
+
if (token.isReadonly) {
|
|
79
|
+
throw new egg_errors_1.ForbiddenError(`Read-only Token "${token.tokenMark}" can't setting`);
|
|
80
|
+
}
|
|
81
|
+
if (token.isAutomation) {
|
|
82
|
+
throw new egg_errors_1.ForbiddenError(`Automation Token "${token.tokenMark}" can't setting`);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
return user;
|
|
86
|
+
}
|
|
87
|
+
async requiredPackageMaintainer(pkg, user) {
|
|
88
|
+
// should be private package
|
|
89
|
+
if (!pkg.isPrivate) {
|
|
90
|
+
// admins can modified public package
|
|
91
|
+
if (this.config.cnpmcore.admins[user.name]) {
|
|
92
|
+
this.logger.warn('[UserRoleManager.requiredPackageMaintainer] admin "%s" modified public package "%s"', user.name, pkg.fullname);
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
throw new egg_errors_1.ForbiddenError(`Can\'t modify npm public package "${pkg.fullname}"`);
|
|
96
|
+
}
|
|
97
|
+
const maintainers = await this.packageRepository.listPackageMaintainers(pkg.packageId);
|
|
98
|
+
const maintainer = maintainers.find(m => m.userId === user.userId);
|
|
99
|
+
if (!maintainer) {
|
|
100
|
+
const names = maintainers.map(m => m.name).join(', ');
|
|
101
|
+
throw new egg_errors_1.ForbiddenError(`"${user.name}" not authorized to modify ${pkg.fullname}, please contact maintainers: "${names}"`);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
async requiredPackageScope(scope, user) {
|
|
105
|
+
var _a;
|
|
106
|
+
const cnpmcoreConfig = this.config.cnpmcore;
|
|
107
|
+
if (!cnpmcoreConfig.allowPublishNonScopePackage) {
|
|
108
|
+
const allowScopes = (_a = user.scopes) !== null && _a !== void 0 ? _a : cnpmcoreConfig.allowScopes;
|
|
109
|
+
if (!scope) {
|
|
110
|
+
throw new egg_errors_1.ForbiddenError(`Package scope required, legal scopes: "${allowScopes.join(', ')}"`);
|
|
111
|
+
}
|
|
112
|
+
if (!allowScopes.includes(scope)) {
|
|
113
|
+
throw new egg_errors_1.ForbiddenError(`Scope "${scope}" not match legal scopes: "${allowScopes.join(', ')}"`);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
async isAdmin(ctx) {
|
|
118
|
+
const authorizedUserAndToken = await this.getAuthorizedUserAndToken(ctx);
|
|
119
|
+
if (!authorizedUserAndToken)
|
|
120
|
+
return false;
|
|
121
|
+
const { user, token } = authorizedUserAndToken;
|
|
122
|
+
if (token.isReadonly)
|
|
123
|
+
return false;
|
|
124
|
+
return user.name in this.config.cnpmcore.admins;
|
|
125
|
+
}
|
|
126
|
+
};
|
|
127
|
+
__decorate([
|
|
128
|
+
(0, tegg_1.Inject)()
|
|
129
|
+
], UserRoleManager.prototype, "userRepository", void 0);
|
|
130
|
+
__decorate([
|
|
131
|
+
(0, tegg_1.Inject)()
|
|
132
|
+
], UserRoleManager.prototype, "packageRepository", void 0);
|
|
133
|
+
__decorate([
|
|
134
|
+
(0, tegg_1.Inject)()
|
|
135
|
+
], UserRoleManager.prototype, "config", void 0);
|
|
136
|
+
__decorate([
|
|
137
|
+
(0, tegg_1.Inject)()
|
|
138
|
+
], UserRoleManager.prototype, "logger", void 0);
|
|
139
|
+
UserRoleManager = __decorate([
|
|
140
|
+
(0, tegg_1.ContextProto)({
|
|
141
|
+
// only inject on port module
|
|
142
|
+
accessLevel: tegg_1.AccessLevel.PRIVATE,
|
|
143
|
+
})
|
|
144
|
+
], UserRoleManager);
|
|
145
|
+
exports.UserRoleManager = UserRoleManager;
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVXNlclJvbGVNYW5hZ2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vYXBwL3BvcnQvVXNlclJvbGVNYW5hZ2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBLHNDQUtxQjtBQUVyQiwyQ0FBK0Q7QUFNL0QsaURBQTRDO0FBUzVDLElBQWEsZUFBZSxHQUE1QixNQUFhLGVBQWU7SUFBNUI7UUFVVSxxQkFBZ0IsR0FBRyxLQUFLLENBQUM7SUFpSG5DLENBQUM7SUE3R0MsSUFBSTtJQUNKLDJFQUEyRTtJQUMzRSw4QkFBOEI7SUFDOUIsa0VBQWtFO0lBQ2xFLHdDQUF3QztJQUN4QyxtQkFBbUI7SUFDbkIsNkJBQTZCO0lBQzdCLHVDQUF1QztJQUN2Qyw0QkFBNEI7SUFDNUIsNkJBQTZCO0lBQzdCLElBQUk7SUFDRyxLQUFLLENBQUMseUJBQXlCLENBQUMsR0FBZTtRQUNwRCxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsRUFBRTtZQUN6QixJQUFJLENBQUMsSUFBSSxDQUFDLHFCQUFxQjtnQkFBRSxPQUFPLElBQUksQ0FBQztZQUM3QyxPQUFPO2dCQUNMLEtBQUssRUFBRSxJQUFJLENBQUMsc0JBQXNCO2dCQUNsQyxJQUFJLEVBQUUsSUFBSSxDQUFDLHFCQUFxQjthQUNqQyxDQUFDO1NBQ0g7UUFFRCxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDO1FBQzdCLE1BQU0sYUFBYSxHQUFHLEdBQUcsQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLENBQUM7UUFDL0MsSUFBSSxDQUFDLGFBQWE7WUFBRSxPQUFPLElBQUksQ0FBQztRQUNoQyxNQUFNLE1BQU0sR0FBRyxxQkFBcUIsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDekQsSUFBSSxDQUFDLE1BQU07WUFBRSxPQUFPLElBQUksQ0FBQztRQUN6QixNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDN0IsTUFBTSxRQUFR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
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { NotFoundError, UnavailableForLegalReasonsError } from 'egg-errors';
|
|
2
|
+
import { EggContext } from '@eggjs/tegg';
|
|
3
|
+
import { EggLogger, EggAppConfig } from 'egg';
|
|
4
|
+
import { MiddlewareController } from '../middleware';
|
|
5
|
+
import { UserRoleManager } from '../UserRoleManager';
|
|
6
|
+
import { PackageRepository } from '../../repository/PackageRepository';
|
|
7
|
+
import { UserRepository } from '../../repository/UserRepository';
|
|
8
|
+
import { Package as PackageEntity } from '../../core/entity/Package';
|
|
9
|
+
import { PackageVersion as PackageVersionEntity } from '../../core/entity/PackageVersion';
|
|
10
|
+
import { UserService } from '../../core/service/UserService';
|
|
11
|
+
declare class PackageNotFoundError extends NotFoundError {
|
|
12
|
+
}
|
|
13
|
+
export declare abstract class AbstractController extends MiddlewareController {
|
|
14
|
+
protected logger: EggLogger;
|
|
15
|
+
protected config: EggAppConfig;
|
|
16
|
+
protected userRoleManager: UserRoleManager;
|
|
17
|
+
protected packageRepository: PackageRepository;
|
|
18
|
+
protected userRepository: UserRepository;
|
|
19
|
+
protected userService: UserService;
|
|
20
|
+
protected get sourceRegistry(): string;
|
|
21
|
+
protected get enableSyncAll(): boolean;
|
|
22
|
+
protected isPrivateScope(scope: string): any;
|
|
23
|
+
protected createPackageNotFoundError(fullname: string, version?: string): PackageNotFoundError;
|
|
24
|
+
protected createPackageBlockError(reason: string, fullname: string, version?: string): UnavailableForLegalReasonsError;
|
|
25
|
+
protected getPackageEntityByFullname(fullname: string): Promise<PackageEntity>;
|
|
26
|
+
protected getPackageEntityAndRequiredMaintainer(ctx: EggContext, fullname: string): Promise<PackageEntity>;
|
|
27
|
+
protected getPackageEntity(scope: string, name: string): Promise<PackageEntity>;
|
|
28
|
+
protected getPackageVersionEntity(pkg: PackageEntity, version: string): Promise<PackageVersionEntity>;
|
|
29
|
+
protected getAndCheckVersionFromFilename(ctx: EggContext, fullname: string, filenameWithVersion: string): string;
|
|
30
|
+
protected setCDNHeaders(ctx: EggContext): void;
|
|
31
|
+
}
|
|
32
|
+
export {};
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AbstractController = void 0;
|
|
10
|
+
const egg_errors_1 = require("egg-errors");
|
|
11
|
+
const tegg_1 = require("@eggjs/tegg");
|
|
12
|
+
const middleware_1 = require("../middleware");
|
|
13
|
+
const PackageUtil_1 = require("../../common/PackageUtil");
|
|
14
|
+
const typebox_1 = require("../typebox");
|
|
15
|
+
class PackageNotFoundError extends egg_errors_1.NotFoundError {
|
|
16
|
+
}
|
|
17
|
+
class AbstractController extends middleware_1.MiddlewareController {
|
|
18
|
+
get sourceRegistry() {
|
|
19
|
+
return this.config.cnpmcore.sourceRegistry;
|
|
20
|
+
}
|
|
21
|
+
get enableSyncAll() {
|
|
22
|
+
return this.config.cnpmcore.syncMode === 'all';
|
|
23
|
+
}
|
|
24
|
+
isPrivateScope(scope) {
|
|
25
|
+
return scope && this.config.cnpmcore.allowScopes.includes(scope);
|
|
26
|
+
}
|
|
27
|
+
createPackageNotFoundError(fullname, version) {
|
|
28
|
+
const message = version ? `${fullname}@${version} not found` : `${fullname} not found`;
|
|
29
|
+
const err = new PackageNotFoundError(message);
|
|
30
|
+
const [scope] = (0, PackageUtil_1.getScopeAndName)(fullname);
|
|
31
|
+
// dont sync private scope
|
|
32
|
+
if (!this.isPrivateScope(scope)) {
|
|
33
|
+
// syncMode = none, redirect public package to source registry
|
|
34
|
+
if (!this.enableSyncAll) {
|
|
35
|
+
err.redirectToSourceRegistry = this.sourceRegistry;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
return err;
|
|
39
|
+
}
|
|
40
|
+
createPackageBlockError(reason, fullname, version) {
|
|
41
|
+
const message = version ? `${fullname}@${version} was blocked` : `${fullname} was blocked`;
|
|
42
|
+
return new egg_errors_1.UnavailableForLegalReasonsError(`${message}, reason: ${reason}`);
|
|
43
|
+
}
|
|
44
|
+
async getPackageEntityByFullname(fullname) {
|
|
45
|
+
const [scope, name] = (0, PackageUtil_1.getScopeAndName)(fullname);
|
|
46
|
+
return await this.getPackageEntity(scope, name);
|
|
47
|
+
}
|
|
48
|
+
// 1. get package
|
|
49
|
+
// 2. check current user is maintainer
|
|
50
|
+
// 3. make sure current token can publish
|
|
51
|
+
async getPackageEntityAndRequiredMaintainer(ctx, fullname) {
|
|
52
|
+
const [scope, name] = (0, PackageUtil_1.getScopeAndName)(fullname);
|
|
53
|
+
const pkg = await this.getPackageEntity(scope, name);
|
|
54
|
+
const authorizedUser = await this.userRoleManager.requiredAuthorizedUser(ctx, 'publish');
|
|
55
|
+
await this.userRoleManager.requiredPackageMaintainer(pkg, authorizedUser);
|
|
56
|
+
return pkg;
|
|
57
|
+
}
|
|
58
|
+
// try to get package entity, throw NotFoundError when package not exists
|
|
59
|
+
async getPackageEntity(scope, name) {
|
|
60
|
+
const packageEntity = await this.packageRepository.findPackage(scope, name);
|
|
61
|
+
if (!packageEntity) {
|
|
62
|
+
const fullname = (0, PackageUtil_1.getFullname)(scope, name);
|
|
63
|
+
throw this.createPackageNotFoundError(fullname);
|
|
64
|
+
}
|
|
65
|
+
return packageEntity;
|
|
66
|
+
}
|
|
67
|
+
async getPackageVersionEntity(pkg, version) {
|
|
68
|
+
const packageVersion = await this.packageRepository.findPackageVersion(pkg.packageId, version);
|
|
69
|
+
if (!packageVersion) {
|
|
70
|
+
throw new egg_errors_1.NotFoundError(`${pkg.fullname}@${version} not found`);
|
|
71
|
+
}
|
|
72
|
+
return packageVersion;
|
|
73
|
+
}
|
|
74
|
+
getAndCheckVersionFromFilename(ctx, fullname, filenameWithVersion) {
|
|
75
|
+
const scopeAndName = (0, PackageUtil_1.getScopeAndName)(fullname);
|
|
76
|
+
const name = scopeAndName[1];
|
|
77
|
+
// @foo/bar/-/bar-1.0.0 == filename: bar ==> 1.0.0
|
|
78
|
+
// bar/-/bar-1.0.0 == filename: bar ==> 1.0.0
|
|
79
|
+
const version = filenameWithVersion.substring(name.length + 1);
|
|
80
|
+
// check version format
|
|
81
|
+
const data = { version };
|
|
82
|
+
ctx.tValidate(typebox_1.VersionRule, data);
|
|
83
|
+
return data.version;
|
|
84
|
+
}
|
|
85
|
+
setCDNHeaders(ctx) {
|
|
86
|
+
const config = this.config.cnpmcore;
|
|
87
|
+
if (config.enableCDN) {
|
|
88
|
+
ctx.set('cache-control', config.cdnCacheControlHeader);
|
|
89
|
+
ctx.vary(config.cdnVaryHeader);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
__decorate([
|
|
94
|
+
(0, tegg_1.Inject)()
|
|
95
|
+
], AbstractController.prototype, "logger", void 0);
|
|
96
|
+
__decorate([
|
|
97
|
+
(0, tegg_1.Inject)()
|
|
98
|
+
], AbstractController.prototype, "config", void 0);
|
|
99
|
+
__decorate([
|
|
100
|
+
(0, tegg_1.Inject)()
|
|
101
|
+
], AbstractController.prototype, "userRoleManager", void 0);
|
|
102
|
+
__decorate([
|
|
103
|
+
(0, tegg_1.Inject)()
|
|
104
|
+
], AbstractController.prototype, "packageRepository", void 0);
|
|
105
|
+
__decorate([
|
|
106
|
+
(0, tegg_1.Inject)()
|
|
107
|
+
], AbstractController.prototype, "userRepository", void 0);
|
|
108
|
+
__decorate([
|
|
109
|
+
(0, tegg_1.Inject)()
|
|
110
|
+
], AbstractController.prototype, "userService", void 0);
|
|
111
|
+
exports.AbstractController = AbstractController;
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQWJzdHJhY3RDb250cm9sbGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vYXBwL3BvcnQvY29udHJvbGxlci9BYnN0cmFjdENvbnRyb2xsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsMkNBR29CO0FBQ3BCLHNDQUdxQjtBQUtyQiw4Q0FBcUQ7QUFJckQsMERBQXdFO0FBSXhFLHdDQUVvQjtBQUVwQixNQUFNLG9CQUFxQixTQUFRLDBCQUFhO0NBQUc7QUFFbkQsTUFBc0Isa0JBQW1CLFNBQVEsaUNBQW9CO0lBY25FLElBQWMsY0FBYztRQUMxQixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLGNBQWMsQ0FBQztJQUM3QyxDQUFDO0lBRUQsSUFBYyxhQUFhO1FBQ3pCLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsUUFBUSxLQUFLLEtBQUssQ0FBQztJQUNqRCxDQUFDO0lBRVMsY0FBYyxDQUFDLEtBQWE7UUFDcEMsT0FBTyxLQUFLLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNuRSxDQUFDO0lBRVMsMEJBQTBCLENBQUMsUUFBZ0IsRUFBRSxPQUFnQjtRQUNyRSxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQUcsUUFBUSxJQUFJLE9BQU8sWUFBWSxDQUFDLENBQUMsQ0FBQyxHQUFHLFFBQVEsWUFBWSxDQUFDO1FBQ3ZGLE1BQU0sR0FBRyxHQUFHLElBQUksb0JBQW9CLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDOUMsTUFBTSxDQUFFLEtBQUssQ0FBRSxHQUFHLElBQUEsNkJBQWUsRUFBQyxRQUFRLENBQUMsQ0FBQztRQUM1QywwQkFBMEI7UUFDMUIsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDL0IsOERBQThEO1lB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
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { EggContext } from '@eggjs/tegg';
|
|
3
|
+
import { AbstractController } from './AbstractController';
|
|
4
|
+
export declare class BinarySyncController extends AbstractController {
|
|
5
|
+
private binarySyncerService;
|
|
6
|
+
showBinaryHTML(ctx: EggContext): Promise<string>;
|
|
7
|
+
listBinaries(): Promise<{
|
|
8
|
+
name: string;
|
|
9
|
+
description: string;
|
|
10
|
+
distUrl: string;
|
|
11
|
+
repoUrl: string;
|
|
12
|
+
type: string;
|
|
13
|
+
url: string;
|
|
14
|
+
}[]>;
|
|
15
|
+
showBinary(ctx: EggContext, binaryName: string, subpath: string): Promise<import("stream").Readable | {
|
|
16
|
+
id: string;
|
|
17
|
+
category: string;
|
|
18
|
+
name: string;
|
|
19
|
+
date: string;
|
|
20
|
+
type: string;
|
|
21
|
+
size: number | undefined;
|
|
22
|
+
url: string;
|
|
23
|
+
modified: Date;
|
|
24
|
+
}[] | undefined>;
|
|
25
|
+
showBinaryIndex(ctx: EggContext, binaryName: string): Promise<import("stream").Readable | {
|
|
26
|
+
id: string;
|
|
27
|
+
category: string;
|
|
28
|
+
name: string;
|
|
29
|
+
date: string;
|
|
30
|
+
type: string;
|
|
31
|
+
size: number | undefined;
|
|
32
|
+
url: string;
|
|
33
|
+
modified: Date;
|
|
34
|
+
}[] | undefined>;
|
|
35
|
+
private formatItems;
|
|
36
|
+
}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
9
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.BinarySyncController = void 0;
|
|
16
|
+
const tegg_1 = require("@eggjs/tegg");
|
|
17
|
+
const path_1 = __importDefault(require("path"));
|
|
18
|
+
const egg_errors_1 = require("egg-errors");
|
|
19
|
+
const AbstractController_1 = require("./AbstractController");
|
|
20
|
+
const binaries_1 = __importDefault(require("../../../config/binaries"));
|
|
21
|
+
let BinarySyncController = class BinarySyncController extends AbstractController_1.AbstractController {
|
|
22
|
+
async showBinaryHTML(ctx) {
|
|
23
|
+
ctx.type = 'html';
|
|
24
|
+
return ctx.app.binaryHTML;
|
|
25
|
+
}
|
|
26
|
+
async listBinaries() {
|
|
27
|
+
return Object.values(binaries_1.default).map(binaryConfig => {
|
|
28
|
+
return {
|
|
29
|
+
name: `${binaryConfig.category}/`,
|
|
30
|
+
description: binaryConfig.description,
|
|
31
|
+
distUrl: binaryConfig.distUrl,
|
|
32
|
+
repoUrl: /^https?:\/\//.test(binaryConfig.repo) ? binaryConfig.repo : `https://github.com/${binaryConfig.repo}`,
|
|
33
|
+
type: 'dir',
|
|
34
|
+
url: `${this.config.cnpmcore.registry}/-/binary/${binaryConfig.category}/`,
|
|
35
|
+
};
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
async showBinary(ctx, binaryName, subpath) {
|
|
39
|
+
subpath = subpath || '/';
|
|
40
|
+
if (subpath === '/') {
|
|
41
|
+
const items = await this.binarySyncerService.listRootBinaries(binaryName);
|
|
42
|
+
return this.formatItems(items);
|
|
43
|
+
}
|
|
44
|
+
subpath = `/${subpath}`;
|
|
45
|
+
const parsed = path_1.default.parse(subpath);
|
|
46
|
+
const parent = parsed.dir === '/' ? '/' : `${parsed.dir}/`;
|
|
47
|
+
const name = subpath.endsWith('/') ? `${parsed.base}/` : parsed.base;
|
|
48
|
+
const binary = await this.binarySyncerService.findBinary(binaryName, parent, name);
|
|
49
|
+
if (!binary) {
|
|
50
|
+
throw new egg_errors_1.NotFoundError(`Binary "${binaryName}${subpath}" not found`);
|
|
51
|
+
}
|
|
52
|
+
if (binary.isDir) {
|
|
53
|
+
const items = await this.binarySyncerService.listDirBinaries(binary);
|
|
54
|
+
return this.formatItems(items);
|
|
55
|
+
}
|
|
56
|
+
// download file
|
|
57
|
+
const urlOrStream = await this.binarySyncerService.downloadBinary(binary);
|
|
58
|
+
if (!urlOrStream) {
|
|
59
|
+
throw new egg_errors_1.NotFoundError(`Binary "${binaryName}${subpath}" not found`);
|
|
60
|
+
}
|
|
61
|
+
if (typeof urlOrStream === 'string') {
|
|
62
|
+
ctx.redirect(urlOrStream);
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
ctx.attachment(name);
|
|
66
|
+
return urlOrStream;
|
|
67
|
+
}
|
|
68
|
+
async showBinaryIndex(ctx, binaryName) {
|
|
69
|
+
return await this.showBinary(ctx, binaryName, '/');
|
|
70
|
+
}
|
|
71
|
+
formatItems(items) {
|
|
72
|
+
return items.map(item => {
|
|
73
|
+
return {
|
|
74
|
+
id: item.binaryId,
|
|
75
|
+
category: item.category,
|
|
76
|
+
name: item.name,
|
|
77
|
+
date: item.date,
|
|
78
|
+
type: item.isDir ? 'dir' : 'file',
|
|
79
|
+
size: item.isDir ? undefined : item.size,
|
|
80
|
+
url: `${this.config.cnpmcore.registry}/-/binary/${item.category}${item.parent}${item.name}`,
|
|
81
|
+
modified: item.updatedAt,
|
|
82
|
+
};
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
__decorate([
|
|
87
|
+
(0, tegg_1.Inject)()
|
|
88
|
+
], BinarySyncController.prototype, "binarySyncerService", void 0);
|
|
89
|
+
__decorate([
|
|
90
|
+
(0, tegg_1.HTTPMethod)({
|
|
91
|
+
path: '/binary.html',
|
|
92
|
+
method: tegg_1.HTTPMethodEnum.GET,
|
|
93
|
+
}),
|
|
94
|
+
__param(0, (0, tegg_1.Context)())
|
|
95
|
+
], BinarySyncController.prototype, "showBinaryHTML", null);
|
|
96
|
+
__decorate([
|
|
97
|
+
(0, tegg_1.HTTPMethod)({
|
|
98
|
+
path: '/-/binary/',
|
|
99
|
+
method: tegg_1.HTTPMethodEnum.GET,
|
|
100
|
+
})
|
|
101
|
+
], BinarySyncController.prototype, "listBinaries", null);
|
|
102
|
+
__decorate([
|
|
103
|
+
(0, tegg_1.HTTPMethod)({
|
|
104
|
+
path: '/-/binary/:binaryName(@[^/]{1,220}\/[^/]{1,220}|[^@/]{1,220})/:subpath(.*)',
|
|
105
|
+
method: tegg_1.HTTPMethodEnum.GET,
|
|
106
|
+
}),
|
|
107
|
+
__param(0, (0, tegg_1.Context)()),
|
|
108
|
+
__param(1, (0, tegg_1.HTTPParam)()),
|
|
109
|
+
__param(2, (0, tegg_1.HTTPParam)())
|
|
110
|
+
], BinarySyncController.prototype, "showBinary", null);
|
|
111
|
+
__decorate([
|
|
112
|
+
(0, tegg_1.HTTPMethod)({
|
|
113
|
+
path: '/-/binary/:binaryName(@[^/]{1,220}\/[^/]{1,220}|[^@/]{1,220})',
|
|
114
|
+
method: tegg_1.HTTPMethodEnum.GET,
|
|
115
|
+
}),
|
|
116
|
+
__param(0, (0, tegg_1.Context)()),
|
|
117
|
+
__param(1, (0, tegg_1.HTTPParam)())
|
|
118
|
+
], BinarySyncController.prototype, "showBinaryIndex", null);
|
|
119
|
+
BinarySyncController = __decorate([
|
|
120
|
+
(0, tegg_1.HTTPController)()
|
|
121
|
+
], BinarySyncController);
|
|
122
|
+
exports.BinarySyncController = BinarySyncController;
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQmluYXJ5U3luY0NvbnRyb2xsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9hcHAvcG9ydC9jb250cm9sbGVyL0JpbmFyeVN5bmNDb250cm9sbGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHNDQVFxQjtBQUNyQixnREFBd0I7QUFDeEIsMkNBQTJDO0FBQzNDLDZEQUEwRDtBQUcxRCx3RUFBZ0Q7QUFHaEQsSUFBYSxvQkFBb0IsR0FBakMsTUFBYSxvQkFBcUIsU0FBUSx1Q0FBa0I7SUFRMUQsS0FBSyxDQUFDLGNBQWMsQ0FBWSxHQUFlO1FBQzdDLEdBQUcsQ0FBQyxJQUFJLEdBQUcsTUFBTSxDQUFDO1FBQ2xCLE9BQU8sR0FBRyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUM7SUFDNUIsQ0FBQztJQU1ELEtBQUssQ0FBQyxZQUFZO1FBQ2hCLE9BQU8sTUFBTSxDQUFDLE1BQU0sQ0FBQyxrQkFBUSxDQUFDLENBQUMsR0FBRyxDQUFDLFlBQVksQ0FBQyxFQUFFO1lBQ2hELE9BQU87Z0JBQ0wsSUFBSSxFQUFFLEdBQUcsWUFBWSxDQUFDLFFBQVEsR0FBRztnQkFDakMsV0FBVyxFQUFFLFlBQVksQ0FBQyxXQUFXO2dCQUNyQyxPQUFPLEVBQUUsWUFBWSxDQUFDLE9BQU87Z0JBQzdCLE9BQU8sRUFBRSxjQUFjLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsc0JBQXNCLFlBQVksQ0FBQyxJQUFJLEVBQUU7Z0JBQy9HLElBQUksRUFBRSxLQUFLO2dCQUNYLEdBQUcsRUFBRSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLFFBQVEsYUFBYSxZQUFZLENBQUMsUUFBUSxHQUFHO2FBQzNFLENBQUM7UUFDSixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFNRCxLQUFLLENBQUMsVUFB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
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { EggContext } from '@eggjs/tegg';
|
|
2
|
+
import { AbstractController } from './AbstractController';
|
|
3
|
+
export declare class ChangesStreamController extends AbstractController {
|
|
4
|
+
private changeRepository;
|
|
5
|
+
listChanges(ctx: EggContext, since: string): Promise<{
|
|
6
|
+
results: {
|
|
7
|
+
seq: bigint;
|
|
8
|
+
type: string;
|
|
9
|
+
id: string;
|
|
10
|
+
changes: any[];
|
|
11
|
+
}[];
|
|
12
|
+
}>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
9
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.ChangesStreamController = void 0;
|
|
13
|
+
const tegg_1 = require("@eggjs/tegg");
|
|
14
|
+
const typebox_1 = require("@sinclair/typebox");
|
|
15
|
+
const AbstractController_1 = require("./AbstractController");
|
|
16
|
+
const ChangeRule = typebox_1.Type.Object({
|
|
17
|
+
since: typebox_1.Type.Integer({ minimum: 0 }),
|
|
18
|
+
});
|
|
19
|
+
let ChangesStreamController = class ChangesStreamController extends AbstractController_1.AbstractController {
|
|
20
|
+
// https://github.com/cnpm/cnpmcore/issues/70
|
|
21
|
+
async listChanges(ctx, since) {
|
|
22
|
+
const params = { since: since ? Number(since) : 0 };
|
|
23
|
+
ctx.tValidate(ChangeRule, params);
|
|
24
|
+
const limit = 1000;
|
|
25
|
+
const changes = await this.changeRepository.query(params.since, limit);
|
|
26
|
+
const results = changes.reverse().map(change => {
|
|
27
|
+
return {
|
|
28
|
+
seq: change.id,
|
|
29
|
+
type: change.type,
|
|
30
|
+
id: change.targetName,
|
|
31
|
+
changes: [change.data],
|
|
32
|
+
};
|
|
33
|
+
});
|
|
34
|
+
return { results };
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
__decorate([
|
|
38
|
+
(0, tegg_1.Inject)()
|
|
39
|
+
], ChangesStreamController.prototype, "changeRepository", void 0);
|
|
40
|
+
__decorate([
|
|
41
|
+
(0, tegg_1.HTTPMethod)({
|
|
42
|
+
// /_changes?since=${since}
|
|
43
|
+
path: '/_changes',
|
|
44
|
+
method: tegg_1.HTTPMethodEnum.GET,
|
|
45
|
+
}),
|
|
46
|
+
__param(0, (0, tegg_1.Context)()),
|
|
47
|
+
__param(1, (0, tegg_1.HTTPQuery)())
|
|
48
|
+
], ChangesStreamController.prototype, "listChanges", null);
|
|
49
|
+
ChangesStreamController = __decorate([
|
|
50
|
+
(0, tegg_1.HTTPController)()
|
|
51
|
+
], ChangesStreamController);
|
|
52
|
+
exports.ChangesStreamController = ChangesStreamController;
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2hhbmdlc1N0cmVhbUNvbnRyb2xsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9hcHAvcG9ydC9jb250cm9sbGVyL0NoYW5nZXNTdHJlYW1Db250cm9sbGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztBQUFBLHNDQVFxQjtBQUNyQiwrQ0FBeUM7QUFDekMsNkRBQTBEO0FBRzFELE1BQU0sVUFBVSxHQUFHLGNBQUksQ0FBQyxNQUFNLENBQUM7SUFDN0IsS0FBSyxFQUFFLGNBQUksQ0FBQyxPQUFPLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUM7Q0FDcEMsQ0FBQyxDQUFDO0FBR0gsSUFBYSx1QkFBdUIsR0FBcEMsTUFBYSx1QkFBd0IsU0FBUSx1Q0FBa0I7SUFJN0QsNkNBQTZDO0lBTTdDLEtBQUssQ0FBQyxXQUFXLENBQVksR0FBZSxFQUFlLEtBQWE7UUFDdEUsTUFBTSxNQUFNLEdBQUcsRUFBRSxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQ3BELEdBQUcsQ0FBQyxTQUFTLENBQUMsVUFBVSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ2xDLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQztRQUNuQixNQUFNLE9BQU8sR0FBRyxNQUFNLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztRQUN2RSxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQzdDLE9BQU87Z0JBQ0wsR0FBRyxFQUFFLE1BQU0sQ0FBQyxFQUFFO2dCQUNkLElBQUksRUFBRSxNQUFNLENBQUMsSUFBSTtnQkFDakIsRUFBRSxFQUFFLE1BQU0sQ0FBQyxVQUFVO2dCQUNyQixPQUFPLEVBQUUsQ0FBRSxNQUFNLENBQUMsSUFBSSxDQUFFO2FBQ3pCLENBQUM7UUFDSixDQUFDLENBQUMsQ0FBQztRQUNILE9BQU8sRUFBRSxPQUFPLEVBQUUsQ0FBQztJQUNyQixDQUFDO0NBQ0YsQ0FBQTtBQXZCQztJQURDLElBQUEsYUFBTSxHQUFFO2lFQUNrQztBQVEzQztJQUxDLElBQUEsaUJBQVUsRUFBQztRQUNWLDJCQUEyQjtRQUMzQixJQUFJLEVBQUUsV0FBVztRQUNqQixNQUFNLEVBQUUscUJBQWMsQ0FBQyxHQUFHO0tBQzNCLENBQUM7SUFDaUIsV0FBQSxJQUFBLGNBQU8sR0FBRSxDQUFBO0lBQW1CLFdBQUEsSUFBQSxnQkFBUyxHQUFFLENBQUE7MERBY3pEO0FBeEJVLHVCQUF1QjtJQURuQyxJQUFBLHFCQUFjLEdBQUU7R0FDSix1QkFBdUIsQ0F5Qm5DO0FBekJZLDBEQUF1QiJ9
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { AbstractController } from './AbstractController';
|
|
2
|
+
export declare class DownloadController extends AbstractController {
|
|
3
|
+
private packageVersionDownloadRepository;
|
|
4
|
+
showPackageDownloads(fullname: string, range: string): Promise<{
|
|
5
|
+
downloads: {
|
|
6
|
+
day: string;
|
|
7
|
+
downloads: number;
|
|
8
|
+
}[];
|
|
9
|
+
versions: {};
|
|
10
|
+
}>;
|
|
11
|
+
showTotalDownloads(scope: string, range: string): Promise<{
|
|
12
|
+
downloads: {
|
|
13
|
+
day: string;
|
|
14
|
+
downloads: number;
|
|
15
|
+
}[];
|
|
16
|
+
}>;
|
|
17
|
+
private checkAndGetRange;
|
|
18
|
+
}
|