@meridianjs/meridian 0.1.2 → 0.1.3
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/api/admin/projects/[id]/access/route.d.ts +3 -0
- package/dist/api/admin/projects/[id]/access/route.d.ts.map +1 -0
- package/dist/api/admin/projects/[id]/access/route.js +33 -0
- package/dist/api/admin/projects/[id]/access/route.js.map +1 -0
- package/dist/api/admin/projects/[id]/members/[userId]/route.d.ts +3 -0
- package/dist/api/admin/projects/[id]/members/[userId]/route.d.ts.map +1 -0
- package/dist/api/admin/projects/[id]/members/[userId]/route.js +6 -0
- package/dist/api/admin/projects/[id]/members/[userId]/route.js.map +1 -0
- package/dist/api/admin/projects/[id]/members/route.d.ts +3 -0
- package/dist/api/admin/projects/[id]/members/route.d.ts.map +1 -0
- package/dist/api/admin/projects/[id]/members/route.js +11 -0
- package/dist/api/admin/projects/[id]/members/route.js.map +1 -0
- package/dist/api/admin/projects/[id]/teams/[teamId]/route.d.ts +3 -0
- package/dist/api/admin/projects/[id]/teams/[teamId]/route.d.ts.map +1 -0
- package/dist/api/admin/projects/[id]/teams/[teamId]/route.js +6 -0
- package/dist/api/admin/projects/[id]/teams/[teamId]/route.js.map +1 -0
- package/dist/api/admin/projects/[id]/teams/route.d.ts +3 -0
- package/dist/api/admin/projects/[id]/teams/route.d.ts.map +1 -0
- package/dist/api/admin/projects/[id]/teams/route.js +11 -0
- package/dist/api/admin/projects/[id]/teams/route.js.map +1 -0
- package/dist/api/admin/projects/route.d.ts.map +1 -1
- package/dist/api/admin/projects/route.js +38 -1
- package/dist/api/admin/projects/route.js.map +1 -1
- package/dist/api/admin/workspaces/[id]/invitations/[inviteId]/route.d.ts +3 -0
- package/dist/api/admin/workspaces/[id]/invitations/[inviteId]/route.d.ts.map +1 -0
- package/dist/api/admin/workspaces/[id]/invitations/[inviteId]/route.js +6 -0
- package/dist/api/admin/workspaces/[id]/invitations/[inviteId]/route.js.map +1 -0
- package/dist/api/admin/workspaces/[id]/invitations/route.d.ts +4 -0
- package/dist/api/admin/workspaces/[id]/invitations/route.d.ts.map +1 -0
- package/dist/api/admin/workspaces/[id]/invitations/route.js +27 -0
- package/dist/api/admin/workspaces/[id]/invitations/route.js.map +1 -0
- package/dist/api/admin/workspaces/[id]/members/[userId]/route.d.ts +4 -0
- package/dist/api/admin/workspaces/[id]/members/[userId]/route.d.ts.map +1 -0
- package/dist/api/admin/workspaces/[id]/members/[userId]/route.js +26 -0
- package/dist/api/admin/workspaces/[id]/members/[userId]/route.js.map +1 -0
- package/dist/api/admin/workspaces/[id]/members/route.d.ts +4 -0
- package/dist/api/admin/workspaces/[id]/members/route.d.ts.map +1 -0
- package/dist/api/admin/workspaces/[id]/members/route.js +40 -0
- package/dist/api/admin/workspaces/[id]/members/route.js.map +1 -0
- package/dist/api/admin/workspaces/[id]/teams/[teamId]/members/[userId]/route.d.ts +3 -0
- package/dist/api/admin/workspaces/[id]/teams/[teamId]/members/[userId]/route.d.ts.map +1 -0
- package/dist/api/admin/workspaces/[id]/teams/[teamId]/members/[userId]/route.js +6 -0
- package/dist/api/admin/workspaces/[id]/teams/[teamId]/members/[userId]/route.js.map +1 -0
- package/dist/api/admin/workspaces/[id]/teams/[teamId]/members/route.d.ts +4 -0
- package/dist/api/admin/workspaces/[id]/teams/[teamId]/members/route.d.ts.map +1 -0
- package/dist/api/admin/workspaces/[id]/teams/[teamId]/members/route.js +37 -0
- package/dist/api/admin/workspaces/[id]/teams/[teamId]/members/route.js.map +1 -0
- package/dist/api/admin/workspaces/[id]/teams/[teamId]/route.d.ts +5 -0
- package/dist/api/admin/workspaces/[id]/teams/[teamId]/route.d.ts.map +1 -0
- package/dist/api/admin/workspaces/[id]/teams/[teamId]/route.js +26 -0
- package/dist/api/admin/workspaces/[id]/teams/[teamId]/route.js.map +1 -0
- package/dist/api/admin/workspaces/[id]/teams/route.d.ts +4 -0
- package/dist/api/admin/workspaces/[id]/teams/route.d.ts.map +1 -0
- package/dist/api/admin/workspaces/[id]/teams/route.js +26 -0
- package/dist/api/admin/workspaces/[id]/teams/route.js.map +1 -0
- package/dist/api/admin/workspaces/route.d.ts.map +1 -1
- package/dist/api/admin/workspaces/route.js +25 -2
- package/dist/api/admin/workspaces/route.js.map +1 -1
- package/dist/api/auth/invite/[token]/route.d.ts +9 -0
- package/dist/api/auth/invite/[token]/route.d.ts.map +1 -0
- package/dist/api/auth/invite/[token]/route.js +73 -0
- package/dist/api/auth/invite/[token]/route.js.map +1 -0
- package/dist/workflows/create-invitation.d.ts +8 -0
- package/dist/workflows/create-invitation.d.ts.map +1 -0
- package/dist/workflows/create-invitation.js +31 -0
- package/dist/workflows/create-invitation.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../../src/api/admin/projects/[id]/access/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAEvC,eAAO,MAAM,GAAG,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAqChD,CAAA"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
export const GET = async (req, res) => {
|
|
2
|
+
const projectMemberService = req.scope.resolve("projectMemberModuleService");
|
|
3
|
+
const userService = req.scope.resolve("userModuleService");
|
|
4
|
+
const teamMemberService = req.scope.resolve("teamMemberModuleService");
|
|
5
|
+
const members = await projectMemberService.listProjectMembers(req.params.id);
|
|
6
|
+
const teamEntries = await projectMemberService.listProjectTeamIds(req.params.id);
|
|
7
|
+
const enrichedMembers = await Promise.all(members.map(async (m) => {
|
|
8
|
+
try {
|
|
9
|
+
const user = await userService.retrieveUser(m.user_id);
|
|
10
|
+
return {
|
|
11
|
+
id: m.id,
|
|
12
|
+
user_id: m.user_id,
|
|
13
|
+
role: m.role,
|
|
14
|
+
user: { id: user.id, email: user.email, first_name: user.first_name, last_name: user.last_name },
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
return { id: m.id, user_id: m.user_id, role: m.role, user: null };
|
|
19
|
+
}
|
|
20
|
+
}));
|
|
21
|
+
const enrichedTeams = await Promise.all(teamEntries.map(async (t) => {
|
|
22
|
+
try {
|
|
23
|
+
const team = await userService.retrieveTeam(t.team_id);
|
|
24
|
+
const memberIds = await teamMemberService.getTeamMemberUserIds(t.team_id);
|
|
25
|
+
return { id: t.id, team_id: t.team_id, team: { ...team, member_count: memberIds.length } };
|
|
26
|
+
}
|
|
27
|
+
catch {
|
|
28
|
+
return { id: t.id, team_id: t.team_id, team: null };
|
|
29
|
+
}
|
|
30
|
+
}));
|
|
31
|
+
res.json({ members: enrichedMembers, teams: enrichedTeams });
|
|
32
|
+
};
|
|
33
|
+
//# sourceMappingURL=route.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../../../src/api/admin/projects/[id]/access/route.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,GAAG,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACnD,MAAM,oBAAoB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,4BAA4B,CAAQ,CAAA;IACnF,MAAM,WAAW,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,mBAAmB,CAAQ,CAAA;IACjE,MAAM,iBAAiB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,yBAAyB,CAAQ,CAAA;IAE7E,MAAM,OAAO,GAAG,MAAM,oBAAoB,CAAC,kBAAkB,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;IAC5E,MAAM,WAAW,GAAG,MAAM,oBAAoB,CAAC,kBAAkB,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;IAEhF,MAAM,eAAe,GAAG,MAAM,OAAO,CAAC,GAAG,CACvC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,CAAM,EAAE,EAAE;QAC3B,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC,CAAA;YACtD,OAAO;gBACL,EAAE,EAAE,CAAC,CAAC,EAAE;gBACR,OAAO,EAAE,CAAC,CAAC,OAAO;gBAClB,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,IAAI,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE;aACjG,CAAA;QACH,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,CAAA;QACnE,CAAC;IACH,CAAC,CAAC,CACH,CAAA;IAED,MAAM,aAAa,GAAG,MAAM,OAAO,CAAC,GAAG,CACrC,WAAW,CAAC,GAAG,CAAC,KAAK,EAAE,CAAM,EAAE,EAAE;QAC/B,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC,CAAA;YACtD,MAAM,SAAS,GAAG,MAAM,iBAAiB,CAAC,oBAAoB,CAAC,CAAC,CAAC,OAAO,CAAC,CAAA;YACzE,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,EAAE,GAAG,IAAI,EAAE,YAAY,EAAE,SAAS,CAAC,MAAM,EAAE,EAAE,CAAA;QAC5F,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,CAAA;QACrD,CAAC;IACH,CAAC,CAAC,CACH,CAAA;IAED,GAAG,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,eAAe,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC,CAAA;AAC9D,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../../../src/api/admin/projects/[id]/members/[userId]/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAEvC,eAAO,MAAM,MAAM,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAInD,CAAA"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export const DELETE = async (req, res) => {
|
|
2
|
+
const projectMemberService = req.scope.resolve("projectMemberModuleService");
|
|
3
|
+
await projectMemberService.removeProjectMember(req.params.id, req.params.userId);
|
|
4
|
+
res.status(204).send();
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=route.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../../../../src/api/admin/projects/[id]/members/[userId]/route.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACtD,MAAM,oBAAoB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,4BAA4B,CAAQ,CAAA;IACnF,MAAM,oBAAoB,CAAC,mBAAmB,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IAChF,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAA;AACxB,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../../src/api/admin/projects/[id]/members/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAEvC,eAAO,MAAM,IAAI,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAWjD,CAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export const POST = async (req, res) => {
|
|
2
|
+
const projectMemberService = req.scope.resolve("projectMemberModuleService");
|
|
3
|
+
const { user_id, role } = req.body;
|
|
4
|
+
if (!user_id) {
|
|
5
|
+
res.status(400).json({ error: { message: "user_id is required" } });
|
|
6
|
+
return;
|
|
7
|
+
}
|
|
8
|
+
await projectMemberService.ensureProjectMember(req.params.id, user_id, role ?? "member");
|
|
9
|
+
res.status(201).json({ ok: true });
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=route.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../../../src/api/admin/projects/[id]/members/route.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,IAAI,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACpD,MAAM,oBAAoB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,4BAA4B,CAAQ,CAAA;IACnF,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,GAAG,GAAG,CAAC,IAAI,CAAA;IAElC,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,qBAAqB,EAAE,EAAE,CAAC,CAAA;QACnE,OAAM;IACR,CAAC;IAED,MAAM,oBAAoB,CAAC,mBAAmB,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,IAAI,QAAQ,CAAC,CAAA;IACxF,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,CAAA;AACpC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../../../src/api/admin/projects/[id]/teams/[teamId]/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAEvC,eAAO,MAAM,MAAM,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAInD,CAAA"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export const DELETE = async (req, res) => {
|
|
2
|
+
const projectMemberService = req.scope.resolve("projectMemberModuleService");
|
|
3
|
+
await projectMemberService.removeProjectTeam(req.params.id, req.params.teamId);
|
|
4
|
+
res.status(204).send();
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=route.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../../../../src/api/admin/projects/[id]/teams/[teamId]/route.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACtD,MAAM,oBAAoB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,4BAA4B,CAAQ,CAAA;IACnF,MAAM,oBAAoB,CAAC,iBAAiB,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IAC9E,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAA;AACxB,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../../src/api/admin/projects/[id]/teams/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAEvC,eAAO,MAAM,IAAI,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAWjD,CAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export const POST = async (req, res) => {
|
|
2
|
+
const projectMemberService = req.scope.resolve("projectMemberModuleService");
|
|
3
|
+
const { team_id } = req.body;
|
|
4
|
+
if (!team_id) {
|
|
5
|
+
res.status(400).json({ error: { message: "team_id is required" } });
|
|
6
|
+
return;
|
|
7
|
+
}
|
|
8
|
+
await projectMemberService.ensureProjectTeam(req.params.id, team_id);
|
|
9
|
+
res.status(201).json({ ok: true });
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=route.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../../../src/api/admin/projects/[id]/teams/route.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,IAAI,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACpD,MAAM,oBAAoB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,4BAA4B,CAAQ,CAAA;IACnF,MAAM,EAAE,OAAO,EAAE,GAAG,GAAG,CAAC,IAAI,CAAA;IAE5B,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,qBAAqB,EAAE,EAAE,CAAC,CAAA;QACnE,OAAM;IACR,CAAC;IAED,MAAM,oBAAoB,CAAC,iBAAiB,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,CAAC,CAAA;IACpE,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,CAAA;AACpC,CAAC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../src/api/admin/projects/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAGvC,eAAO,MAAM,GAAG,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../src/api/admin/projects/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAGvC,eAAO,MAAM,GAAG,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAgDhD,CAAA;AAED,eAAO,MAAM,IAAI,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAyBjD,CAAA"}
|
|
@@ -8,10 +8,43 @@ export const GET = async (req, res) => {
|
|
|
8
8
|
filters.workspace_id = req.query.workspace_id;
|
|
9
9
|
if (req.query.status)
|
|
10
10
|
filters.status = req.query.status;
|
|
11
|
-
const
|
|
11
|
+
const roles = req.user?.roles ?? [];
|
|
12
|
+
const isPrivileged = roles.includes("super-admin") || roles.includes("admin");
|
|
13
|
+
if (isPrivileged) {
|
|
14
|
+
const [projects, count] = await projectService.listAndCountProjects(filters, { limit, offset });
|
|
15
|
+
res.json({ projects, count, limit, offset });
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
const workspaceMemberService = req.scope.resolve("workspaceMemberModuleService");
|
|
19
|
+
const teamMemberService = req.scope.resolve("teamMemberModuleService");
|
|
20
|
+
const projectMemberService = req.scope.resolve("projectMemberModuleService");
|
|
21
|
+
const userId = req.user?.id;
|
|
22
|
+
// Workspace admins see all projects in their workspace
|
|
23
|
+
if (filters.workspace_id) {
|
|
24
|
+
const membership = await workspaceMemberService.getMembership(filters.workspace_id, userId);
|
|
25
|
+
if (!membership) {
|
|
26
|
+
res.status(403).json({ error: { message: "Forbidden — not a member of this workspace" } });
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
if (membership.role === "admin") {
|
|
30
|
+
const [projects, count] = await projectService.listAndCountProjects(filters, { limit, offset });
|
|
31
|
+
res.json({ projects, count, limit, offset });
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
// Members: filter by explicit project access
|
|
36
|
+
const userTeamIds = await teamMemberService.getUserTeamIds(userId);
|
|
37
|
+
const accessibleProjectIds = await projectMemberService.getAccessibleProjectIds(userId, userTeamIds);
|
|
38
|
+
if (accessibleProjectIds.length === 0) {
|
|
39
|
+
res.json({ projects: [], count: 0, limit, offset });
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
const memberFilters = { ...filters, id: accessibleProjectIds };
|
|
43
|
+
const [projects, count] = await projectService.listAndCountProjects(memberFilters, { limit, offset });
|
|
12
44
|
res.json({ projects, count, limit, offset });
|
|
13
45
|
};
|
|
14
46
|
export const POST = async (req, res) => {
|
|
47
|
+
const projectMemberService = req.scope.resolve("projectMemberModuleService");
|
|
15
48
|
const { name, description, workspace_id, visibility, icon, color, identifier, initial_statuses } = req.body;
|
|
16
49
|
if (!name || !workspace_id) {
|
|
17
50
|
res.status(400).json({ error: { message: "name and workspace_id are required" } });
|
|
@@ -30,6 +63,10 @@ export const POST = async (req, res) => {
|
|
|
30
63
|
res.status(err.status ?? 500).json({ error: { message: err.message } });
|
|
31
64
|
return;
|
|
32
65
|
}
|
|
66
|
+
// Auto-create project membership for the creator (manager role)
|
|
67
|
+
if (req.user?.id && project) {
|
|
68
|
+
await projectMemberService.ensureProjectMember(project.id, req.user.id, "manager");
|
|
69
|
+
}
|
|
33
70
|
res.status(201).json({ project });
|
|
34
71
|
};
|
|
35
72
|
//# sourceMappingURL=route.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../src/api/admin/projects/route.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAA;AAE5E,MAAM,CAAC,MAAM,GAAG,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACnD,MAAM,cAAc,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,sBAAsB,CAAQ,CAAA;IACvE,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,GAAG,CAAC,CAAA;IAC1D,MAAM,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;IAC5C,MAAM,OAAO,GAA4B,EAAE,CAAA;IAC3C,IAAI,GAAG,CAAC,KAAK,CAAC,YAAY;QAAE,OAAO,CAAC,YAAY,GAAG,GAAG,CAAC,KAAK,CAAC,YAAY,CAAA;IACzE,IAAI,GAAG,CAAC,KAAK,CAAC,MAAM;QAAE,OAAO,CAAC,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,MAAM,CAAA;IACvD,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,GAAG,MAAM,cAAc,CAAC,oBAAoB,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAA;
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../src/api/admin/projects/route.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../../../src/api/admin/workspaces/[id]/invitations/[inviteId]/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAEvC,eAAO,MAAM,MAAM,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAInD,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../../../../src/api/admin/workspaces/[id]/invitations/[inviteId]/route.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACtD,MAAM,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,yBAAyB,CAAQ,CAAA;IAC/D,MAAM,GAAG,CAAC,gBAAgB,CAAC,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;IAC/C,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAA;AACxB,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../../src/api/admin/workspaces/[id]/invitations/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAGvC,eAAO,MAAM,GAAG,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAOhD,CAAA;AAED,eAAO,MAAM,IAAI,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAuBjD,CAAA"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { createInvitationWorkflow } from "../../../../../workflows/create-invitation.js";
|
|
2
|
+
export const GET = async (req, res) => {
|
|
3
|
+
const svc = req.scope.resolve("invitationModuleService");
|
|
4
|
+
const [invitations, count] = await svc.listAndCountInvitations({ workspace_id: req.params.id }, { limit: 100 });
|
|
5
|
+
res.json({ invitations, count });
|
|
6
|
+
};
|
|
7
|
+
export const POST = async (req, res) => {
|
|
8
|
+
const { email, role } = req.body;
|
|
9
|
+
if (!role || !["admin", "member"].includes(role)) {
|
|
10
|
+
res.status(400).json({ error: { message: "role must be 'admin' or 'member'" } });
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
const { result, errors, transaction_status } = await createInvitationWorkflow(req.scope).run({
|
|
14
|
+
input: {
|
|
15
|
+
workspace_id: req.params.id,
|
|
16
|
+
email: email?.trim() || null,
|
|
17
|
+
role,
|
|
18
|
+
created_by: req.user?.id ?? "system",
|
|
19
|
+
},
|
|
20
|
+
});
|
|
21
|
+
if (transaction_status === "reverted") {
|
|
22
|
+
res.status(500).json({ error: { message: errors[0]?.message ?? "Failed to create invitation" } });
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
res.status(201).json({ invitation: result });
|
|
26
|
+
};
|
|
27
|
+
//# sourceMappingURL=route.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../../../src/api/admin/workspaces/[id]/invitations/route.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,wBAAwB,EAAE,MAAM,+CAA+C,CAAA;AAExF,MAAM,CAAC,MAAM,GAAG,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACnD,MAAM,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,yBAAyB,CAAQ,CAAA;IAC/D,MAAM,CAAC,WAAW,EAAE,KAAK,CAAC,GAAG,MAAM,GAAG,CAAC,uBAAuB,CAC5D,EAAE,YAAY,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,EAC/B,EAAE,KAAK,EAAE,GAAG,EAAE,CACf,CAAA;IACD,GAAG,CAAC,IAAI,CAAC,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAA;AAClC,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,IAAI,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACpD,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,GAAG,CAAC,IAAI,CAAA;IAEhC,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;QACjD,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,kCAAkC,EAAE,EAAE,CAAC,CAAA;QAChF,OAAM;IACR,CAAC;IAED,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,kBAAkB,EAAE,GAAG,MAAM,wBAAwB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC;QAC3F,KAAK,EAAE;YACL,YAAY,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE;YAC3B,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,IAAI;YAC5B,IAAI;YACJ,UAAU,EAAE,GAAG,CAAC,IAAI,EAAE,EAAE,IAAI,QAAQ;SACrC;KACF,CAAC,CAAA;IAEF,IAAI,kBAAkB,KAAK,UAAU,EAAE,CAAC;QACtC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,OAAO,IAAI,6BAA6B,EAAE,EAAE,CAAC,CAAA;QACjG,OAAM;IACR,CAAC;IAED,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC,CAAA;AAC9C,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../../../src/api/admin/workspaces/[id]/members/[userId]/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAEvC,eAAO,MAAM,KAAK,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAiBlD,CAAA;AAED,eAAO,MAAM,MAAM,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAWnD,CAAA"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export const PATCH = async (req, res) => {
|
|
2
|
+
const workspaceMemberService = req.scope.resolve("workspaceMemberModuleService");
|
|
3
|
+
const { role } = req.body;
|
|
4
|
+
if (!role || !["admin", "member"].includes(role)) {
|
|
5
|
+
res.status(400).json({ error: { message: "role must be 'admin' or 'member'" } });
|
|
6
|
+
return;
|
|
7
|
+
}
|
|
8
|
+
const membership = await workspaceMemberService.getMembership(req.params.id, req.params.userId);
|
|
9
|
+
if (!membership) {
|
|
10
|
+
res.status(404).json({ error: { message: "Member not found" } });
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
const updated = await workspaceMemberService.updateWorkspaceMember(membership.id, { role });
|
|
14
|
+
res.json({ member: updated });
|
|
15
|
+
};
|
|
16
|
+
export const DELETE = async (req, res) => {
|
|
17
|
+
const workspaceMemberService = req.scope.resolve("workspaceMemberModuleService");
|
|
18
|
+
const membership = await workspaceMemberService.getMembership(req.params.id, req.params.userId);
|
|
19
|
+
if (!membership) {
|
|
20
|
+
res.status(404).json({ error: { message: "Member not found" } });
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
await workspaceMemberService.deleteWorkspaceMember(membership.id);
|
|
24
|
+
res.status(204).send();
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=route.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../../../../src/api/admin/workspaces/[id]/members/[userId]/route.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,KAAK,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACrD,MAAM,sBAAsB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,8BAA8B,CAAQ,CAAA;IACvF,MAAM,EAAE,IAAI,EAAE,GAAG,GAAG,CAAC,IAAI,CAAA;IAEzB,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;QACjD,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,kCAAkC,EAAE,EAAE,CAAC,CAAA;QAChF,OAAM;IACR,CAAC;IAED,MAAM,UAAU,GAAG,MAAM,sBAAsB,CAAC,aAAa,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IAC/F,IAAI,CAAC,UAAU,EAAE,CAAC;QAChB,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,kBAAkB,EAAE,EAAE,CAAC,CAAA;QAChE,OAAM;IACR,CAAC;IAED,MAAM,OAAO,GAAG,MAAM,sBAAsB,CAAC,qBAAqB,CAAC,UAAU,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,CAAA;IAC3F,GAAG,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,CAAA;AAC/B,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACtD,MAAM,sBAAsB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,8BAA8B,CAAQ,CAAA;IAEvF,MAAM,UAAU,GAAG,MAAM,sBAAsB,CAAC,aAAa,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IAC/F,IAAI,CAAC,UAAU,EAAE,CAAC;QAChB,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,kBAAkB,EAAE,EAAE,CAAC,CAAA;QAChE,OAAM;IACR,CAAC;IAED,MAAM,sBAAsB,CAAC,qBAAqB,CAAC,UAAU,CAAC,EAAE,CAAC,CAAA;IACjE,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAA;AACxB,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../../src/api/admin/workspaces/[id]/members/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAEvC,eAAO,MAAM,GAAG,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBA0BhD,CAAA;AAED,eAAO,MAAM,IAAI,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAsBjD,CAAA"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
export const GET = async (req, res) => {
|
|
2
|
+
const workspaceMemberService = req.scope.resolve("workspaceMemberModuleService");
|
|
3
|
+
const userService = req.scope.resolve("userModuleService");
|
|
4
|
+
const [members] = await workspaceMemberService.listAndCountWorkspaceMembers({ workspace_id: req.params.id }, { limit: 100 });
|
|
5
|
+
const enriched = await Promise.all(members.map(async (m) => {
|
|
6
|
+
try {
|
|
7
|
+
const user = await userService.retrieveUser(m.user_id);
|
|
8
|
+
return {
|
|
9
|
+
id: m.id,
|
|
10
|
+
user_id: m.user_id,
|
|
11
|
+
role: m.role,
|
|
12
|
+
user: { id: user.id, email: user.email, first_name: user.first_name, last_name: user.last_name },
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
catch {
|
|
16
|
+
return { id: m.id, user_id: m.user_id, role: m.role, user: null };
|
|
17
|
+
}
|
|
18
|
+
}));
|
|
19
|
+
res.json({ members: enriched, count: enriched.length });
|
|
20
|
+
};
|
|
21
|
+
export const POST = async (req, res) => {
|
|
22
|
+
const workspaceMemberService = req.scope.resolve("workspaceMemberModuleService");
|
|
23
|
+
const { user_id, role } = req.body;
|
|
24
|
+
if (!user_id) {
|
|
25
|
+
res.status(400).json({ error: { message: "user_id is required" } });
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
const existing = await workspaceMemberService.getMembership(req.params.id, user_id);
|
|
29
|
+
if (existing) {
|
|
30
|
+
res.status(409).json({ error: { message: "User is already a member of this workspace" } });
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
const member = await workspaceMemberService.createWorkspaceMember({
|
|
34
|
+
workspace_id: req.params.id,
|
|
35
|
+
user_id,
|
|
36
|
+
role: role ?? "member",
|
|
37
|
+
});
|
|
38
|
+
res.status(201).json({ member });
|
|
39
|
+
};
|
|
40
|
+
//# sourceMappingURL=route.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../../../src/api/admin/workspaces/[id]/members/route.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,GAAG,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACnD,MAAM,sBAAsB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,8BAA8B,CAAQ,CAAA;IACvF,MAAM,WAAW,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,mBAAmB,CAAQ,CAAA;IAEjE,MAAM,CAAC,OAAO,CAAC,GAAG,MAAM,sBAAsB,CAAC,4BAA4B,CACzE,EAAE,YAAY,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,EAC/B,EAAE,KAAK,EAAE,GAAG,EAAE,CACf,CAAA;IAED,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,GAAG,CAChC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,CAAM,EAAE,EAAE;QAC3B,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC,CAAA;YACtD,OAAO;gBACL,EAAE,EAAE,CAAC,CAAC,EAAE;gBACR,OAAO,EAAE,CAAC,CAAC,OAAO;gBAClB,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,IAAI,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE;aACjG,CAAA;QACH,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,CAAA;QACnE,CAAC;IACH,CAAC,CAAC,CACH,CAAA;IAED,GAAG,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAA;AACzD,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,IAAI,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACpD,MAAM,sBAAsB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,8BAA8B,CAAQ,CAAA;IACvF,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,GAAG,GAAG,CAAC,IAAI,CAAA;IAElC,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,qBAAqB,EAAE,EAAE,CAAC,CAAA;QACnE,OAAM;IACR,CAAC;IAED,MAAM,QAAQ,GAAG,MAAM,sBAAsB,CAAC,aAAa,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,CAAC,CAAA;IACnF,IAAI,QAAQ,EAAE,CAAC;QACb,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,4CAA4C,EAAE,EAAE,CAAC,CAAA;QAC1F,OAAM;IACR,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,sBAAsB,CAAC,qBAAqB,CAAC;QAChE,YAAY,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE;QAC3B,OAAO;QACP,IAAI,EAAE,IAAI,IAAI,QAAQ;KACvB,CAAC,CAAA;IAEF,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,CAAA;AAClC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../../../../../src/api/admin/workspaces/[id]/teams/[teamId]/members/[userId]/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAEvC,eAAO,MAAM,MAAM,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAInD,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../../../../../../src/api/admin/workspaces/[id]/teams/[teamId]/members/[userId]/route.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACtD,MAAM,iBAAiB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,yBAAyB,CAAQ,CAAA;IAC7E,MAAM,iBAAiB,CAAC,mBAAmB,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IACjF,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAA;AACxB,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../../../../src/api/admin/workspaces/[id]/teams/[teamId]/members/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAEvC,eAAO,MAAM,GAAG,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAyBhD,CAAA;AAED,eAAO,MAAM,IAAI,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAoBjD,CAAA"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
export const GET = async (req, res) => {
|
|
2
|
+
const teamMemberService = req.scope.resolve("teamMemberModuleService");
|
|
3
|
+
const userService = req.scope.resolve("userModuleService");
|
|
4
|
+
const [members] = await teamMemberService.listAndCountTeamMembers({ team_id: req.params.teamId }, { limit: 100 });
|
|
5
|
+
const enriched = await Promise.all(members.map(async (m) => {
|
|
6
|
+
try {
|
|
7
|
+
const user = await userService.retrieveUser(m.user_id);
|
|
8
|
+
return {
|
|
9
|
+
id: m.id,
|
|
10
|
+
user_id: m.user_id,
|
|
11
|
+
user: { id: user.id, email: user.email, first_name: user.first_name, last_name: user.last_name },
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
catch {
|
|
15
|
+
return { id: m.id, user_id: m.user_id, user: null };
|
|
16
|
+
}
|
|
17
|
+
}));
|
|
18
|
+
res.json({ members: enriched, count: enriched.length });
|
|
19
|
+
};
|
|
20
|
+
export const POST = async (req, res) => {
|
|
21
|
+
const teamMemberService = req.scope.resolve("teamMemberModuleService");
|
|
22
|
+
const { user_id } = req.body;
|
|
23
|
+
if (!user_id) {
|
|
24
|
+
res.status(400).json({ error: { message: "user_id is required" } });
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
if (await teamMemberService.isMember(req.params.teamId, user_id)) {
|
|
28
|
+
res.status(409).json({ error: { message: "User is already a member of this team" } });
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
const member = await teamMemberService.createTeamMember({
|
|
32
|
+
team_id: req.params.teamId,
|
|
33
|
+
user_id,
|
|
34
|
+
});
|
|
35
|
+
res.status(201).json({ member });
|
|
36
|
+
};
|
|
37
|
+
//# sourceMappingURL=route.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../../../../../src/api/admin/workspaces/[id]/teams/[teamId]/members/route.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,GAAG,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACnD,MAAM,iBAAiB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,yBAAyB,CAAQ,CAAA;IAC7E,MAAM,WAAW,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,mBAAmB,CAAQ,CAAA;IAEjE,MAAM,CAAC,OAAO,CAAC,GAAG,MAAM,iBAAiB,CAAC,uBAAuB,CAC/D,EAAE,OAAO,EAAE,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,EAC9B,EAAE,KAAK,EAAE,GAAG,EAAE,CACf,CAAA;IAED,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,GAAG,CAChC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,CAAM,EAAE,EAAE;QAC3B,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC,CAAA;YACtD,OAAO;gBACL,EAAE,EAAE,CAAC,CAAC,EAAE;gBACR,OAAO,EAAE,CAAC,CAAC,OAAO;gBAClB,IAAI,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE;aACjG,CAAA;QACH,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,CAAA;QACrD,CAAC;IACH,CAAC,CAAC,CACH,CAAA;IAED,GAAG,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAA;AACzD,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,IAAI,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACpD,MAAM,iBAAiB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,yBAAyB,CAAQ,CAAA;IAC7E,MAAM,EAAE,OAAO,EAAE,GAAG,GAAG,CAAC,IAAI,CAAA;IAE5B,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,qBAAqB,EAAE,EAAE,CAAC,CAAA;QACnE,OAAM;IACR,CAAC;IAED,IAAI,MAAM,iBAAiB,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;QACjE,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,uCAAuC,EAAE,EAAE,CAAC,CAAA;QACrF,OAAM;IACR,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,iBAAiB,CAAC,gBAAgB,CAAC;QACtD,OAAO,EAAE,GAAG,CAAC,MAAM,CAAC,MAAM;QAC1B,OAAO;KACR,CAAC,CAAA;IAEF,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,CAAA;AAClC,CAAC,CAAA"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { Response } from "express";
|
|
2
|
+
export declare const GET: (req: any, res: Response) => Promise<void>;
|
|
3
|
+
export declare const PUT: (req: any, res: Response) => Promise<void>;
|
|
4
|
+
export declare const DELETE: (req: any, res: Response) => Promise<void>;
|
|
5
|
+
//# sourceMappingURL=route.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../../../src/api/admin/workspaces/[id]/teams/[teamId]/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAEvC,eAAO,MAAM,GAAG,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAIhD,CAAA;AAED,eAAO,MAAM,GAAG,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAUhD,CAAA;AAED,eAAO,MAAM,MAAM,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAOnD,CAAA"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export const GET = async (req, res) => {
|
|
2
|
+
const userService = req.scope.resolve("userModuleService");
|
|
3
|
+
const team = await userService.retrieveTeam(req.params.teamId);
|
|
4
|
+
res.json({ team });
|
|
5
|
+
};
|
|
6
|
+
export const PUT = async (req, res) => {
|
|
7
|
+
const userService = req.scope.resolve("userModuleService");
|
|
8
|
+
const { name, description, icon } = req.body;
|
|
9
|
+
const updates = {};
|
|
10
|
+
if (name !== undefined)
|
|
11
|
+
updates.name = name.trim();
|
|
12
|
+
if (description !== undefined)
|
|
13
|
+
updates.description = description;
|
|
14
|
+
if (icon !== undefined)
|
|
15
|
+
updates.icon = icon;
|
|
16
|
+
const team = await userService.updateTeam(req.params.teamId, updates);
|
|
17
|
+
res.json({ team });
|
|
18
|
+
};
|
|
19
|
+
export const DELETE = async (req, res) => {
|
|
20
|
+
const userService = req.scope.resolve("userModuleService");
|
|
21
|
+
const teamMemberService = req.scope.resolve("teamMemberModuleService");
|
|
22
|
+
await teamMemberService.deleteAllForTeam(req.params.teamId);
|
|
23
|
+
await userService.deleteTeam(req.params.teamId);
|
|
24
|
+
res.status(204).send();
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=route.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../../../../src/api/admin/workspaces/[id]/teams/[teamId]/route.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,GAAG,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACnD,MAAM,WAAW,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,mBAAmB,CAAQ,CAAA;IACjE,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IAC9D,GAAG,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,CAAA;AACpB,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,GAAG,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACnD,MAAM,WAAW,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,mBAAmB,CAAQ,CAAA;IACjE,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,GAAG,GAAG,CAAC,IAAI,CAAA;IAC5C,MAAM,OAAO,GAA4B,EAAE,CAAA;IAC3C,IAAI,IAAI,KAAK,SAAS;QAAE,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,CAAA;IAClD,IAAI,WAAW,KAAK,SAAS;QAAE,OAAO,CAAC,WAAW,GAAG,WAAW,CAAA;IAChE,IAAI,IAAI,KAAK,SAAS;QAAE,OAAO,CAAC,IAAI,GAAG,IAAI,CAAA;IAE3C,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IACrE,GAAG,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,CAAA;AACpB,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACtD,MAAM,WAAW,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,mBAAmB,CAAQ,CAAA;IACjE,MAAM,iBAAiB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,yBAAyB,CAAQ,CAAA;IAE7E,MAAM,iBAAiB,CAAC,gBAAgB,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IAC3D,MAAM,WAAW,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IAC/C,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAA;AACxB,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../../src/api/admin/workspaces/[id]/teams/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAEvC,eAAO,MAAM,GAAG,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAiBhD,CAAA;AAED,eAAO,MAAM,IAAI,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAiBjD,CAAA"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export const GET = async (req, res) => {
|
|
2
|
+
const userService = req.scope.resolve("userModuleService");
|
|
3
|
+
const teamMemberService = req.scope.resolve("teamMemberModuleService");
|
|
4
|
+
const [teams] = await userService.listAndCountTeams({ workspace_id: req.params.id }, { limit: 100 });
|
|
5
|
+
const enriched = await Promise.all(teams.map(async (t) => {
|
|
6
|
+
const memberIds = await teamMemberService.getTeamMemberUserIds(t.id);
|
|
7
|
+
return { ...t, member_count: memberIds.length };
|
|
8
|
+
}));
|
|
9
|
+
res.json({ teams: enriched, count: enriched.length });
|
|
10
|
+
};
|
|
11
|
+
export const POST = async (req, res) => {
|
|
12
|
+
const userService = req.scope.resolve("userModuleService");
|
|
13
|
+
const { name, description, icon } = req.body;
|
|
14
|
+
if (!name || typeof name !== "string" || name.trim().length === 0) {
|
|
15
|
+
res.status(400).json({ error: { message: "name is required" } });
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
const team = await userService.createTeam({
|
|
19
|
+
workspace_id: req.params.id,
|
|
20
|
+
name: name.trim(),
|
|
21
|
+
description: description ?? null,
|
|
22
|
+
icon: icon ?? null,
|
|
23
|
+
});
|
|
24
|
+
res.status(201).json({ team });
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=route.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../../../src/api/admin/workspaces/[id]/teams/route.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,GAAG,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACnD,MAAM,WAAW,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,mBAAmB,CAAQ,CAAA;IACjE,MAAM,iBAAiB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,yBAAyB,CAAQ,CAAA;IAE7E,MAAM,CAAC,KAAK,CAAC,GAAG,MAAM,WAAW,CAAC,iBAAiB,CACjD,EAAE,YAAY,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,EAC/B,EAAE,KAAK,EAAE,GAAG,EAAE,CACf,CAAA;IAED,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,GAAG,CAChC,KAAK,CAAC,GAAG,CAAC,KAAK,EAAE,CAAM,EAAE,EAAE;QACzB,MAAM,SAAS,GAAG,MAAM,iBAAiB,CAAC,oBAAoB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;QACpE,OAAO,EAAE,GAAG,CAAC,EAAE,YAAY,EAAE,SAAS,CAAC,MAAM,EAAE,CAAA;IACjD,CAAC,CAAC,CACH,CAAA;IAED,GAAG,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,IAAI,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACpD,MAAM,WAAW,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,mBAAmB,CAAQ,CAAA;IACjE,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,GAAG,GAAG,CAAC,IAAI,CAAA;IAE5C,IAAI,CAAC,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAClE,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,kBAAkB,EAAE,EAAE,CAAC,CAAA;QAChE,OAAM;IACR,CAAC;IAED,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC,UAAU,CAAC;QACxC,YAAY,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE;QAC3B,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE;QACjB,WAAW,EAAE,WAAW,IAAI,IAAI;QAChC,IAAI,EAAE,IAAI,IAAI,IAAI;KACnB,CAAC,CAAA;IAEF,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,CAAA;AAChC,CAAC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../src/api/admin/workspaces/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAEvC,eAAO,MAAM,GAAG,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../src/api/admin/workspaces/route.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAEvC,eAAO,MAAM,GAAG,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBA4BhD,CAAA;AAED,eAAO,MAAM,IAAI,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBAuBjD,CAAA"}
|
|
@@ -2,18 +2,41 @@ export const GET = async (req, res) => {
|
|
|
2
2
|
const workspaceService = req.scope.resolve("workspaceModuleService");
|
|
3
3
|
const limit = Math.min(Number(req.query.limit) || 20, 100);
|
|
4
4
|
const offset = Number(req.query.offset) || 0;
|
|
5
|
-
const
|
|
5
|
+
const roles = req.user?.roles ?? [];
|
|
6
|
+
const isPrivileged = roles.includes("super-admin") || roles.includes("admin");
|
|
7
|
+
if (isPrivileged) {
|
|
8
|
+
const [workspaces, count] = await workspaceService.listAndCountWorkspaces({}, { limit, offset });
|
|
9
|
+
res.json({ workspaces, count, limit, offset });
|
|
10
|
+
return;
|
|
11
|
+
}
|
|
12
|
+
// Members: filter to workspaces they belong to
|
|
13
|
+
const workspaceMemberService = req.scope.resolve("workspaceMemberModuleService");
|
|
14
|
+
const workspaceIds = await workspaceMemberService.getWorkspaceIdsForUser(req.user.id);
|
|
15
|
+
if (workspaceIds.length === 0) {
|
|
16
|
+
res.json({ workspaces: [], count: 0, limit, offset });
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
const [workspaces, count] = await workspaceService.listAndCountWorkspaces({ id: workspaceIds }, { limit, offset });
|
|
6
20
|
res.json({ workspaces, count, limit, offset });
|
|
7
21
|
};
|
|
8
22
|
export const POST = async (req, res) => {
|
|
9
23
|
const workspaceService = req.scope.resolve("workspaceModuleService");
|
|
24
|
+
const workspaceMemberService = req.scope.resolve("workspaceMemberModuleService");
|
|
10
25
|
const { name, plan } = req.body;
|
|
11
26
|
if (!name || typeof name !== "string" || name.trim().length === 0) {
|
|
12
27
|
res.status(400).json({ error: { message: "name is required" } });
|
|
13
28
|
return;
|
|
14
29
|
}
|
|
15
30
|
const slug = workspaceService.generateSlug(name.trim());
|
|
16
|
-
const workspace = await workspaceService.createWorkspace({
|
|
31
|
+
const workspace = await workspaceService.createWorkspace({
|
|
32
|
+
name: name.trim(),
|
|
33
|
+
slug,
|
|
34
|
+
plan: plan ?? "free",
|
|
35
|
+
});
|
|
36
|
+
// Auto-create workspace membership for the creator (admin role)
|
|
37
|
+
if (req.user?.id) {
|
|
38
|
+
await workspaceMemberService.ensureMember(workspace.id, req.user.id, "admin");
|
|
39
|
+
}
|
|
17
40
|
res.status(201).json({ workspace });
|
|
18
41
|
};
|
|
19
42
|
//# sourceMappingURL=route.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../src/api/admin/workspaces/route.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,GAAG,GAAG,KAAK,EAAE,GAAQ,EAAE,GAAa,EAAE,EAAE;IACnD,MAAM,gBAAgB,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,wBAAwB,CAAQ,CAAA;IAC3E,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,GAAG,CAAC,CAAA;IAC1D,MAAM,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../src/api/admin/workspaces/route.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Response } from "express";
|
|
2
|
+
/** Public endpoint — no auth middleware. Returns invitation + workspace name for the accept page. */
|
|
3
|
+
export declare const GET: (req: any, res: Response) => Promise<void>;
|
|
4
|
+
/**
|
|
5
|
+
* POST /auth/invite/:token
|
|
6
|
+
* Public — registers a new user via an invite link.
|
|
7
|
+
*/
|
|
8
|
+
export declare const POST: (req: any, res: Response) => Promise<void>;
|
|
9
|
+
//# sourceMappingURL=route.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../src/api/auth/invite/[token]/route.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAEvC,qGAAqG;AACrG,eAAO,MAAM,GAAG,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBA+BhD,CAAA;AASD;;;GAGG;AACH,eAAO,MAAM,IAAI,GAAU,KAAK,GAAG,EAAE,KAAK,QAAQ,kBA8CjD,CAAA"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
/** Public endpoint — no auth middleware. Returns invitation + workspace name for the accept page. */
|
|
3
|
+
export const GET = async (req, res) => {
|
|
4
|
+
const invitationService = req.scope.resolve("invitationModuleService");
|
|
5
|
+
const workspaceService = req.scope.resolve("workspaceModuleService");
|
|
6
|
+
const [invitations] = await invitationService.listAndCountInvitations({ token: req.params.token }, { limit: 1 });
|
|
7
|
+
const invitation = invitations[0];
|
|
8
|
+
if (!invitation) {
|
|
9
|
+
res.status(404).json({ error: { message: "Invitation not found" } });
|
|
10
|
+
return;
|
|
11
|
+
}
|
|
12
|
+
if (invitation.status !== "pending") {
|
|
13
|
+
res.status(410).json({ error: { message: `Invitation has been ${invitation.status}` } });
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
const workspace = await workspaceService.retrieveWorkspace(invitation.workspace_id);
|
|
17
|
+
res.json({
|
|
18
|
+
invitation: {
|
|
19
|
+
id: invitation.id,
|
|
20
|
+
role: invitation.role,
|
|
21
|
+
email: invitation.email,
|
|
22
|
+
status: invitation.status,
|
|
23
|
+
},
|
|
24
|
+
workspace: { id: workspace.id, name: workspace.name, slug: workspace.slug },
|
|
25
|
+
});
|
|
26
|
+
};
|
|
27
|
+
const acceptSchema = z.object({
|
|
28
|
+
email: z.string().email(),
|
|
29
|
+
password: z.string().min(8, "Password must be at least 8 characters"),
|
|
30
|
+
first_name: z.string().min(1, "First name is required"),
|
|
31
|
+
last_name: z.string().min(1, "Last name is required"),
|
|
32
|
+
});
|
|
33
|
+
/**
|
|
34
|
+
* POST /auth/invite/:token
|
|
35
|
+
* Public — registers a new user via an invite link.
|
|
36
|
+
*/
|
|
37
|
+
export const POST = async (req, res) => {
|
|
38
|
+
const invitationService = req.scope.resolve("invitationModuleService");
|
|
39
|
+
const authService = req.scope.resolve("authModuleService");
|
|
40
|
+
const workspaceMemberService = req.scope.resolve("workspaceMemberModuleService");
|
|
41
|
+
const [invitations] = await invitationService.listAndCountInvitations({ token: req.params.token }, { limit: 1 });
|
|
42
|
+
const invitation = invitations[0];
|
|
43
|
+
if (!invitation) {
|
|
44
|
+
res.status(404).json({ error: { message: "Invitation not found" } });
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
if (invitation.status !== "pending") {
|
|
48
|
+
res.status(410).json({ error: { message: `Invitation has already been ${invitation.status}` } });
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
const parsed = acceptSchema.safeParse(req.body);
|
|
52
|
+
if (!parsed.success) {
|
|
53
|
+
res.status(400).json({ error: { message: "Validation error", details: parsed.error.flatten().fieldErrors } });
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
if (invitation.email && invitation.email.toLowerCase() !== parsed.data.email.toLowerCase()) {
|
|
57
|
+
res.status(422).json({
|
|
58
|
+
error: { message: `This invitation was sent to ${invitation.email}. Please use that email address.` },
|
|
59
|
+
});
|
|
60
|
+
return;
|
|
61
|
+
}
|
|
62
|
+
const authResult = await authService.register({
|
|
63
|
+
email: parsed.data.email,
|
|
64
|
+
password: parsed.data.password,
|
|
65
|
+
first_name: parsed.data.first_name,
|
|
66
|
+
last_name: parsed.data.last_name,
|
|
67
|
+
role: invitation.role,
|
|
68
|
+
});
|
|
69
|
+
await workspaceMemberService.ensureMember(invitation.workspace_id, authResult.user.id, invitation.role);
|
|
70
|
+
await invitationService.updateInvitation(invitation.id, { status: "accepted" });
|
|
71
|
+
res.status(201).json(authResult);
|
|
72
|
+
};
|
|
73
|
+
//# sourceMappingURL=route.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route.js","sourceRoot":"","sources":["../../../../../src/api/auth/invite/[token]/route.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export interface CreateInvitationInput {
|
|
2
|
+
workspace_id: string;
|
|
3
|
+
email?: string | null;
|
|
4
|
+
role: "admin" | "member";
|
|
5
|
+
created_by: string;
|
|
6
|
+
}
|
|
7
|
+
export declare const createInvitationWorkflow: (container: import("@meridianjs/types").MeridianContainer) => import("@meridianjs/workflow-engine").WorkflowRunner<CreateInvitationInput, any>;
|
|
8
|
+
//# sourceMappingURL=create-invitation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-invitation.d.ts","sourceRoot":"","sources":["../../src/workflows/create-invitation.ts"],"names":[],"mappings":"AAQA,MAAM,WAAW,qBAAqB;IACpC,YAAY,EAAE,MAAM,CAAA;IACpB,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACrB,IAAI,EAAE,OAAO,GAAG,QAAQ,CAAA;IACxB,UAAU,EAAE,MAAM,CAAA;CACnB;AAoBD,eAAO,MAAM,wBAAwB,gJAmBpC,CAAA"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { createStep, createWorkflow, StepResponse, WorkflowResponse, } from "@meridianjs/workflow-engine";
|
|
2
|
+
import { emitEventStep } from "./emit-event.js";
|
|
3
|
+
const createInvitationStep = createStep("create-invitation", async (input, { container }) => {
|
|
4
|
+
const svc = container.resolve("invitationModuleService");
|
|
5
|
+
const invitation = await svc.createInvitationWithToken({
|
|
6
|
+
workspace_id: input.workspace_id,
|
|
7
|
+
email: input.email ?? null,
|
|
8
|
+
role: input.role,
|
|
9
|
+
created_by: input.created_by,
|
|
10
|
+
});
|
|
11
|
+
return new StepResponse(invitation, { invitationId: invitation.id });
|
|
12
|
+
}, async ({ invitationId }, { container }) => {
|
|
13
|
+
const svc = container.resolve("invitationModuleService");
|
|
14
|
+
await svc.deleteInvitation(invitationId);
|
|
15
|
+
});
|
|
16
|
+
export const createInvitationWorkflow = createWorkflow("create-invitation", async (input) => {
|
|
17
|
+
const invitation = await createInvitationStep(input);
|
|
18
|
+
await emitEventStep({
|
|
19
|
+
name: "workspace.member_invited",
|
|
20
|
+
data: {
|
|
21
|
+
invitation_id: invitation.id,
|
|
22
|
+
workspace_id: invitation.workspace_id,
|
|
23
|
+
email: invitation.email,
|
|
24
|
+
role: invitation.role,
|
|
25
|
+
token: invitation.token,
|
|
26
|
+
created_by: input.created_by,
|
|
27
|
+
},
|
|
28
|
+
});
|
|
29
|
+
return new WorkflowResponse(invitation);
|
|
30
|
+
});
|
|
31
|
+
//# sourceMappingURL=create-invitation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-invitation.js","sourceRoot":"","sources":["../../src/workflows/create-invitation.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,UAAU,EACV,cAAc,EACd,YAAY,EACZ,gBAAgB,GACjB,MAAM,6BAA6B,CAAA;AACpC,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAS/C,MAAM,oBAAoB,GAAG,UAAU,CACrC,mBAAmB,EACnB,KAAK,EAAE,KAA4B,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;IACpD,MAAM,GAAG,GAAG,SAAS,CAAC,OAAO,CAAC,yBAAyB,CAAQ,CAAA;IAC/D,MAAM,UAAU,GAAG,MAAM,GAAG,CAAC,yBAAyB,CAAC;QACrD,YAAY,EAAE,KAAK,CAAC,YAAY;QAChC,KAAK,EAAE,KAAK,CAAC,KAAK,IAAI,IAAI;QAC1B,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,UAAU,EAAE,KAAK,CAAC,UAAU;KAC7B,CAAC,CAAA;IACF,OAAO,IAAI,YAAY,CAAC,UAAU,EAAE,EAAE,YAAY,EAAE,UAAU,CAAC,EAAE,EAAE,CAAC,CAAA;AACtE,CAAC,EACD,KAAK,EAAE,EAAE,YAAY,EAA4B,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;IAClE,MAAM,GAAG,GAAG,SAAS,CAAC,OAAO,CAAC,yBAAyB,CAAQ,CAAA;IAC/D,MAAM,GAAG,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAA;AAC1C,CAAC,CACF,CAAA;AAED,MAAM,CAAC,MAAM,wBAAwB,GAAG,cAAc,CACpD,mBAAmB,EACnB,KAAK,EAAE,KAA4B,EAAE,EAAE;IACrC,MAAM,UAAU,GAAG,MAAM,oBAAoB,CAAC,KAAK,CAAC,CAAA;IAEpD,MAAM,aAAa,CAAC;QAClB,IAAI,EAAE,0BAA0B;QAChC,IAAI,EAAE;YACJ,aAAa,EAAE,UAAU,CAAC,EAAE;YAC5B,YAAY,EAAE,UAAU,CAAC,YAAY;YACrC,KAAK,EAAE,UAAU,CAAC,KAAK;YACvB,IAAI,EAAE,UAAU,CAAC,IAAI;YACrB,KAAK,EAAE,UAAU,CAAC,KAAK;YACvB,UAAU,EAAE,KAAK,CAAC,UAAU;SAC7B;KACF,CAAC,CAAA;IAEF,OAAO,IAAI,gBAAgB,CAAC,UAAU,CAAC,CAAA;AACzC,CAAC,CACF,CAAA"}
|
package/package.json
CHANGED