cnpmcore 3.78.0 → 3.80.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/app/core/service/OrgService.d.ts +1 -0
- package/dist/app/core/service/OrgService.js +15 -1
- package/dist/app/core/service/TeamService.js +9 -5
- package/dist/app/port/UserRoleManager.d.ts +2 -0
- package/dist/app/port/UserRoleManager.js +27 -1
- package/dist/app/port/controller/OrgController.d.ts +34 -0
- package/dist/app/port/controller/OrgController.js +222 -0
- package/dist/app/port/controller/PackageVersionFileController.js +3 -1
- package/dist/app/port/controller/TeamController.d.ts +47 -0
- package/dist/app/port/controller/TeamController.js +329 -0
- package/dist/app/port/controller/package/DownloadPackageVersionTar.js +3 -1
- package/dist/app/port/controller/package/ShowPackageController.d.ts +1 -0
- package/dist/app/port/controller/package/ShowPackageController.js +14 -5
- package/dist/app/port/controller/package/ShowPackageVersionController.js +2 -1
- package/dist/app/repository/OrgRepository.js +1 -1
- package/dist/app/repository/PackageRepository.d.ts +1 -0
- package/dist/app/repository/PackageRepository.js +7 -1
- package/dist/app/repository/TeamRepository.d.ts +2 -0
- package/dist/app/repository/TeamRepository.js +18 -1
- package/dist/app/repository/UserRepository.d.ts +1 -0
- package/dist/app/repository/UserRepository.js +7 -1
- package/package.json +1 -1
|
@@ -12,6 +12,7 @@ export declare class OrgService extends AbstractService {
|
|
|
12
12
|
createOrg(cmd: CreateOrgCmd): Promise<Org>;
|
|
13
13
|
removeOrg(orgId: string): Promise<void>;
|
|
14
14
|
findOrgByName(name: string): Promise<Org | null>;
|
|
15
|
+
ensureOrgForScope(scope: string): Promise<Org>;
|
|
15
16
|
addMember(orgId: string, userId: string, role?: 'owner' | 'member'): Promise<OrgMember>;
|
|
16
17
|
removeMember(orgId: string, userId: string): Promise<void>;
|
|
17
18
|
listMembers(orgId: string): Promise<OrgMember[]>;
|
|
@@ -56,6 +56,20 @@ let OrgService = class OrgService extends AbstractService_1.AbstractService {
|
|
|
56
56
|
async findOrgByName(name) {
|
|
57
57
|
return await this.orgRepository.findOrgByName(name);
|
|
58
58
|
}
|
|
59
|
+
// Auto-create org for allowScopes if it doesn't exist
|
|
60
|
+
async ensureOrgForScope(scope) {
|
|
61
|
+
const orgName = scope.replace(/^@/, '');
|
|
62
|
+
const existing = await this.orgRepository.findOrgByName(orgName);
|
|
63
|
+
if (existing)
|
|
64
|
+
return existing;
|
|
65
|
+
const org = Org_1.Org.create({
|
|
66
|
+
name: orgName,
|
|
67
|
+
description: `Auto-created org for scope ${scope}`,
|
|
68
|
+
});
|
|
69
|
+
await this.orgRepository.saveOrg(org);
|
|
70
|
+
this.logger.info('[OrgService:ensureOrgForScope] orgId: %s, scope: %s', org.orgId, scope);
|
|
71
|
+
return org;
|
|
72
|
+
}
|
|
59
73
|
async addMember(orgId, userId, role = 'member') {
|
|
60
74
|
const org = await this.orgRepository.findOrgByOrgId(orgId);
|
|
61
75
|
if (!org) {
|
|
@@ -119,4 +133,4 @@ exports.OrgService = OrgService = __decorate([
|
|
|
119
133
|
accessLevel: tegg_1.AccessLevel.PUBLIC,
|
|
120
134
|
})
|
|
121
135
|
], OrgService);
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
136
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT3JnU2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2FwcC9jb3JlL3NlcnZpY2UvT3JnU2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQSxzQ0FJcUI7QUFDckIsMkNBQTJEO0FBQzNELGtFQUErRDtBQUMvRCxzREFBeUQ7QUFDekQsa0VBQStEO0FBQy9ELG9FQUFpRTtBQUNqRSx1Q0FBb0M7QUFDcEMsbURBQWdEO0FBQ2hELHlDQUFzQztBQUN0QyxxREFBa0Q7QUFXM0MsSUFBTSxVQUFVLEdBQWhCLE1BQU0sVUFBVyxTQUFRLGlDQUFlO0lBTzdDLEtBQUssQ0FBQyxTQUFTLENBQUMsR0FBaUI7UUFDL0IsTUFBTSxRQUFRLEdBQUcsTUFBTSxJQUFJLENBQUMsYUFBYSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDbEUsSUFBSSxRQUFRLEVBQUU7WUFDWixNQUFNLElBQUksMkJBQWMsQ0FBQyxRQUFRLEdBQUcsQ0FBQyxJQUFJLGtCQUFrQixDQUFDLENBQUM7U0FDOUQ7UUFFRCx3RUFBd0U7UUFDeEUsTUFBTSxHQUFHLEdBQUcsU0FBRyxDQUFDLE1BQU0sQ0FBQztZQUNyQixJQUFJLEVBQUUsR0FBRyxDQUFDLElBQUk7WUFDZCxXQUFXLEVBQUUsR0FBRyxDQUFDLFdBQVc7U0FDN0IsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxjQUFjLEdBQUcsV0FBSSxDQUFDLE1BQU0sQ0FBQztZQUNqQyxLQUFLLEVBQUUsR0FBRyxDQUFDLEtBQUs7WUFDaEIsSUFBSSxFQUFFLDJCQUFlO1lBQ3JCLFdBQVcsRUFBRSxjQUFjO1NBQzVCLENBQUMsQ0FBQztRQUNILE1BQU0sV0FBVyxHQUFHLHFCQUFTLENBQUMsTUFBTSxDQUFDO1lBQ25DLEtBQUssRUFBRSxHQUFHLENBQUMsS0FBSztZQUNoQixNQUFNLEVBQUUsR0FBRyxDQUFDLGFBQWE7WUFDekIsSUFBSSxFQUFFLE9B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
|
|
@@ -51,10 +51,14 @@ let TeamService = class TeamService extends AbstractService_1.AbstractService {
|
|
|
51
51
|
if (!team) {
|
|
52
52
|
throw new egg_errors_1.NotFoundError('Team not found');
|
|
53
53
|
}
|
|
54
|
-
//
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
54
|
+
// For allowScopes orgs, skip org member check (self-registry users have implicit access)
|
|
55
|
+
// For other orgs, must be an org member first
|
|
56
|
+
const org = await this.orgRepository.findOrgByOrgId(team.orgId);
|
|
57
|
+
if (org && !this.config.cnpmcore.allowScopes.includes(`@${org.name}`)) {
|
|
58
|
+
const orgMember = await this.orgRepository.findMember(team.orgId, userId);
|
|
59
|
+
if (!orgMember) {
|
|
60
|
+
throw new egg_errors_1.ForbiddenError('User must be an org member before joining a team');
|
|
61
|
+
}
|
|
58
62
|
}
|
|
59
63
|
const existing = await this.teamRepository.findMember(teamId, userId);
|
|
60
64
|
if (existing) {
|
|
@@ -108,4 +112,4 @@ exports.TeamService = TeamService = __decorate([
|
|
|
108
112
|
accessLevel: tegg_1.AccessLevel.PUBLIC,
|
|
109
113
|
})
|
|
110
114
|
], TeamService);
|
|
111
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGVhbVNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9hcHAvY29yZS9zZXJ2aWNlL1RlYW1TZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztBQUFBLHNDQUlxQjtBQUNyQiwyQ0FBMkQ7QUFDM0Qsa0VBQStEO0FBQy9ELHNEQUF5RDtBQUN6RCxrRUFBK0Q7QUFDL0Qsb0VBQWlFO0FBQ2pFLHlDQUFzQztBQUN0QyxxREFBa0Q7QUFDbEQsdURBQW9EO0FBSzdDLElBQU0sV0FBVyxHQUFqQixNQUFNLFdBQVksU0FBUSxpQ0FBZTtJQVE5QyxLQUFLLENBQUMsVUFBVSxDQUFDLEtBQWEsRUFBRSxJQUFZLEVBQUUsV0FBb0I7UUFDaEUsTUFBTSxRQUFRLEdBQUcsTUFBTSxJQUFJLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDakUsSUFBSSxRQUFRLEVBQUU7WUFDWixNQUFNLElBQUksMkJBQWMsQ0FBQyxTQUFTLElBQUksa0JBQWtCLENBQUMsQ0FBQztTQUMzRDtRQUVELE1BQU0sSUFBSSxHQUFHLFdBQUksQ0FBQyxNQUFNLENBQUM7WUFDdkIsS0FBSztZQUNMLElBQUk7WUFDSixXQUFXO1NBQ1osQ0FBQyxDQUFDO1FBQ0gsTUFBTSxJQUFJLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6QyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQywwREFBMEQsRUFBRSxJQUFJLENBQUMsTUFBTSxFQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztRQUN2RyxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxLQUFLLENBQUMsVUFBVSxDQUFDLE1BQWM7UUFDN0IsTUFBTSxJQUFJLEdBQUcsTUFBTSxJQUFJLENBQUMsY0FBYyxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ2hFLElBQUksQ0FB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
|
|
@@ -10,6 +10,7 @@ export declare class UserRoleManager {
|
|
|
10
10
|
protected logger: EggLogger;
|
|
11
11
|
private readonly registryManagerService;
|
|
12
12
|
private readonly tokenService;
|
|
13
|
+
private readonly teamRepository;
|
|
13
14
|
private handleAuthorized;
|
|
14
15
|
private currentAuthorizedUser;
|
|
15
16
|
private currentAuthorizedToken;
|
|
@@ -22,4 +23,5 @@ export declare class UserRoleManager {
|
|
|
22
23
|
requiredPackageMaintainer(pkg: PackageEntity, user: UserEntity): Promise<void>;
|
|
23
24
|
requiredPackageScope(scope: string, user: UserEntity): Promise<void>;
|
|
24
25
|
isAdmin(ctx: EggContext): Promise<boolean>;
|
|
26
|
+
checkReadAccess(ctx: EggContext, scope: string, name: string): Promise<boolean>;
|
|
25
27
|
}
|
|
@@ -13,6 +13,7 @@ exports.UserRoleManager = void 0;
|
|
|
13
13
|
const tegg_1 = require("@eggjs/tegg");
|
|
14
14
|
const egg_errors_1 = require("egg-errors");
|
|
15
15
|
const PackageRepository_1 = require("../repository/PackageRepository");
|
|
16
|
+
const TeamRepository_1 = require("../repository/TeamRepository");
|
|
16
17
|
const PackageUtil_1 = require("../common/PackageUtil");
|
|
17
18
|
const RegistryManagerService_1 = require("../core/service/RegistryManagerService");
|
|
18
19
|
const TokenService_1 = require("../core/service/TokenService");
|
|
@@ -159,6 +160,27 @@ let UserRoleManager = class UserRoleManager {
|
|
|
159
160
|
return false;
|
|
160
161
|
return user.name in this.config.cnpmcore.admins;
|
|
161
162
|
}
|
|
163
|
+
// self scope + no team binding = everyone can read, returns false
|
|
164
|
+
// self scope + team binding = only team members can read, returns true
|
|
165
|
+
// returns true if package is team-bound (private cache needed)
|
|
166
|
+
async checkReadAccess(ctx, scope, name) {
|
|
167
|
+
if (!scope || !this.config.cnpmcore.allowScopes.includes(scope))
|
|
168
|
+
return false;
|
|
169
|
+
const pkg = await this.packageRepository.findPackage(scope, name);
|
|
170
|
+
if (!pkg)
|
|
171
|
+
return false; // let downstream throw 404
|
|
172
|
+
const hasTeamBinding = await this.teamRepository.hasAnyTeamBinding(pkg.packageId);
|
|
173
|
+
if (!hasTeamBinding)
|
|
174
|
+
return false; // no team binding, everyone can read
|
|
175
|
+
// team binding exists, require auth
|
|
176
|
+
const user = await this.requiredAuthorizedUser(ctx, 'read');
|
|
177
|
+
if (await this.isAdmin(ctx))
|
|
178
|
+
return true;
|
|
179
|
+
const hasAccess = await this.teamRepository.hasPackageAccess(pkg.packageId, user.userId);
|
|
180
|
+
if (hasAccess)
|
|
181
|
+
return true;
|
|
182
|
+
throw new egg_errors_1.ForbiddenError(`"${user.name}" is not authorized to access ${pkg.fullname}`);
|
|
183
|
+
}
|
|
162
184
|
};
|
|
163
185
|
exports.UserRoleManager = UserRoleManager;
|
|
164
186
|
__decorate([
|
|
@@ -181,10 +203,14 @@ __decorate([
|
|
|
181
203
|
(0, tegg_1.Inject)(),
|
|
182
204
|
__metadata("design:type", TokenService_1.TokenService)
|
|
183
205
|
], UserRoleManager.prototype, "tokenService", void 0);
|
|
206
|
+
__decorate([
|
|
207
|
+
(0, tegg_1.Inject)(),
|
|
208
|
+
__metadata("design:type", TeamRepository_1.TeamRepository)
|
|
209
|
+
], UserRoleManager.prototype, "teamRepository", void 0);
|
|
184
210
|
exports.UserRoleManager = UserRoleManager = __decorate([
|
|
185
211
|
(0, tegg_1.ContextProto)({
|
|
186
212
|
// only inject on port module
|
|
187
213
|
accessLevel: tegg_1.AccessLevel.PRIVATE,
|
|
188
214
|
})
|
|
189
215
|
], UserRoleManager);
|
|
190
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
216
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"UserRoleManager.js","sourceRoot":"","sources":["../../../app/port/UserRoleManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { EggContext } from '@eggjs/tegg';
|
|
2
|
+
import { AbstractController } from './AbstractController';
|
|
3
|
+
export declare class OrgController extends AbstractController {
|
|
4
|
+
private readonly orgService;
|
|
5
|
+
private readonly teamRepository;
|
|
6
|
+
createOrg(ctx: EggContext, body: {
|
|
7
|
+
name: string;
|
|
8
|
+
description?: string;
|
|
9
|
+
}): Promise<{
|
|
10
|
+
ok: boolean;
|
|
11
|
+
}>;
|
|
12
|
+
showOrg(ctx: EggContext, orgName: string): Promise<{
|
|
13
|
+
name: string;
|
|
14
|
+
description: string;
|
|
15
|
+
created: Date;
|
|
16
|
+
}>;
|
|
17
|
+
removeOrg(ctx: EggContext, orgName: string): Promise<{
|
|
18
|
+
ok: boolean;
|
|
19
|
+
}>;
|
|
20
|
+
listMembers(ctx: EggContext, orgName: string): Promise<Record<string, string>>;
|
|
21
|
+
addMember(ctx: EggContext, orgName: string, body: {
|
|
22
|
+
user: string;
|
|
23
|
+
role?: 'owner' | 'member';
|
|
24
|
+
}): Promise<{
|
|
25
|
+
ok: boolean;
|
|
26
|
+
}>;
|
|
27
|
+
removeMember(ctx: EggContext, orgName: string, username: string): Promise<{
|
|
28
|
+
ok: boolean;
|
|
29
|
+
}>;
|
|
30
|
+
listUserTeams(ctx: EggContext, orgName: string, username: string): Promise<{
|
|
31
|
+
name: string;
|
|
32
|
+
description: string;
|
|
33
|
+
}[]>;
|
|
34
|
+
}
|
|
@@ -0,0 +1,222 @@
|
|
|
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 __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.OrgController = void 0;
|
|
16
|
+
const tegg_1 = require("@eggjs/tegg");
|
|
17
|
+
const egg_errors_1 = require("egg-errors");
|
|
18
|
+
const AbstractController_1 = require("./AbstractController");
|
|
19
|
+
const AdminAccess_1 = require("../middleware/AdminAccess");
|
|
20
|
+
const OrgService_1 = require("../../core/service/OrgService");
|
|
21
|
+
const TeamRepository_1 = require("../../repository/TeamRepository");
|
|
22
|
+
let OrgController = class OrgController extends AbstractController_1.AbstractController {
|
|
23
|
+
// PUT /-/org — Admin only
|
|
24
|
+
async createOrg(ctx, body) {
|
|
25
|
+
const authorizedUser = await this.userRoleManager.requiredAuthorizedUser(ctx, 'setting');
|
|
26
|
+
if (!body.name) {
|
|
27
|
+
throw new egg_errors_1.UnprocessableEntityError('name is required');
|
|
28
|
+
}
|
|
29
|
+
await this.orgService.createOrg({
|
|
30
|
+
name: body.name,
|
|
31
|
+
description: body.description,
|
|
32
|
+
creatorUserId: authorizedUser.userId,
|
|
33
|
+
});
|
|
34
|
+
return { ok: true };
|
|
35
|
+
}
|
|
36
|
+
// GET /-/org/:orgName
|
|
37
|
+
async showOrg(ctx, orgName) {
|
|
38
|
+
await this.userRoleManager.requiredAuthorizedUser(ctx, 'read');
|
|
39
|
+
const org = await this.orgService.findOrgByName(orgName);
|
|
40
|
+
if (!org) {
|
|
41
|
+
throw new egg_errors_1.NotFoundError(`Org "${orgName}" not found`);
|
|
42
|
+
}
|
|
43
|
+
return {
|
|
44
|
+
name: org.name,
|
|
45
|
+
description: org.description,
|
|
46
|
+
created: org.createdAt,
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
// DELETE /-/org/:orgName — Admin only
|
|
50
|
+
async removeOrg(ctx, orgName) {
|
|
51
|
+
await this.userRoleManager.requiredAuthorizedUser(ctx, 'setting');
|
|
52
|
+
const org = await this.orgService.findOrgByName(orgName);
|
|
53
|
+
if (!org) {
|
|
54
|
+
throw new egg_errors_1.NotFoundError(`Org "${orgName}" not found`);
|
|
55
|
+
}
|
|
56
|
+
await this.orgService.removeOrg(org.orgId);
|
|
57
|
+
return { ok: true };
|
|
58
|
+
}
|
|
59
|
+
// GET /-/org/:orgName/member — npm org ls
|
|
60
|
+
async listMembers(ctx, orgName) {
|
|
61
|
+
await this.userRoleManager.requiredAuthorizedUser(ctx, 'read');
|
|
62
|
+
const org = await this.orgService.findOrgByName(orgName);
|
|
63
|
+
if (!org) {
|
|
64
|
+
throw new egg_errors_1.NotFoundError(`Org "${orgName}" not found`);
|
|
65
|
+
}
|
|
66
|
+
const members = await this.orgService.listMembers(org.orgId);
|
|
67
|
+
const users = await this.userRepository.findUsersByUserIds(members.map(m => m.userId));
|
|
68
|
+
const userMap = new Map(users.map(u => [u.userId, u]));
|
|
69
|
+
const result = {};
|
|
70
|
+
for (const member of members) {
|
|
71
|
+
const user = userMap.get(member.userId);
|
|
72
|
+
if (user) {
|
|
73
|
+
result[user.displayName] = member.role;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return result;
|
|
77
|
+
}
|
|
78
|
+
// PUT /-/org/:orgName/member — npm org set
|
|
79
|
+
async addMember(ctx, orgName, body) {
|
|
80
|
+
const authorizedUser = await this.userRoleManager.requiredAuthorizedUser(ctx, 'setting');
|
|
81
|
+
const org = await this.orgService.findOrgByName(orgName);
|
|
82
|
+
if (!org) {
|
|
83
|
+
throw new egg_errors_1.NotFoundError(`Org "${orgName}" not found`);
|
|
84
|
+
}
|
|
85
|
+
const isAdmin = await this.userRoleManager.isAdmin(ctx);
|
|
86
|
+
await this.orgService.requiredOrgOwnerOrAdmin(org.orgId, authorizedUser.userId, isAdmin);
|
|
87
|
+
if (!body.user) {
|
|
88
|
+
throw new egg_errors_1.UnprocessableEntityError('user is required');
|
|
89
|
+
}
|
|
90
|
+
const targetUser = await this.userRepository.findUserByName(body.user);
|
|
91
|
+
if (!targetUser) {
|
|
92
|
+
throw new egg_errors_1.NotFoundError(`User "${body.user}" not found`);
|
|
93
|
+
}
|
|
94
|
+
await this.orgService.addMember(org.orgId, targetUser.userId, body.role || 'member');
|
|
95
|
+
return { ok: true };
|
|
96
|
+
}
|
|
97
|
+
// DELETE /-/org/:orgName/member/:username — npm org rm
|
|
98
|
+
async removeMember(ctx, orgName, username) {
|
|
99
|
+
const authorizedUser = await this.userRoleManager.requiredAuthorizedUser(ctx, 'setting');
|
|
100
|
+
const org = await this.orgService.findOrgByName(orgName);
|
|
101
|
+
if (!org) {
|
|
102
|
+
throw new egg_errors_1.NotFoundError(`Org "${orgName}" not found`);
|
|
103
|
+
}
|
|
104
|
+
const isAdmin = await this.userRoleManager.isAdmin(ctx);
|
|
105
|
+
await this.orgService.requiredOrgOwnerOrAdmin(org.orgId, authorizedUser.userId, isAdmin);
|
|
106
|
+
const targetUser = await this.userRepository.findUserByName(username);
|
|
107
|
+
if (!targetUser) {
|
|
108
|
+
throw new egg_errors_1.NotFoundError(`User "${username}" not found`);
|
|
109
|
+
}
|
|
110
|
+
await this.orgService.removeMember(org.orgId, targetUser.userId);
|
|
111
|
+
return { ok: true };
|
|
112
|
+
}
|
|
113
|
+
// GET /-/org/:orgName/member/:username/team
|
|
114
|
+
async listUserTeams(ctx, orgName, username) {
|
|
115
|
+
await this.userRoleManager.requiredAuthorizedUser(ctx, 'read');
|
|
116
|
+
const org = await this.orgService.findOrgByName(orgName);
|
|
117
|
+
if (!org) {
|
|
118
|
+
throw new egg_errors_1.NotFoundError(`Org "${orgName}" not found`);
|
|
119
|
+
}
|
|
120
|
+
const targetUser = await this.userRepository.findUserByName(username);
|
|
121
|
+
if (!targetUser) {
|
|
122
|
+
throw new egg_errors_1.NotFoundError(`User "${username}" not found`);
|
|
123
|
+
}
|
|
124
|
+
const teams = await this.teamRepository.listTeamsByUserIdAndOrgId(targetUser.userId, org.orgId);
|
|
125
|
+
return teams.map(t => ({ name: t.name, description: t.description }));
|
|
126
|
+
}
|
|
127
|
+
};
|
|
128
|
+
exports.OrgController = OrgController;
|
|
129
|
+
__decorate([
|
|
130
|
+
(0, tegg_1.Inject)(),
|
|
131
|
+
__metadata("design:type", OrgService_1.OrgService)
|
|
132
|
+
], OrgController.prototype, "orgService", void 0);
|
|
133
|
+
__decorate([
|
|
134
|
+
(0, tegg_1.Inject)(),
|
|
135
|
+
__metadata("design:type", TeamRepository_1.TeamRepository)
|
|
136
|
+
], OrgController.prototype, "teamRepository", void 0);
|
|
137
|
+
__decorate([
|
|
138
|
+
(0, tegg_1.HTTPMethod)({
|
|
139
|
+
path: '/-/org',
|
|
140
|
+
method: tegg_1.HTTPMethodEnum.PUT,
|
|
141
|
+
}),
|
|
142
|
+
(0, tegg_1.Middleware)(AdminAccess_1.AdminAccess),
|
|
143
|
+
__param(0, (0, tegg_1.Context)()),
|
|
144
|
+
__param(1, (0, tegg_1.HTTPBody)()),
|
|
145
|
+
__metadata("design:type", Function),
|
|
146
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
147
|
+
__metadata("design:returntype", Promise)
|
|
148
|
+
], OrgController.prototype, "createOrg", null);
|
|
149
|
+
__decorate([
|
|
150
|
+
(0, tegg_1.HTTPMethod)({
|
|
151
|
+
path: '/-/org/:orgName',
|
|
152
|
+
method: tegg_1.HTTPMethodEnum.GET,
|
|
153
|
+
}),
|
|
154
|
+
__param(0, (0, tegg_1.Context)()),
|
|
155
|
+
__param(1, (0, tegg_1.HTTPParam)()),
|
|
156
|
+
__metadata("design:type", Function),
|
|
157
|
+
__metadata("design:paramtypes", [Object, String]),
|
|
158
|
+
__metadata("design:returntype", Promise)
|
|
159
|
+
], OrgController.prototype, "showOrg", null);
|
|
160
|
+
__decorate([
|
|
161
|
+
(0, tegg_1.HTTPMethod)({
|
|
162
|
+
path: '/-/org/:orgName',
|
|
163
|
+
method: tegg_1.HTTPMethodEnum.DELETE,
|
|
164
|
+
}),
|
|
165
|
+
(0, tegg_1.Middleware)(AdminAccess_1.AdminAccess),
|
|
166
|
+
__param(0, (0, tegg_1.Context)()),
|
|
167
|
+
__param(1, (0, tegg_1.HTTPParam)()),
|
|
168
|
+
__metadata("design:type", Function),
|
|
169
|
+
__metadata("design:paramtypes", [Object, String]),
|
|
170
|
+
__metadata("design:returntype", Promise)
|
|
171
|
+
], OrgController.prototype, "removeOrg", null);
|
|
172
|
+
__decorate([
|
|
173
|
+
(0, tegg_1.HTTPMethod)({
|
|
174
|
+
path: '/-/org/:orgName/member',
|
|
175
|
+
method: tegg_1.HTTPMethodEnum.GET,
|
|
176
|
+
}),
|
|
177
|
+
__param(0, (0, tegg_1.Context)()),
|
|
178
|
+
__param(1, (0, tegg_1.HTTPParam)()),
|
|
179
|
+
__metadata("design:type", Function),
|
|
180
|
+
__metadata("design:paramtypes", [Object, String]),
|
|
181
|
+
__metadata("design:returntype", Promise)
|
|
182
|
+
], OrgController.prototype, "listMembers", null);
|
|
183
|
+
__decorate([
|
|
184
|
+
(0, tegg_1.HTTPMethod)({
|
|
185
|
+
path: '/-/org/:orgName/member',
|
|
186
|
+
method: tegg_1.HTTPMethodEnum.PUT,
|
|
187
|
+
}),
|
|
188
|
+
__param(0, (0, tegg_1.Context)()),
|
|
189
|
+
__param(1, (0, tegg_1.HTTPParam)()),
|
|
190
|
+
__param(2, (0, tegg_1.HTTPBody)()),
|
|
191
|
+
__metadata("design:type", Function),
|
|
192
|
+
__metadata("design:paramtypes", [Object, String, Object]),
|
|
193
|
+
__metadata("design:returntype", Promise)
|
|
194
|
+
], OrgController.prototype, "addMember", null);
|
|
195
|
+
__decorate([
|
|
196
|
+
(0, tegg_1.HTTPMethod)({
|
|
197
|
+
path: '/-/org/:orgName/member/:username',
|
|
198
|
+
method: tegg_1.HTTPMethodEnum.DELETE,
|
|
199
|
+
}),
|
|
200
|
+
__param(0, (0, tegg_1.Context)()),
|
|
201
|
+
__param(1, (0, tegg_1.HTTPParam)()),
|
|
202
|
+
__param(2, (0, tegg_1.HTTPParam)()),
|
|
203
|
+
__metadata("design:type", Function),
|
|
204
|
+
__metadata("design:paramtypes", [Object, String, String]),
|
|
205
|
+
__metadata("design:returntype", Promise)
|
|
206
|
+
], OrgController.prototype, "removeMember", null);
|
|
207
|
+
__decorate([
|
|
208
|
+
(0, tegg_1.HTTPMethod)({
|
|
209
|
+
path: '/-/org/:orgName/member/:username/team',
|
|
210
|
+
method: tegg_1.HTTPMethodEnum.GET,
|
|
211
|
+
}),
|
|
212
|
+
__param(0, (0, tegg_1.Context)()),
|
|
213
|
+
__param(1, (0, tegg_1.HTTPParam)()),
|
|
214
|
+
__param(2, (0, tegg_1.HTTPParam)()),
|
|
215
|
+
__metadata("design:type", Function),
|
|
216
|
+
__metadata("design:paramtypes", [Object, String, String]),
|
|
217
|
+
__metadata("design:returntype", Promise)
|
|
218
|
+
], OrgController.prototype, "listUserTeams", null);
|
|
219
|
+
exports.OrgController = OrgController = __decorate([
|
|
220
|
+
(0, tegg_1.HTTPController)()
|
|
221
|
+
], OrgController);
|
|
222
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"OrgController.js","sourceRoot":"","sources":["../../../../app/port/controller/OrgController.ts"],"names":[],"mappings":"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"}
|
|
@@ -62,6 +62,7 @@ let PackageVersionFileController = class PackageVersionFileController extends Ab
|
|
|
62
62
|
ctx.tValidate(typebox_1.Spec, `${fullname}@${versionSpec}`);
|
|
63
63
|
ctx.vary(this.config.cnpmcore.cdnVaryHeader);
|
|
64
64
|
const [scope, name] = (0, PackageUtil_1.getScopeAndName)(fullname);
|
|
65
|
+
await this.userRoleManager.checkReadAccess(ctx, scope, name);
|
|
65
66
|
const packageVersion = await __classPrivateFieldGet(this, _PackageVersionFileController_instances, "m", _PackageVersionFileController_getPackageVersion).call(this, ctx, fullname, scope, name, versionSpec);
|
|
66
67
|
ctx.set('cache-control', META_CACHE_CONTROL);
|
|
67
68
|
const hasMeta = typeof meta === 'string' || ctx.path.endsWith('/files/');
|
|
@@ -87,6 +88,7 @@ let PackageVersionFileController = class PackageVersionFileController extends Ab
|
|
|
87
88
|
ctx.tValidate(typebox_1.Spec, `${fullname}@${versionSpec}`);
|
|
88
89
|
ctx.vary(this.config.cnpmcore.cdnVaryHeader);
|
|
89
90
|
const [scope, name] = (0, PackageUtil_1.getScopeAndName)(fullname);
|
|
91
|
+
await this.userRoleManager.checkReadAccess(ctx, scope, name);
|
|
90
92
|
path = `/${path}`;
|
|
91
93
|
const packageVersion = await __classPrivateFieldGet(this, _PackageVersionFileController_instances, "m", _PackageVersionFileController_getPackageVersion).call(this, ctx, fullname, scope, name, versionSpec);
|
|
92
94
|
if (path.endsWith('/')) {
|
|
@@ -246,4 +248,4 @@ __decorate([
|
|
|
246
248
|
exports.PackageVersionFileController = PackageVersionFileController = __decorate([
|
|
247
249
|
(0, tegg_1.HTTPController)()
|
|
248
250
|
], PackageVersionFileController);
|
|
249
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PackageVersionFileController.js","sourceRoot":"","sources":["../../../../app/port/controller/PackageVersionFileController.ts"],"names":[],"mappings":"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"}
|
|
251
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PackageVersionFileController.js","sourceRoot":"","sources":["../../../../app/port/controller/PackageVersionFileController.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { EggContext } from '@eggjs/tegg';
|
|
2
|
+
import { AbstractController } from './AbstractController';
|
|
3
|
+
export declare class TeamController extends AbstractController {
|
|
4
|
+
private readonly orgService;
|
|
5
|
+
private readonly teamService;
|
|
6
|
+
private readonly teamRepository;
|
|
7
|
+
private isAllowScopeOrg;
|
|
8
|
+
private findOrg;
|
|
9
|
+
private requireOrgWriteAccess;
|
|
10
|
+
private requireTeamWriteAccess;
|
|
11
|
+
createTeam(ctx: EggContext, orgName: string, body: {
|
|
12
|
+
name: string;
|
|
13
|
+
description?: string;
|
|
14
|
+
}): Promise<{
|
|
15
|
+
ok: boolean;
|
|
16
|
+
}>;
|
|
17
|
+
listTeams(ctx: EggContext, orgName: string): Promise<{
|
|
18
|
+
name: string;
|
|
19
|
+
description: string;
|
|
20
|
+
}[]>;
|
|
21
|
+
showTeam(ctx: EggContext, orgName: string, teamName: string): Promise<{
|
|
22
|
+
name: string;
|
|
23
|
+
description: string;
|
|
24
|
+
created: Date;
|
|
25
|
+
}>;
|
|
26
|
+
removeTeam(ctx: EggContext, orgName: string, teamName: string): Promise<{
|
|
27
|
+
ok: boolean;
|
|
28
|
+
}>;
|
|
29
|
+
listTeamMembers(ctx: EggContext, orgName: string, teamName: string): Promise<string[]>;
|
|
30
|
+
addTeamMember(ctx: EggContext, orgName: string, teamName: string, body: {
|
|
31
|
+
user: string;
|
|
32
|
+
}): Promise<{
|
|
33
|
+
ok: boolean;
|
|
34
|
+
}>;
|
|
35
|
+
removeTeamMember(ctx: EggContext, orgName: string, teamName: string, username: string): Promise<{
|
|
36
|
+
ok: boolean;
|
|
37
|
+
}>;
|
|
38
|
+
listTeamPackages(ctx: EggContext, orgName: string, teamName: string): Promise<Record<string, string>>;
|
|
39
|
+
grantPackageAccess(ctx: EggContext, orgName: string, teamName: string, body: {
|
|
40
|
+
package: string;
|
|
41
|
+
}): Promise<{
|
|
42
|
+
ok: boolean;
|
|
43
|
+
}>;
|
|
44
|
+
revokePackageAccess(ctx: EggContext, orgName: string, teamName: string, scope: string, name: string): Promise<{
|
|
45
|
+
ok: boolean;
|
|
46
|
+
}>;
|
|
47
|
+
}
|