cloudisk 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.env.example +17 -0
- package/README.md +120 -0
- package/dist/config/index.d.ts +27 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +45 -0
- package/dist/config/index.js.map +1 -0
- package/dist/dto/auth.dto.d.ts +14 -0
- package/dist/dto/auth.dto.d.ts.map +1 -0
- package/dist/dto/auth.dto.js +16 -0
- package/dist/dto/auth.dto.js.map +1 -0
- package/dist/dto/user.dto.d.ts +76 -0
- package/dist/dto/user.dto.d.ts.map +1 -0
- package/dist/dto/user.dto.js +70 -0
- package/dist/dto/user.dto.js.map +1 -0
- package/dist/handlers/auth.handler.d.ts +10 -0
- package/dist/handlers/auth.handler.d.ts.map +1 -0
- package/dist/handlers/auth.handler.js +41 -0
- package/dist/handlers/auth.handler.js.map +1 -0
- package/dist/handlers/disk.handler.d.ts +12 -0
- package/dist/handlers/disk.handler.d.ts.map +1 -0
- package/dist/handlers/disk.handler.js +61 -0
- package/dist/handlers/disk.handler.js.map +1 -0
- package/dist/handlers/samba.handler.d.ts +16 -0
- package/dist/handlers/samba.handler.d.ts.map +1 -0
- package/dist/handlers/samba.handler.js +120 -0
- package/dist/handlers/samba.handler.js.map +1 -0
- package/dist/handlers/share.handler.d.ts +11 -0
- package/dist/handlers/share.handler.d.ts.map +1 -0
- package/dist/handlers/share.handler.js +52 -0
- package/dist/handlers/share.handler.js.map +1 -0
- package/dist/handlers/system.handler.d.ts +17 -0
- package/dist/handlers/system.handler.d.ts.map +1 -0
- package/dist/handlers/system.handler.js +210 -0
- package/dist/handlers/system.handler.js.map +1 -0
- package/dist/handlers/user.handler.d.ts +16 -0
- package/dist/handlers/user.handler.d.ts.map +1 -0
- package/dist/handlers/user.handler.js +101 -0
- package/dist/handlers/user.handler.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +799 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/errors.d.ts +13 -0
- package/dist/lib/errors.d.ts.map +1 -0
- package/dist/lib/errors.js +35 -0
- package/dist/lib/errors.js.map +1 -0
- package/dist/lib/log-buffer.d.ts +20 -0
- package/dist/lib/log-buffer.d.ts.map +1 -0
- package/dist/lib/log-buffer.js +75 -0
- package/dist/lib/log-buffer.js.map +1 -0
- package/dist/lib/response.d.ts +5 -0
- package/dist/lib/response.d.ts.map +1 -0
- package/dist/lib/response.js +19 -0
- package/dist/lib/response.js.map +1 -0
- package/dist/lib/shell.d.ts +9 -0
- package/dist/lib/shell.d.ts.map +1 -0
- package/dist/lib/shell.js +32 -0
- package/dist/lib/shell.js.map +1 -0
- package/dist/middleware/auth.d.ts +17 -0
- package/dist/middleware/auth.d.ts.map +1 -0
- package/dist/middleware/auth.js +43 -0
- package/dist/middleware/auth.js.map +1 -0
- package/dist/middleware/error-handler.d.ts +3 -0
- package/dist/middleware/error-handler.d.ts.map +1 -0
- package/dist/middleware/error-handler.js +14 -0
- package/dist/middleware/error-handler.js.map +1 -0
- package/dist/middleware/logger.d.ts +3 -0
- package/dist/middleware/logger.d.ts.map +1 -0
- package/dist/middleware/logger.js +25 -0
- package/dist/middleware/logger.js.map +1 -0
- package/dist/middleware/validate.d.ts +3 -0
- package/dist/middleware/validate.d.ts.map +1 -0
- package/dist/middleware/validate.js +28 -0
- package/dist/middleware/validate.js.map +1 -0
- package/dist/operators/disk.operator.d.ts +29 -0
- package/dist/operators/disk.operator.d.ts.map +1 -0
- package/dist/operators/disk.operator.js +70 -0
- package/dist/operators/disk.operator.js.map +1 -0
- package/dist/operators/linux-user.operator.d.ts +13 -0
- package/dist/operators/linux-user.operator.d.ts.map +1 -0
- package/dist/operators/linux-user.operator.js +47 -0
- package/dist/operators/linux-user.operator.js.map +1 -0
- package/dist/operators/quota.operator.d.ts +18 -0
- package/dist/operators/quota.operator.d.ts.map +1 -0
- package/dist/operators/quota.operator.js +54 -0
- package/dist/operators/quota.operator.js.map +1 -0
- package/dist/operators/samba.operator.d.ts +41 -0
- package/dist/operators/samba.operator.d.ts.map +1 -0
- package/dist/operators/samba.operator.js +274 -0
- package/dist/operators/samba.operator.js.map +1 -0
- package/dist/operators/share.operator.d.ts +21 -0
- package/dist/operators/share.operator.d.ts.map +1 -0
- package/dist/operators/share.operator.js +67 -0
- package/dist/operators/share.operator.js.map +1 -0
- package/dist/repositories/admin.repo.d.ts +30 -0
- package/dist/repositories/admin.repo.d.ts.map +1 -0
- package/dist/repositories/admin.repo.js +20 -0
- package/dist/repositories/admin.repo.js.map +1 -0
- package/dist/repositories/user.repo.d.ts +44 -0
- package/dist/repositories/user.repo.d.ts.map +1 -0
- package/dist/repositories/user.repo.js +3 -0
- package/dist/repositories/user.repo.js.map +1 -0
- package/dist/repositories/user.repo.sqlite.d.ts +16 -0
- package/dist/repositories/user.repo.sqlite.d.ts.map +1 -0
- package/dist/repositories/user.repo.sqlite.js +47 -0
- package/dist/repositories/user.repo.sqlite.js.map +1 -0
- package/dist/routes/auth.routes.d.ts +4 -0
- package/dist/routes/auth.routes.d.ts.map +1 -0
- package/dist/routes/auth.routes.js +15 -0
- package/dist/routes/auth.routes.js.map +1 -0
- package/dist/routes/disk.routes.d.ts +4 -0
- package/dist/routes/disk.routes.d.ts.map +1 -0
- package/dist/routes/disk.routes.js +16 -0
- package/dist/routes/disk.routes.js.map +1 -0
- package/dist/routes/index.d.ts +4 -0
- package/dist/routes/index.d.ts.map +1 -0
- package/dist/routes/index.js +64 -0
- package/dist/routes/index.js.map +1 -0
- package/dist/routes/samba.routes.d.ts +4 -0
- package/dist/routes/samba.routes.d.ts.map +1 -0
- package/dist/routes/samba.routes.js +20 -0
- package/dist/routes/samba.routes.js.map +1 -0
- package/dist/routes/share.routes.d.ts +4 -0
- package/dist/routes/share.routes.d.ts.map +1 -0
- package/dist/routes/share.routes.js +15 -0
- package/dist/routes/share.routes.js.map +1 -0
- package/dist/routes/system.routes.d.ts +4 -0
- package/dist/routes/system.routes.d.ts.map +1 -0
- package/dist/routes/system.routes.js +20 -0
- package/dist/routes/system.routes.js.map +1 -0
- package/dist/routes/user.routes.d.ts +5 -0
- package/dist/routes/user.routes.d.ts.map +1 -0
- package/dist/routes/user.routes.js +44 -0
- package/dist/routes/user.routes.js.map +1 -0
- package/dist/services/auth.service.d.ts +23 -0
- package/dist/services/auth.service.d.ts.map +1 -0
- package/dist/services/auth.service.js +62 -0
- package/dist/services/auth.service.js.map +1 -0
- package/dist/services/disk.service.d.ts +12 -0
- package/dist/services/disk.service.d.ts.map +1 -0
- package/dist/services/disk.service.js +34 -0
- package/dist/services/disk.service.js.map +1 -0
- package/dist/services/init.service.d.ts +8 -0
- package/dist/services/init.service.d.ts.map +1 -0
- package/dist/services/init.service.js +47 -0
- package/dist/services/init.service.js.map +1 -0
- package/dist/services/quota.service.d.ts +14 -0
- package/dist/services/quota.service.d.ts.map +1 -0
- package/dist/services/quota.service.js +32 -0
- package/dist/services/quota.service.js.map +1 -0
- package/dist/services/samba.service.d.ts +45 -0
- package/dist/services/samba.service.d.ts.map +1 -0
- package/dist/services/samba.service.js +61 -0
- package/dist/services/samba.service.js.map +1 -0
- package/dist/services/share.service.d.ts +18 -0
- package/dist/services/share.service.d.ts.map +1 -0
- package/dist/services/share.service.js +29 -0
- package/dist/services/share.service.js.map +1 -0
- package/dist/services/user.service.d.ts +48 -0
- package/dist/services/user.service.d.ts.map +1 -0
- package/dist/services/user.service.js +196 -0
- package/dist/services/user.service.js.map +1 -0
- package/dist/types/index.d.ts +7 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +23 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/service.interfaces.d.ts +45 -0
- package/dist/types/service.interfaces.d.ts.map +1 -0
- package/dist/types/service.interfaces.js +3 -0
- package/dist/types/service.interfaces.js.map +1 -0
- package/package.json +63 -0
- package/prisma/schema.prisma +53 -0
- package/public/assets/Dashboard-BupoWE_7.js +1 -0
- package/public/assets/DiskManage-BY6Sy7T6.js +1 -0
- package/public/assets/InitWizard-CA9epEkr.css +1 -0
- package/public/assets/InitWizard-D5Xj7dX0.js +1 -0
- package/public/assets/Layout-D-CPXnPP.js +1 -0
- package/public/assets/Layout-DaQY8YzE.css +1 -0
- package/public/assets/LogViewer-CIJZzoXw.css +1 -0
- package/public/assets/LogViewer-DDAIjW9J.js +1 -0
- package/public/assets/Login-D92i6dQA.js +1 -0
- package/public/assets/Login-DimFYijw.css +1 -0
- package/public/assets/ServiceManage-CIWLurL_.css +1 -0
- package/public/assets/ServiceManage-D-ZWP7Ry.js +1 -0
- package/public/assets/ShareManage-BMsFoGea.js +1 -0
- package/public/assets/UserList-CqeA7r2Y.js +1 -0
- package/public/assets/index-B-crAlzg.css +1 -0
- package/public/assets/index-CfC5GCM9.js +100 -0
- package/public/index.html +14 -0
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.InitService = void 0;
|
|
7
|
+
const bcryptjs_1 = __importDefault(require("bcryptjs"));
|
|
8
|
+
const crypto_1 = __importDefault(require("crypto"));
|
|
9
|
+
const auth_1 = require("../middleware/auth");
|
|
10
|
+
const logger_1 = require("../middleware/logger");
|
|
11
|
+
class InitService {
|
|
12
|
+
prisma;
|
|
13
|
+
constructor(prisma) {
|
|
14
|
+
this.prisma = prisma;
|
|
15
|
+
}
|
|
16
|
+
async getInitStatus() {
|
|
17
|
+
try {
|
|
18
|
+
const setting = await this.prisma.setting.findUnique({ where: { key: 'initialized' } });
|
|
19
|
+
return setting?.value === 'true';
|
|
20
|
+
}
|
|
21
|
+
catch {
|
|
22
|
+
return false;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
async init(adminUsername, adminPassword, siteTitle) {
|
|
26
|
+
const jwtSecret = crypto_1.default.randomBytes(32).toString('hex');
|
|
27
|
+
await this.prisma.setting.createMany({
|
|
28
|
+
data: [
|
|
29
|
+
{ key: 'initialized', value: 'true' },
|
|
30
|
+
{ key: 'jwtSecret', value: jwtSecret },
|
|
31
|
+
{ key: 'siteTitle', value: siteTitle || 'Cloud Storage Manager' },
|
|
32
|
+
],
|
|
33
|
+
});
|
|
34
|
+
(0, auth_1.setJwtSecret)(jwtSecret);
|
|
35
|
+
const hashed = await bcryptjs_1.default.hash(adminPassword, 10);
|
|
36
|
+
await this.prisma.admin.create({
|
|
37
|
+
data: {
|
|
38
|
+
username: adminUsername,
|
|
39
|
+
password: hashed,
|
|
40
|
+
role: 'superadmin',
|
|
41
|
+
},
|
|
42
|
+
});
|
|
43
|
+
logger_1.logger.info({ username: adminUsername, siteTitle }, '系统初始化完成');
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
exports.InitService = InitService;
|
|
47
|
+
//# sourceMappingURL=init.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init.service.js","sourceRoot":"","sources":["../../src/services/init.service.ts"],"names":[],"mappings":";;;;;;AAAA,wDAA6B;AAC7B,oDAA2B;AAE3B,6CAAiD;AACjD,iDAA6C;AAE7C,MAAa,WAAW;IACF;IAApB,YAAoB,MAAoB;QAApB,WAAM,GAAN,MAAM,CAAc;IAAG,CAAC;IAE5C,KAAK,CAAC,aAAa;QACjB,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,KAAK,EAAE,EAAE,GAAG,EAAE,aAAa,EAAE,EAAE,CAAC,CAAA;YACvF,OAAO,OAAO,EAAE,KAAK,KAAK,MAAM,CAAA;QAClC,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAA;QACd,CAAC;IACH,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,aAAqB,EAAE,aAAqB,EAAE,SAAkB;QACzE,MAAM,SAAS,GAAG,gBAAM,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;QAExD,MAAM,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC;YACnC,IAAI,EAAE;gBACJ,EAAE,GAAG,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,EAAE;gBACrC,EAAE,GAAG,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,EAAE;gBACtC,EAAE,GAAG,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,IAAI,uBAAuB,EAAE;aAClE;SACF,CAAC,CAAA;QAEF,IAAA,mBAAY,EAAC,SAAS,CAAC,CAAA;QAEvB,MAAM,MAAM,GAAG,MAAM,kBAAM,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,CAAC,CAAA;QACnD,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC;YAC7B,IAAI,EAAE;gBACJ,QAAQ,EAAE,aAAa;gBACvB,QAAQ,EAAE,MAAM;gBAChB,IAAI,EAAE,YAAY;aACnB;SACF,CAAC,CAAA;QAEF,eAAM,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,aAAa,EAAE,SAAS,EAAE,EAAE,SAAS,CAAC,CAAA;IAChE,CAAC;CACF;AApCD,kCAoCC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { IQuotaOperator } from '../operators/quota.operator';
|
|
2
|
+
import { IUserRepository } from '../repositories/user.repo';
|
|
3
|
+
export declare class QuotaService {
|
|
4
|
+
private userRepo;
|
|
5
|
+
private quotaOp;
|
|
6
|
+
constructor(userRepo: IUserRepository, quotaOp: IQuotaOperator);
|
|
7
|
+
get(userId: number): Promise<import("../types").QuotaInfo>;
|
|
8
|
+
update(userId: number, softGB: number, hardGB?: number): Promise<{
|
|
9
|
+
username: string;
|
|
10
|
+
quotaSoft: number;
|
|
11
|
+
quotaHard: number;
|
|
12
|
+
}>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=quota.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"quota.service.d.ts","sourceRoot":"","sources":["../../src/services/quota.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAA;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAI3D,qBAAa,YAAY;IAErB,OAAO,CAAC,QAAQ;IAChB,OAAO,CAAC,OAAO;gBADP,QAAQ,EAAE,eAAe,EACzB,OAAO,EAAE,cAAc;IAG3B,GAAG,CAAC,MAAM,EAAE,MAAM;IAOlB,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM;;;;;CAW7D"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.QuotaService = void 0;
|
|
4
|
+
const errors_1 = require("../lib/errors");
|
|
5
|
+
const logger_1 = require("../middleware/logger");
|
|
6
|
+
class QuotaService {
|
|
7
|
+
userRepo;
|
|
8
|
+
quotaOp;
|
|
9
|
+
constructor(userRepo, quotaOp) {
|
|
10
|
+
this.userRepo = userRepo;
|
|
11
|
+
this.quotaOp = quotaOp;
|
|
12
|
+
}
|
|
13
|
+
async get(userId) {
|
|
14
|
+
const user = await this.userRepo.findById(userId);
|
|
15
|
+
if (!user)
|
|
16
|
+
throw errors_1.AppError.notFound('用户不存在');
|
|
17
|
+
logger_1.logger.debug({ username: user.username }, '查询用户配额');
|
|
18
|
+
return this.quotaOp.get(user.username);
|
|
19
|
+
}
|
|
20
|
+
async update(userId, softGB, hardGB) {
|
|
21
|
+
const user = await this.userRepo.findById(userId);
|
|
22
|
+
if (!user)
|
|
23
|
+
throw errors_1.AppError.notFound('用户不存在');
|
|
24
|
+
const hard = hardGB || softGB;
|
|
25
|
+
logger_1.logger.info({ username: user.username, softGB, hardGB: hard }, '更新用户配额');
|
|
26
|
+
await this.quotaOp.set(user.username, softGB, hard);
|
|
27
|
+
await this.userRepo.update(userId, { quotaSoft: softGB, quotaHard: hard });
|
|
28
|
+
return { username: user.username, quotaSoft: softGB, quotaHard: hard };
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
exports.QuotaService = QuotaService;
|
|
32
|
+
//# sourceMappingURL=quota.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"quota.service.js","sourceRoot":"","sources":["../../src/services/quota.service.ts"],"names":[],"mappings":";;;AAEA,0CAAwC;AACxC,iDAA6C;AAE7C,MAAa,YAAY;IAEb;IACA;IAFV,YACU,QAAyB,EACzB,OAAuB;QADvB,aAAQ,GAAR,QAAQ,CAAiB;QACzB,YAAO,GAAP,OAAO,CAAgB;IAC9B,CAAC;IAEJ,KAAK,CAAC,GAAG,CAAC,MAAc;QACtB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAA;QACjD,IAAI,CAAC,IAAI;YAAE,MAAM,iBAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAA;QAC3C,eAAM,CAAC,KAAK,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,QAAQ,CAAC,CAAA;QACnD,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IACxC,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,MAAc,EAAE,MAAc,EAAE,MAAe;QAC1D,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAA;QACjD,IAAI,CAAC,IAAI;YAAE,MAAM,iBAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAA;QAE3C,MAAM,IAAI,GAAG,MAAM,IAAI,MAAM,CAAA;QAC7B,eAAM,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,QAAQ,CAAC,CAAA;QACxE,MAAM,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,CAAA;QACnD,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAA;QAE1E,OAAO,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,CAAA;IACxE,CAAC;CACF;AAxBD,oCAwBC"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { ISambaOperator } from '../operators/samba.operator';
|
|
2
|
+
import type { ISambaService } from '../types/service.interfaces';
|
|
3
|
+
export declare class SambaService implements ISambaService {
|
|
4
|
+
private sambaOp;
|
|
5
|
+
private confPath;
|
|
6
|
+
constructor(sambaOp: ISambaOperator);
|
|
7
|
+
status(): Promise<{
|
|
8
|
+
smb: boolean;
|
|
9
|
+
nmb: boolean;
|
|
10
|
+
installed: boolean;
|
|
11
|
+
}>;
|
|
12
|
+
install(onLog?: (msg: string) => void): Promise<{
|
|
13
|
+
smb: boolean;
|
|
14
|
+
nmb: boolean;
|
|
15
|
+
installed: boolean;
|
|
16
|
+
}>;
|
|
17
|
+
start(): Promise<{
|
|
18
|
+
smb: boolean;
|
|
19
|
+
nmb: boolean;
|
|
20
|
+
installed: boolean;
|
|
21
|
+
}>;
|
|
22
|
+
stop(): Promise<{
|
|
23
|
+
smb: boolean;
|
|
24
|
+
nmb: boolean;
|
|
25
|
+
installed: boolean;
|
|
26
|
+
}>;
|
|
27
|
+
uninstall(onLog?: (msg: string) => void): Promise<{
|
|
28
|
+
smb: boolean;
|
|
29
|
+
nmb: boolean;
|
|
30
|
+
installed: boolean;
|
|
31
|
+
}>;
|
|
32
|
+
restart(): Promise<{
|
|
33
|
+
smb: boolean;
|
|
34
|
+
nmb: boolean;
|
|
35
|
+
installed: boolean;
|
|
36
|
+
}>;
|
|
37
|
+
getConfig(): Promise<{
|
|
38
|
+
content: string;
|
|
39
|
+
path: string;
|
|
40
|
+
}>;
|
|
41
|
+
updateConfig(content: string): Promise<{
|
|
42
|
+
message: string;
|
|
43
|
+
}>;
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=samba.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"samba.service.d.ts","sourceRoot":"","sources":["../../src/services/samba.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAA;AAE5D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAA;AAGhE,qBAAa,YAAa,YAAW,aAAa;IAGpC,OAAO,CAAC,OAAO;IAF3B,OAAO,CAAC,QAAQ,CAAwB;gBAEpB,OAAO,EAAE,cAAc;IAErC,MAAM;;;;;IAIN,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI;;;;;IAMrC,KAAK;;;;;IAML,IAAI;;;;;IAMJ,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI;;;;;IAMvC,OAAO;;;;;IAMP,SAAS;;;;IAWT,YAAY,CAAC,OAAO,EAAE,MAAM;;;CAMnC"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.SambaService = void 0;
|
|
7
|
+
const logger_1 = require("../middleware/logger");
|
|
8
|
+
const fs_1 = __importDefault(require("fs"));
|
|
9
|
+
class SambaService {
|
|
10
|
+
sambaOp;
|
|
11
|
+
confPath = '/etc/samba/smb.conf';
|
|
12
|
+
constructor(sambaOp) {
|
|
13
|
+
this.sambaOp = sambaOp;
|
|
14
|
+
}
|
|
15
|
+
async status() {
|
|
16
|
+
return this.sambaOp.status();
|
|
17
|
+
}
|
|
18
|
+
async install(onLog) {
|
|
19
|
+
logger_1.logger.info('开始安装 Samba 服务');
|
|
20
|
+
await this.sambaOp.install(onLog);
|
|
21
|
+
return this.sambaOp.status();
|
|
22
|
+
}
|
|
23
|
+
async start() {
|
|
24
|
+
logger_1.logger.info('启动 Samba 服务');
|
|
25
|
+
await this.sambaOp.start();
|
|
26
|
+
return this.sambaOp.status();
|
|
27
|
+
}
|
|
28
|
+
async stop() {
|
|
29
|
+
logger_1.logger.info('停止 Samba 服务');
|
|
30
|
+
await this.sambaOp.stop();
|
|
31
|
+
return this.sambaOp.status();
|
|
32
|
+
}
|
|
33
|
+
async uninstall(onLog) {
|
|
34
|
+
logger_1.logger.info('开始卸载 Samba 服务');
|
|
35
|
+
await this.sambaOp.uninstall(onLog);
|
|
36
|
+
return this.sambaOp.status();
|
|
37
|
+
}
|
|
38
|
+
async restart() {
|
|
39
|
+
logger_1.logger.info('重启 Samba 服务');
|
|
40
|
+
await this.sambaOp.restart();
|
|
41
|
+
return this.sambaOp.status();
|
|
42
|
+
}
|
|
43
|
+
async getConfig() {
|
|
44
|
+
logger_1.logger.debug('读取 Samba 配置文件');
|
|
45
|
+
if (!fs_1.default.existsSync(this.confPath)) {
|
|
46
|
+
return { content: '', path: this.confPath };
|
|
47
|
+
}
|
|
48
|
+
return {
|
|
49
|
+
content: fs_1.default.readFileSync(this.confPath, 'utf-8'),
|
|
50
|
+
path: this.confPath,
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
async updateConfig(content) {
|
|
54
|
+
logger_1.logger.info('更新 Samba 配置文件');
|
|
55
|
+
fs_1.default.writeFileSync(this.confPath, content);
|
|
56
|
+
await this.sambaOp.restart();
|
|
57
|
+
return { message: '配置已更新并重启服务' };
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
exports.SambaService = SambaService;
|
|
61
|
+
//# sourceMappingURL=samba.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"samba.service.js","sourceRoot":"","sources":["../../src/services/samba.service.ts"],"names":[],"mappings":";;;;;;AACA,iDAA6C;AAE7C,4CAAmB;AAEnB,MAAa,YAAY;IAGH;IAFZ,QAAQ,GAAG,qBAAqB,CAAA;IAExC,YAAoB,OAAuB;QAAvB,YAAO,GAAP,OAAO,CAAgB;IAAG,CAAC;IAE/C,KAAK,CAAC,MAAM;QACV,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAA;IAC9B,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,KAA6B;QACzC,eAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAA;QAC5B,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;QACjC,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAA;IAC9B,CAAC;IAED,KAAK,CAAC,KAAK;QACT,eAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA;QAC1B,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAA;QAC1B,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAA;IAC9B,CAAC;IAED,KAAK,CAAC,IAAI;QACR,eAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA;QAC1B,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAA;QACzB,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAA;IAC9B,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,KAA6B;QAC3C,eAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAA;QAC5B,MAAM,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,CAAA;QACnC,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAA;IAC9B,CAAC;IAED,KAAK,CAAC,OAAO;QACX,eAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA;QAC1B,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAA;QAC5B,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAA;IAC9B,CAAC;IAED,KAAK,CAAC,SAAS;QACb,eAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAA;QAC7B,IAAI,CAAC,YAAE,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;YAClC,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAA;QAC7C,CAAC;QACD,OAAO;YACL,OAAO,EAAE,YAAE,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,CAAC;YAChD,IAAI,EAAE,IAAI,CAAC,QAAQ;SACpB,CAAA;IACH,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,OAAe;QAChC,eAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAA;QAC5B,YAAE,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAA;QACxC,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAA;QAC5B,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,CAAA;IAClC,CAAC;CACF;AAxDD,oCAwDC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { IShareOperator } from '../operators/share.operator';
|
|
2
|
+
import type { IShareService } from '../types/service.interfaces';
|
|
3
|
+
export declare class ShareService implements IShareService {
|
|
4
|
+
private shareOp;
|
|
5
|
+
constructor(shareOp: IShareOperator);
|
|
6
|
+
list(): Promise<import("../types").ShareInfo[]>;
|
|
7
|
+
create(path: string, owner: string, group?: string): Promise<{
|
|
8
|
+
path: string;
|
|
9
|
+
owner: string;
|
|
10
|
+
group: string;
|
|
11
|
+
}>;
|
|
12
|
+
remove(path: string): Promise<void>;
|
|
13
|
+
setPermissions(path: string, mode: string): Promise<{
|
|
14
|
+
path: string;
|
|
15
|
+
mode: string;
|
|
16
|
+
}>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=share.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"share.service.d.ts","sourceRoot":"","sources":["../../src/services/share.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAA;AAE5D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAA;AAEhE,qBAAa,YAAa,YAAW,aAAa;IACpC,OAAO,CAAC,OAAO;gBAAP,OAAO,EAAE,cAAc;IAErC,IAAI;IAIJ,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM;;;;;IAMlD,MAAM,CAAC,IAAI,EAAE,MAAM;IAKnB,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM;;;;CAKhD"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ShareService = void 0;
|
|
4
|
+
const logger_1 = require("../middleware/logger");
|
|
5
|
+
class ShareService {
|
|
6
|
+
shareOp;
|
|
7
|
+
constructor(shareOp) {
|
|
8
|
+
this.shareOp = shareOp;
|
|
9
|
+
}
|
|
10
|
+
async list() {
|
|
11
|
+
return this.shareOp.list();
|
|
12
|
+
}
|
|
13
|
+
async create(path, owner, group) {
|
|
14
|
+
logger_1.logger.info({ path, owner, group: group || owner }, '创建共享目录');
|
|
15
|
+
await this.shareOp.create(path, owner, group || owner);
|
|
16
|
+
return { path, owner, group: group || owner };
|
|
17
|
+
}
|
|
18
|
+
async remove(path) {
|
|
19
|
+
logger_1.logger.info({ path }, '删除共享目录');
|
|
20
|
+
await this.shareOp.remove(path);
|
|
21
|
+
}
|
|
22
|
+
async setPermissions(path, mode) {
|
|
23
|
+
logger_1.logger.info({ path, mode }, '设置共享目录权限');
|
|
24
|
+
await this.shareOp.setPermissions(path, mode);
|
|
25
|
+
return { path, mode };
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
exports.ShareService = ShareService;
|
|
29
|
+
//# sourceMappingURL=share.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"share.service.js","sourceRoot":"","sources":["../../src/services/share.service.ts"],"names":[],"mappings":";;;AACA,iDAA6C;AAG7C,MAAa,YAAY;IACH;IAApB,YAAoB,OAAuB;QAAvB,YAAO,GAAP,OAAO,CAAgB;IAAG,CAAC;IAE/C,KAAK,CAAC,IAAI;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAA;IAC5B,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,IAAY,EAAE,KAAa,EAAE,KAAc;QACtD,eAAM,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,IAAI,KAAK,EAAE,EAAE,QAAQ,CAAC,CAAA;QAC7D,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,IAAI,KAAK,CAAC,CAAA;QACtD,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,IAAI,KAAK,EAAE,CAAA;IAC/C,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,IAAY;QACvB,eAAM,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,EAAE,QAAQ,CAAC,CAAA;QAC/B,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;IACjC,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,IAAY,EAAE,IAAY;QAC7C,eAAM,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,UAAU,CAAC,CAAA;QACvC,MAAM,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,CAAC,CAAA;QAC7C,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,CAAA;IACvB,CAAC;CACF;AAvBD,oCAuBC"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { IUserRepository, UpdateUserInput, ListParams } from '../repositories/user.repo';
|
|
2
|
+
import { IUserOperator } from '../operators/linux-user.operator';
|
|
3
|
+
import { ISambaOperator } from '../operators/samba.operator';
|
|
4
|
+
import { IQuotaOperator } from '../operators/quota.operator';
|
|
5
|
+
import { IShareOperator } from '../operators/share.operator';
|
|
6
|
+
import type { IUserService } from '../types/service.interfaces';
|
|
7
|
+
export declare class UserService implements IUserService {
|
|
8
|
+
private userRepo;
|
|
9
|
+
private userOp;
|
|
10
|
+
private sambaOp;
|
|
11
|
+
private quotaOp;
|
|
12
|
+
private shareOp;
|
|
13
|
+
constructor(userRepo: IUserRepository, userOp: IUserOperator, sambaOp: ISambaOperator, quotaOp: IQuotaOperator, shareOp: IShareOperator);
|
|
14
|
+
create(input: {
|
|
15
|
+
username: string;
|
|
16
|
+
password: string;
|
|
17
|
+
groupName?: string;
|
|
18
|
+
quotaSoft: number;
|
|
19
|
+
quotaHard?: number;
|
|
20
|
+
}): Promise<any>;
|
|
21
|
+
findById(id: number): Promise<any>;
|
|
22
|
+
changePassword(username: string, oldPassword: string, newPassword: string): Promise<{
|
|
23
|
+
success: boolean;
|
|
24
|
+
}>;
|
|
25
|
+
list(params: ListParams): Promise<{
|
|
26
|
+
items: any[];
|
|
27
|
+
total: number;
|
|
28
|
+
}>;
|
|
29
|
+
update(id: number, input: UpdateUserInput): Promise<any>;
|
|
30
|
+
delete(id: number): Promise<void>;
|
|
31
|
+
disable(id: number): Promise<any>;
|
|
32
|
+
enable(id: number, password?: string): Promise<any>;
|
|
33
|
+
batch(accounts: Array<{
|
|
34
|
+
username: string;
|
|
35
|
+
password: string;
|
|
36
|
+
groupName?: string;
|
|
37
|
+
quotaSoft: number;
|
|
38
|
+
quotaHard?: number;
|
|
39
|
+
action: 'add' | 'delete';
|
|
40
|
+
}>): Promise<{
|
|
41
|
+
username: string;
|
|
42
|
+
action: string;
|
|
43
|
+
success: boolean;
|
|
44
|
+
error?: string;
|
|
45
|
+
}[]>;
|
|
46
|
+
private toSafeUser;
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=user.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user.service.d.ts","sourceRoot":"","sources":["../../src/services/user.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAA;AACxF,OAAO,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAA;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAA;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAA;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAA;AAI5D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAG/D,qBAAa,WAAY,YAAW,YAAY;IAE5C,OAAO,CAAC,QAAQ;IAChB,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,OAAO;gBAJP,QAAQ,EAAE,eAAe,EACzB,MAAM,EAAE,aAAa,EACrB,OAAO,EAAE,cAAc,EACvB,OAAO,EAAE,cAAc,EACvB,OAAO,EAAE,cAAc;IAG3B,MAAM,CAAC,KAAK,EAAE;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAC;QAAC,SAAS,CAAC,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,SAAS,CAAC,EAAE,MAAM,CAAA;KAAE;IA2C/G,QAAQ,CAAC,EAAE,EAAE,MAAM;IAMnB,cAAc,CAAC,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM;;;IAuBzE,IAAI,CAAC,MAAM,EAAE,UAAU;;;;IAQvB,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,eAAe;IA4BzC,MAAM,CAAC,EAAE,EAAE,MAAM;IAgBjB,OAAO,CAAC,EAAE,EAAE,MAAM;IAelB,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM;IAmBpC,KAAK,CACT,QAAQ,EAAE,KAAK,CAAC;QACd,QAAQ,EAAE,MAAM,CAAA;QAChB,QAAQ,EAAE,MAAM,CAAA;QAChB,SAAS,CAAC,EAAE,MAAM,CAAA;QAClB,SAAS,EAAE,MAAM,CAAA;QACjB,SAAS,CAAC,EAAE,MAAM,CAAA;QAClB,MAAM,EAAE,KAAK,GAAG,QAAQ,CAAA;KACzB,CAAC;kBAG+B,MAAM;gBAAU,MAAM;iBAAW,OAAO;gBAAU,MAAM;;IAiC3F,OAAO,CAAC,UAAU;CAInB"}
|
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.UserService = void 0;
|
|
7
|
+
const config_1 = require("../config");
|
|
8
|
+
const errors_1 = require("../lib/errors");
|
|
9
|
+
const logger_1 = require("../middleware/logger");
|
|
10
|
+
const bcryptjs_1 = __importDefault(require("bcryptjs"));
|
|
11
|
+
class UserService {
|
|
12
|
+
userRepo;
|
|
13
|
+
userOp;
|
|
14
|
+
sambaOp;
|
|
15
|
+
quotaOp;
|
|
16
|
+
shareOp;
|
|
17
|
+
constructor(userRepo, userOp, sambaOp, quotaOp, shareOp) {
|
|
18
|
+
this.userRepo = userRepo;
|
|
19
|
+
this.userOp = userOp;
|
|
20
|
+
this.sambaOp = sambaOp;
|
|
21
|
+
this.quotaOp = quotaOp;
|
|
22
|
+
this.shareOp = shareOp;
|
|
23
|
+
}
|
|
24
|
+
async create(input) {
|
|
25
|
+
const existing = await this.userRepo.findByUsername(input.username);
|
|
26
|
+
if (existing) {
|
|
27
|
+
logger_1.logger.warn({ username: input.username }, '创建用户失败: 用户名已存在');
|
|
28
|
+
throw errors_1.AppError.conflict('用户名已存在');
|
|
29
|
+
}
|
|
30
|
+
const sharePath = `${config_1.config.system.shareBase}/${input.username}`;
|
|
31
|
+
const groupName = input.groupName || input.username;
|
|
32
|
+
const quotaHard = input.quotaHard || input.quotaSoft;
|
|
33
|
+
logger_1.logger.info({ username: input.username, groupName, sharePath, quotaSoft: input.quotaSoft, quotaHard }, '开始创建用户');
|
|
34
|
+
// Hash password for storage
|
|
35
|
+
const hashed = await bcryptjs_1.default.hash(input.password, 10);
|
|
36
|
+
// Create in DB
|
|
37
|
+
const user = await this.userRepo.create({
|
|
38
|
+
username: input.username,
|
|
39
|
+
password: hashed,
|
|
40
|
+
groupName,
|
|
41
|
+
sharePath,
|
|
42
|
+
quotaSoft: input.quotaSoft,
|
|
43
|
+
quotaHard,
|
|
44
|
+
});
|
|
45
|
+
// System operations (best-effort with rollback)
|
|
46
|
+
try {
|
|
47
|
+
await this.userOp.createSystemUser(input.username, input.password);
|
|
48
|
+
await this.shareOp.create(sharePath, input.username, groupName);
|
|
49
|
+
await this.sambaOp.addUser(input.username, input.password);
|
|
50
|
+
await this.sambaOp.writeShareConfig(input.username, sharePath);
|
|
51
|
+
await this.quotaOp.set(input.username, input.quotaSoft, quotaHard);
|
|
52
|
+
}
|
|
53
|
+
catch (err) {
|
|
54
|
+
logger_1.logger.error({ username: input.username, err }, '创建用户失败,回滚数据库记录');
|
|
55
|
+
await this.userRepo.delete(user.id).catch(() => { });
|
|
56
|
+
throw err;
|
|
57
|
+
}
|
|
58
|
+
logger_1.logger.info({ username: input.username }, '用户创建成功');
|
|
59
|
+
return this.toSafeUser(user);
|
|
60
|
+
}
|
|
61
|
+
async findById(id) {
|
|
62
|
+
const user = await this.userRepo.findById(id);
|
|
63
|
+
if (!user)
|
|
64
|
+
throw errors_1.AppError.notFound('用户不存在');
|
|
65
|
+
return this.toSafeUser(user);
|
|
66
|
+
}
|
|
67
|
+
async changePassword(username, oldPassword, newPassword) {
|
|
68
|
+
const user = await this.userRepo.findByUsername(username);
|
|
69
|
+
if (!user) {
|
|
70
|
+
logger_1.logger.warn({ username }, '修改密码失败: 用户不存在');
|
|
71
|
+
throw errors_1.AppError.unauthorized('用户名或密码错误');
|
|
72
|
+
}
|
|
73
|
+
const valid = await bcryptjs_1.default.compare(oldPassword, user.password);
|
|
74
|
+
if (!valid) {
|
|
75
|
+
logger_1.logger.warn({ username }, '修改密码失败: 原密码错误');
|
|
76
|
+
throw errors_1.AppError.unauthorized('用户名或密码错误');
|
|
77
|
+
}
|
|
78
|
+
await this.userOp.setPassword(user.username, newPassword);
|
|
79
|
+
await this.sambaOp.addUser(user.username, newPassword);
|
|
80
|
+
const hashed = await bcryptjs_1.default.hash(newPassword, 10);
|
|
81
|
+
await this.userRepo.update(user.id, { password: hashed });
|
|
82
|
+
logger_1.logger.info({ username }, '用户密码修改成功');
|
|
83
|
+
return { success: true };
|
|
84
|
+
}
|
|
85
|
+
async list(params) {
|
|
86
|
+
const result = await this.userRepo.list(params);
|
|
87
|
+
return {
|
|
88
|
+
items: result.items.map((u) => this.toSafeUser(u)),
|
|
89
|
+
total: result.total,
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
async update(id, input) {
|
|
93
|
+
const user = await this.userRepo.findById(id);
|
|
94
|
+
if (!user)
|
|
95
|
+
throw errors_1.AppError.notFound('用户不存在');
|
|
96
|
+
logger_1.logger.info({ id, username: user.username, fields: Object.keys(input) }, '更新用户信息');
|
|
97
|
+
if (input.password) {
|
|
98
|
+
await this.userOp.setPassword(user.username, input.password);
|
|
99
|
+
await this.sambaOp.addUser(user.username, input.password);
|
|
100
|
+
}
|
|
101
|
+
if (input.quotaSoft !== undefined) {
|
|
102
|
+
const hard = input.quotaHard || input.quotaSoft;
|
|
103
|
+
await this.quotaOp.set(user.username, input.quotaSoft, hard);
|
|
104
|
+
}
|
|
105
|
+
const hashed = input.password
|
|
106
|
+
? await bcryptjs_1.default.hash(input.password, 10)
|
|
107
|
+
: undefined;
|
|
108
|
+
const updated = await this.userRepo.update(id, {
|
|
109
|
+
...input,
|
|
110
|
+
password: hashed,
|
|
111
|
+
});
|
|
112
|
+
return this.toSafeUser(updated);
|
|
113
|
+
}
|
|
114
|
+
async delete(id) {
|
|
115
|
+
const user = await this.userRepo.findById(id);
|
|
116
|
+
if (!user)
|
|
117
|
+
throw errors_1.AppError.notFound('用户不存在');
|
|
118
|
+
logger_1.logger.info({ id, username: user.username }, '删除用户');
|
|
119
|
+
// System cleanup
|
|
120
|
+
await this.quotaOp.remove(user.username).catch(() => { });
|
|
121
|
+
await this.sambaOp.removeUser(user.username).catch(() => { });
|
|
122
|
+
await this.sambaOp.removeShareConfig(user.username).catch(() => { });
|
|
123
|
+
await this.userOp.deleteSystemUser(user.username).catch(() => { });
|
|
124
|
+
await this.userRepo.delete(id);
|
|
125
|
+
logger_1.logger.info({ username: user.username }, '用户已删除');
|
|
126
|
+
}
|
|
127
|
+
async disable(id) {
|
|
128
|
+
const user = await this.userRepo.findById(id);
|
|
129
|
+
if (!user)
|
|
130
|
+
throw errors_1.AppError.notFound('用户不存在');
|
|
131
|
+
if (user.status === 'disabled')
|
|
132
|
+
throw errors_1.AppError.badRequest('用户已被禁用');
|
|
133
|
+
logger_1.logger.info({ id, username: user.username }, '禁用用户');
|
|
134
|
+
// Remove system access but keep data and DB record
|
|
135
|
+
await this.sambaOp.removeUser(user.username).catch(() => { });
|
|
136
|
+
await this.userOp.deleteSystemUser(user.username).catch(() => { });
|
|
137
|
+
const updated = await this.userRepo.update(id, { status: 'disabled' });
|
|
138
|
+
return this.toSafeUser(updated);
|
|
139
|
+
}
|
|
140
|
+
async enable(id, password) {
|
|
141
|
+
const user = await this.userRepo.findById(id);
|
|
142
|
+
if (!user)
|
|
143
|
+
throw errors_1.AppError.notFound('用户不存在');
|
|
144
|
+
if (user.status === 'active')
|
|
145
|
+
throw errors_1.AppError.badRequest('用户已处于启用状态');
|
|
146
|
+
logger_1.logger.info({ id, username: user.username }, '启用用户');
|
|
147
|
+
const pwd = password || 'changeme123';
|
|
148
|
+
// Recreate system user and Samba access
|
|
149
|
+
await this.userOp.createSystemUser(user.username, pwd);
|
|
150
|
+
await this.sambaOp.addUser(user.username, pwd);
|
|
151
|
+
await this.sambaOp.writeShareConfig(user.username, user.sharePath);
|
|
152
|
+
const hashed = password ? await bcryptjs_1.default.hash(password, 10) : user.password;
|
|
153
|
+
const updated = await this.userRepo.update(id, { status: 'active', password: hashed });
|
|
154
|
+
return this.toSafeUser(updated);
|
|
155
|
+
}
|
|
156
|
+
async batch(accounts) {
|
|
157
|
+
logger_1.logger.info({ count: accounts.length }, '批量操作用户');
|
|
158
|
+
const results = [];
|
|
159
|
+
for (const account of accounts) {
|
|
160
|
+
try {
|
|
161
|
+
if (account.action === 'add') {
|
|
162
|
+
await this.create({
|
|
163
|
+
username: account.username,
|
|
164
|
+
password: account.password,
|
|
165
|
+
groupName: account.groupName,
|
|
166
|
+
quotaSoft: account.quotaSoft,
|
|
167
|
+
quotaHard: account.quotaHard,
|
|
168
|
+
});
|
|
169
|
+
results.push({ username: account.username, action: 'add', success: true });
|
|
170
|
+
}
|
|
171
|
+
else {
|
|
172
|
+
const user = await this.userRepo.findByUsername(account.username);
|
|
173
|
+
if (user) {
|
|
174
|
+
await this.delete(user.id);
|
|
175
|
+
}
|
|
176
|
+
results.push({ username: account.username, action: 'delete', success: true });
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
catch (err) {
|
|
180
|
+
results.push({
|
|
181
|
+
username: account.username,
|
|
182
|
+
action: account.action,
|
|
183
|
+
success: false,
|
|
184
|
+
error: err.message,
|
|
185
|
+
});
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
return results;
|
|
189
|
+
}
|
|
190
|
+
toSafeUser(user) {
|
|
191
|
+
const { password, ...safe } = user;
|
|
192
|
+
return safe;
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
exports.UserService = UserService;
|
|
196
|
+
//# sourceMappingURL=user.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user.service.js","sourceRoot":"","sources":["../../src/services/user.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from '../repositories/user.repo';
|
|
2
|
+
export * from '../operators/linux-user.operator';
|
|
3
|
+
export * from '../operators/samba.operator';
|
|
4
|
+
export * from '../operators/quota.operator';
|
|
5
|
+
export * from '../operators/disk.operator';
|
|
6
|
+
export * from '../operators/share.operator';
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,2BAA2B,CAAA;AACzC,cAAc,kCAAkC,CAAA;AAChD,cAAc,6BAA6B,CAAA;AAC3C,cAAc,6BAA6B,CAAA;AAC3C,cAAc,4BAA4B,CAAA;AAC1C,cAAc,6BAA6B,CAAA"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("../repositories/user.repo"), exports);
|
|
18
|
+
__exportStar(require("../operators/linux-user.operator"), exports);
|
|
19
|
+
__exportStar(require("../operators/samba.operator"), exports);
|
|
20
|
+
__exportStar(require("../operators/quota.operator"), exports);
|
|
21
|
+
__exportStar(require("../operators/disk.operator"), exports);
|
|
22
|
+
__exportStar(require("../operators/share.operator"), exports);
|
|
23
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,4DAAyC;AACzC,mEAAgD;AAChD,8DAA2C;AAC3C,8DAA2C;AAC3C,6DAA0C;AAC1C,8DAA2C"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
export interface IAuthService {
|
|
2
|
+
login(username: string, password: string): Promise<{
|
|
3
|
+
token: string;
|
|
4
|
+
user: any;
|
|
5
|
+
}>;
|
|
6
|
+
refreshToken(token: string): Promise<{
|
|
7
|
+
token: string;
|
|
8
|
+
}>;
|
|
9
|
+
getMe(userId: number): Promise<any>;
|
|
10
|
+
}
|
|
11
|
+
export interface IDiskService {
|
|
12
|
+
list(): Promise<any[]>;
|
|
13
|
+
format(device: string, fsType: string): Promise<void>;
|
|
14
|
+
mount(device: string, target: string, options?: string): Promise<void>;
|
|
15
|
+
umount(target: string): Promise<void>;
|
|
16
|
+
usage(mountPoint: string): Promise<any>;
|
|
17
|
+
}
|
|
18
|
+
export interface ISambaService {
|
|
19
|
+
status(): Promise<any>;
|
|
20
|
+
install(onLog?: (msg: string) => void): Promise<any>;
|
|
21
|
+
start(): Promise<any>;
|
|
22
|
+
stop(): Promise<any>;
|
|
23
|
+
uninstall(onLog?: (msg: string) => void): Promise<any>;
|
|
24
|
+
restart(): Promise<any>;
|
|
25
|
+
getConfig(): Promise<any>;
|
|
26
|
+
updateConfig(content: string): Promise<any>;
|
|
27
|
+
}
|
|
28
|
+
export interface IShareService {
|
|
29
|
+
list(): Promise<any[]>;
|
|
30
|
+
create(path: string, owner: string, group?: string): Promise<any>;
|
|
31
|
+
remove(path: string): Promise<void>;
|
|
32
|
+
setPermissions(path: string, mode: string): Promise<any>;
|
|
33
|
+
}
|
|
34
|
+
export interface IUserService {
|
|
35
|
+
create(input: any): Promise<any>;
|
|
36
|
+
findById(id: number): Promise<any>;
|
|
37
|
+
changePassword(username: string, oldPassword: string, newPassword: string): Promise<any>;
|
|
38
|
+
list(params: any): Promise<any>;
|
|
39
|
+
update(id: number, input: any): Promise<any>;
|
|
40
|
+
delete(id: number): Promise<void>;
|
|
41
|
+
disable(id: number): Promise<any>;
|
|
42
|
+
enable(id: number, password?: string): Promise<any>;
|
|
43
|
+
batch(accounts: any[]): Promise<any[]>;
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=service.interfaces.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service.interfaces.d.ts","sourceRoot":"","sources":["../../src/types/service.interfaces.ts"],"names":[],"mappings":"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"}
|