github-project-manager 0.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/apps/backend/dist/app.controller.d.ts +9 -0
- package/apps/backend/dist/app.controller.js +35 -0
- package/apps/backend/dist/app.controller.js.map +1 -0
- package/apps/backend/dist/app.module.d.ts +4 -0
- package/apps/backend/dist/app.module.js +59 -0
- package/apps/backend/dist/app.module.js.map +1 -0
- package/apps/backend/dist/app.service.d.ts +6 -0
- package/apps/backend/dist/app.service.js +20 -0
- package/apps/backend/dist/app.service.js.map +1 -0
- package/apps/backend/dist/filters/github-exception.filter.d.ts +4 -0
- package/apps/backend/dist/filters/github-exception.filter.js +63 -0
- package/apps/backend/dist/filters/github-exception.filter.js.map +1 -0
- package/apps/backend/dist/main.d.ts +1 -0
- package/apps/backend/dist/main.js +15 -0
- package/apps/backend/dist/main.js.map +1 -0
- package/apps/backend/dist/middleware/project-context.middleware.d.ts +8 -0
- package/apps/backend/dist/middleware/project-context.middleware.js +43 -0
- package/apps/backend/dist/middleware/project-context.middleware.js.map +1 -0
- package/apps/backend/dist/modules/label/label.entity.d.ts +10 -0
- package/apps/backend/dist/modules/label/label.entity.js +57 -0
- package/apps/backend/dist/modules/label/label.entity.js.map +1 -0
- package/apps/backend/dist/modules/label/label.module.d.ts +2 -0
- package/apps/backend/dist/modules/label/label.module.js +22 -0
- package/apps/backend/dist/modules/label/label.module.js.map +1 -0
- package/apps/backend/dist/modules/milestone/milestone.entity.d.ts +11 -0
- package/apps/backend/dist/modules/milestone/milestone.entity.js +62 -0
- package/apps/backend/dist/modules/milestone/milestone.entity.js.map +1 -0
- package/apps/backend/dist/modules/milestone/milestone.module.d.ts +2 -0
- package/apps/backend/dist/modules/milestone/milestone.module.js +22 -0
- package/apps/backend/dist/modules/milestone/milestone.module.js.map +1 -0
- package/apps/backend/dist/modules/project/project.controller.d.ts +6 -0
- package/apps/backend/dist/modules/project/project.controller.js +35 -0
- package/apps/backend/dist/modules/project/project.controller.js.map +1 -0
- package/apps/backend/dist/modules/project/project.entity.d.ts +19 -0
- package/apps/backend/dist/modules/project/project.entity.js +90 -0
- package/apps/backend/dist/modules/project/project.entity.js.map +1 -0
- package/apps/backend/dist/modules/project/project.module.d.ts +2 -0
- package/apps/backend/dist/modules/project/project.module.js +27 -0
- package/apps/backend/dist/modules/project/project.module.js.map +1 -0
- package/apps/backend/dist/modules/project/project.service.d.ts +10 -0
- package/apps/backend/dist/modules/project/project.service.js +59 -0
- package/apps/backend/dist/modules/project/project.service.js.map +1 -0
- package/apps/backend/dist/modules/sync/github.service.d.ts +61 -0
- package/apps/backend/dist/modules/sync/github.service.js +213 -0
- package/apps/backend/dist/modules/sync/github.service.js.map +1 -0
- package/apps/backend/dist/modules/sync/sync-log.entity.d.ts +11 -0
- package/apps/backend/dist/modules/sync/sync-log.entity.js +62 -0
- package/apps/backend/dist/modules/sync/sync-log.entity.js.map +1 -0
- package/apps/backend/dist/modules/sync/sync.controller.d.ts +8 -0
- package/apps/backend/dist/modules/sync/sync.controller.js +43 -0
- package/apps/backend/dist/modules/sync/sync.controller.js.map +1 -0
- package/apps/backend/dist/modules/sync/sync.module.d.ts +2 -0
- package/apps/backend/dist/modules/sync/sync.module.js +28 -0
- package/apps/backend/dist/modules/sync/sync.module.js.map +1 -0
- package/apps/backend/dist/modules/sync/sync.service.d.ts +24 -0
- package/apps/backend/dist/modules/sync/sync.service.js +193 -0
- package/apps/backend/dist/modules/sync/sync.service.js.map +1 -0
- package/apps/backend/dist/modules/task/task.controller.d.ts +23 -0
- package/apps/backend/dist/modules/task/task.controller.js +111 -0
- package/apps/backend/dist/modules/task/task.controller.js.map +1 -0
- package/apps/backend/dist/modules/task/task.entity.d.ts +22 -0
- package/apps/backend/dist/modules/task/task.entity.js +118 -0
- package/apps/backend/dist/modules/task/task.entity.js.map +1 -0
- package/apps/backend/dist/modules/task/task.module.d.ts +2 -0
- package/apps/backend/dist/modules/task/task.module.js +27 -0
- package/apps/backend/dist/modules/task/task.module.js.map +1 -0
- package/apps/backend/dist/modules/task/task.service.d.ts +11 -0
- package/apps/backend/dist/modules/task/task.service.js +57 -0
- package/apps/backend/dist/modules/task/task.service.js.map +1 -0
- package/apps/cli/bin/gpm.js +2 -0
- package/apps/cli/dist/commands/init.d.ts +14 -0
- package/apps/cli/dist/commands/init.js +177 -0
- package/apps/cli/dist/commands/init.js.map +1 -0
- package/apps/cli/dist/commands/server.d.ts +4 -0
- package/apps/cli/dist/commands/server.js +65 -0
- package/apps/cli/dist/commands/server.js.map +1 -0
- package/apps/cli/dist/index.d.ts +1 -0
- package/apps/cli/dist/index.js +231 -0
- package/apps/cli/dist/index.js.map +1 -0
- package/apps/cli/dist/types.d.ts +7 -0
- package/apps/cli/dist/types.js +3 -0
- package/apps/cli/dist/types.js.map +1 -0
- package/apps/cli/dist/utils/api-client.d.ts +7 -0
- package/apps/cli/dist/utils/api-client.js +53 -0
- package/apps/cli/dist/utils/api-client.js.map +1 -0
- package/apps/cli/dist/utils/bootstrap.d.ts +4 -0
- package/apps/cli/dist/utils/bootstrap.js +23 -0
- package/apps/cli/dist/utils/bootstrap.js.map +1 -0
- package/apps/cli/dist/utils/gpmrc.d.ts +3 -0
- package/apps/cli/dist/utils/gpmrc.js +22 -0
- package/apps/cli/dist/utils/gpmrc.js.map +1 -0
- package/apps/frontend/dist/assets/index-5kQElBCK.css +1 -0
- package/apps/frontend/dist/assets/index-DzMlDUgv.js +60 -0
- package/apps/frontend/dist/index.html +13 -0
- package/package.json +42 -0
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.Project = void 0;
|
|
13
|
+
const typeorm_1 = require("typeorm");
|
|
14
|
+
const task_entity_1 = require("../task/task.entity");
|
|
15
|
+
const label_entity_1 = require("../label/label.entity");
|
|
16
|
+
const milestone_entity_1 = require("../milestone/milestone.entity");
|
|
17
|
+
const sync_log_entity_1 = require("../sync/sync-log.entity");
|
|
18
|
+
let Project = class Project {
|
|
19
|
+
id;
|
|
20
|
+
owner;
|
|
21
|
+
ownerType;
|
|
22
|
+
repo;
|
|
23
|
+
projectNumber;
|
|
24
|
+
projectUrl;
|
|
25
|
+
githubProjectId;
|
|
26
|
+
createdAt;
|
|
27
|
+
updatedAt;
|
|
28
|
+
tasks;
|
|
29
|
+
labels;
|
|
30
|
+
milestones;
|
|
31
|
+
syncLogs;
|
|
32
|
+
};
|
|
33
|
+
exports.Project = Project;
|
|
34
|
+
__decorate([
|
|
35
|
+
(0, typeorm_1.PrimaryGeneratedColumn)(),
|
|
36
|
+
__metadata("design:type", Number)
|
|
37
|
+
], Project.prototype, "id", void 0);
|
|
38
|
+
__decorate([
|
|
39
|
+
(0, typeorm_1.Column)(),
|
|
40
|
+
__metadata("design:type", String)
|
|
41
|
+
], Project.prototype, "owner", void 0);
|
|
42
|
+
__decorate([
|
|
43
|
+
(0, typeorm_1.Column)({ name: 'owner_type', default: 'organization' }),
|
|
44
|
+
__metadata("design:type", String)
|
|
45
|
+
], Project.prototype, "ownerType", void 0);
|
|
46
|
+
__decorate([
|
|
47
|
+
(0, typeorm_1.Column)({ nullable: true }),
|
|
48
|
+
__metadata("design:type", String)
|
|
49
|
+
], Project.prototype, "repo", void 0);
|
|
50
|
+
__decorate([
|
|
51
|
+
(0, typeorm_1.Column)({ name: 'project_number' }),
|
|
52
|
+
__metadata("design:type", Number)
|
|
53
|
+
], Project.prototype, "projectNumber", void 0);
|
|
54
|
+
__decorate([
|
|
55
|
+
(0, typeorm_1.Column)({ name: 'project_url' }),
|
|
56
|
+
__metadata("design:type", String)
|
|
57
|
+
], Project.prototype, "projectUrl", void 0);
|
|
58
|
+
__decorate([
|
|
59
|
+
(0, typeorm_1.Column)({ name: 'github_project_id', nullable: true }),
|
|
60
|
+
__metadata("design:type", String)
|
|
61
|
+
], Project.prototype, "githubProjectId", void 0);
|
|
62
|
+
__decorate([
|
|
63
|
+
(0, typeorm_1.CreateDateColumn)({ name: 'created_at' }),
|
|
64
|
+
__metadata("design:type", Date)
|
|
65
|
+
], Project.prototype, "createdAt", void 0);
|
|
66
|
+
__decorate([
|
|
67
|
+
(0, typeorm_1.UpdateDateColumn)({ name: 'updated_at' }),
|
|
68
|
+
__metadata("design:type", Date)
|
|
69
|
+
], Project.prototype, "updatedAt", void 0);
|
|
70
|
+
__decorate([
|
|
71
|
+
(0, typeorm_1.OneToMany)(() => task_entity_1.Task, (task) => task.project),
|
|
72
|
+
__metadata("design:type", Array)
|
|
73
|
+
], Project.prototype, "tasks", void 0);
|
|
74
|
+
__decorate([
|
|
75
|
+
(0, typeorm_1.OneToMany)(() => label_entity_1.Label, (label) => label.project),
|
|
76
|
+
__metadata("design:type", Array)
|
|
77
|
+
], Project.prototype, "labels", void 0);
|
|
78
|
+
__decorate([
|
|
79
|
+
(0, typeorm_1.OneToMany)(() => milestone_entity_1.Milestone, (milestone) => milestone.project),
|
|
80
|
+
__metadata("design:type", Array)
|
|
81
|
+
], Project.prototype, "milestones", void 0);
|
|
82
|
+
__decorate([
|
|
83
|
+
(0, typeorm_1.OneToMany)(() => sync_log_entity_1.SyncLog, (syncLog) => syncLog.project),
|
|
84
|
+
__metadata("design:type", Array)
|
|
85
|
+
], Project.prototype, "syncLogs", void 0);
|
|
86
|
+
exports.Project = Project = __decorate([
|
|
87
|
+
(0, typeorm_1.Entity)('projects'),
|
|
88
|
+
(0, typeorm_1.Unique)(['owner', 'projectNumber'])
|
|
89
|
+
], Project);
|
|
90
|
+
//# sourceMappingURL=project.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project.entity.js","sourceRoot":"","sources":["../../../src/modules/project/project.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qCAQiB;AACjB,qDAA2C;AAC3C,wDAA8C;AAC9C,oEAA0D;AAC1D,6DAAkD;AAI3C,IAAM,OAAO,GAAb,MAAM,OAAO;IAElB,EAAE,CAAS;IAGX,KAAK,CAAS;IAGd,SAAS,CAAS;IAGlB,IAAI,CAAS;IAGb,aAAa,CAAS;IAGtB,UAAU,CAAS;IAGnB,eAAe,CAAS;IAGxB,SAAS,CAAO;IAGhB,SAAS,CAAO;IAGhB,KAAK,CAAS;IAGd,MAAM,CAAU;IAGhB,UAAU,CAAc;IAGxB,QAAQ,CAAY;CACrB,CAAA;AAvCY,0BAAO;AAElB;IADC,IAAA,gCAAsB,GAAE;;mCACd;AAGX;IADC,IAAA,gBAAM,GAAE;;sCACK;AAGd;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,YAAY,EAAE,OAAO,EAAE,cAAc,EAAE,CAAC;;0CACtC;AAGlB;IADC,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;qCACd;AAGb;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE,CAAC;;8CACb;AAGtB;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC;;2CACb;AAGnB;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,mBAAmB,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;gDAC9B;AAGxB;IADC,IAAA,0BAAgB,EAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;8BAC9B,IAAI;0CAAC;AAGhB;IADC,IAAA,0BAAgB,EAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;8BAC9B,IAAI;0CAAC;AAGhB;IADC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,kBAAI,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC;;sCAChC;AAGd;IADC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,oBAAK,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC;;uCACjC;AAGhB;IADC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,4BAAS,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC;;2CACrC;AAGxB;IADC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,yBAAO,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC;;yCACnC;kBAtCT,OAAO;IAFnB,IAAA,gBAAM,EAAC,UAAU,CAAC;IAClB,IAAA,gBAAM,EAAC,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;GACtB,OAAO,CAuCnB"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.ProjectModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
12
|
+
const project_entity_1 = require("./project.entity");
|
|
13
|
+
const project_service_1 = require("./project.service");
|
|
14
|
+
const project_controller_1 = require("./project.controller");
|
|
15
|
+
let ProjectModule = class ProjectModule {
|
|
16
|
+
};
|
|
17
|
+
exports.ProjectModule = ProjectModule;
|
|
18
|
+
exports.ProjectModule = ProjectModule = __decorate([
|
|
19
|
+
(0, common_1.Global)(),
|
|
20
|
+
(0, common_1.Module)({
|
|
21
|
+
imports: [typeorm_1.TypeOrmModule.forFeature([project_entity_1.Project])],
|
|
22
|
+
controllers: [project_controller_1.ProjectController],
|
|
23
|
+
providers: [project_service_1.ProjectService],
|
|
24
|
+
exports: [project_service_1.ProjectService],
|
|
25
|
+
})
|
|
26
|
+
], ProjectModule);
|
|
27
|
+
//# sourceMappingURL=project.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project.module.js","sourceRoot":"","sources":["../../../src/modules/project/project.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAgD;AAChD,6CAAgD;AAChD,qDAA2C;AAC3C,uDAAmD;AACnD,6DAAyD;AASlD,IAAM,aAAa,GAAnB,MAAM,aAAa;CAAG,CAAA;AAAhB,sCAAa;wBAAb,aAAa;IAPzB,IAAA,eAAM,GAAE;IACR,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,uBAAa,CAAC,UAAU,CAAC,CAAC,wBAAO,CAAC,CAAC,CAAC;QAC9C,WAAW,EAAE,CAAC,sCAAiB,CAAC;QAChC,SAAS,EAAE,CAAC,gCAAc,CAAC;QAC3B,OAAO,EAAE,CAAC,gCAAc,CAAC;KAC1B,CAAC;GACW,aAAa,CAAG"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Repository } from 'typeorm';
|
|
2
|
+
import { Project } from './project.entity';
|
|
3
|
+
export declare class ProjectService {
|
|
4
|
+
private readonly projectRepo;
|
|
5
|
+
constructor(projectRepo: Repository<Project>);
|
|
6
|
+
findAll(): Promise<Project[]>;
|
|
7
|
+
findById(id: number): Promise<Project | null>;
|
|
8
|
+
findOrCreate(owner: string, projectNumber: number, extra?: Partial<Pick<Project, 'ownerType' | 'repo' | 'projectUrl'>>): Promise<Project>;
|
|
9
|
+
findByOwnerAndNumber(owner: string, projectNumber: number): Promise<Project | null>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.ProjectService = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
18
|
+
const typeorm_2 = require("typeorm");
|
|
19
|
+
const project_entity_1 = require("./project.entity");
|
|
20
|
+
let ProjectService = class ProjectService {
|
|
21
|
+
projectRepo;
|
|
22
|
+
constructor(projectRepo) {
|
|
23
|
+
this.projectRepo = projectRepo;
|
|
24
|
+
}
|
|
25
|
+
async findAll() {
|
|
26
|
+
return this.projectRepo.find({ order: { createdAt: 'DESC' } });
|
|
27
|
+
}
|
|
28
|
+
async findById(id) {
|
|
29
|
+
return this.projectRepo.findOneBy({ id });
|
|
30
|
+
}
|
|
31
|
+
async findOrCreate(owner, projectNumber, extra) {
|
|
32
|
+
const existing = await this.projectRepo.findOneBy({ owner, projectNumber });
|
|
33
|
+
if (existing) {
|
|
34
|
+
if (extra) {
|
|
35
|
+
Object.assign(existing, extra);
|
|
36
|
+
return this.projectRepo.save(existing);
|
|
37
|
+
}
|
|
38
|
+
return existing;
|
|
39
|
+
}
|
|
40
|
+
const project = this.projectRepo.create({
|
|
41
|
+
owner,
|
|
42
|
+
projectNumber,
|
|
43
|
+
projectUrl: extra?.projectUrl ?? '',
|
|
44
|
+
ownerType: extra?.ownerType ?? 'organization',
|
|
45
|
+
repo: extra?.repo ?? undefined,
|
|
46
|
+
});
|
|
47
|
+
return this.projectRepo.save(project);
|
|
48
|
+
}
|
|
49
|
+
async findByOwnerAndNumber(owner, projectNumber) {
|
|
50
|
+
return this.projectRepo.findOneBy({ owner, projectNumber });
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
exports.ProjectService = ProjectService;
|
|
54
|
+
exports.ProjectService = ProjectService = __decorate([
|
|
55
|
+
(0, common_1.Injectable)(),
|
|
56
|
+
__param(0, (0, typeorm_1.InjectRepository)(project_entity_1.Project)),
|
|
57
|
+
__metadata("design:paramtypes", [typeorm_2.Repository])
|
|
58
|
+
], ProjectService);
|
|
59
|
+
//# sourceMappingURL=project.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project.service.js","sourceRoot":"","sources":["../../../src/modules/project/project.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA4C;AAC5C,6CAAmD;AACnD,qCAAqC;AACrC,qDAA2C;AAGpC,IAAM,cAAc,GAApB,MAAM,cAAc;IAGN;IAFnB,YAEmB,WAAgC;QAAhC,gBAAW,GAAX,WAAW,CAAqB;IAChD,CAAC;IAEJ,KAAK,CAAC,OAAO;QACX,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC;IACjE,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,EAAU;QACvB,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;IAC5C,CAAC;IAED,KAAK,CAAC,YAAY,CAChB,KAAa,EACb,aAAqB,EACrB,KAAmE;QAEnE,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC,CAAC;QAC5E,IAAI,QAAQ,EAAE,CAAC;YACb,IAAI,KAAK,EAAE,CAAC;gBACV,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;gBAC/B,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACzC,CAAC;YACD,OAAO,QAAQ,CAAC;QAClB,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;YACtC,KAAK;YACL,aAAa;YACb,UAAU,EAAE,KAAK,EAAE,UAAU,IAAI,EAAE;YACnC,SAAS,EAAE,KAAK,EAAE,SAAS,IAAI,cAAc;YAC7C,IAAI,EAAE,KAAK,EAAE,IAAI,IAAI,SAAS;SAC/B,CAAC,CAAC;QACH,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IAED,KAAK,CAAC,oBAAoB,CAAC,KAAa,EAAE,aAAqB;QAC7D,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC,CAAC;IAC9D,CAAC;CACF,CAAA;AAzCY,wCAAc;yBAAd,cAAc;IAD1B,IAAA,mBAAU,GAAE;IAGR,WAAA,IAAA,0BAAgB,EAAC,wBAAO,CAAC,CAAA;qCACI,oBAAU;GAH/B,cAAc,CAyC1B"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
interface ProjectItem {
|
|
2
|
+
id: string;
|
|
3
|
+
content: {
|
|
4
|
+
__typename: string;
|
|
5
|
+
title?: string;
|
|
6
|
+
body?: string;
|
|
7
|
+
updatedAt?: string;
|
|
8
|
+
labels?: {
|
|
9
|
+
nodes: {
|
|
10
|
+
name: string;
|
|
11
|
+
color: string;
|
|
12
|
+
}[];
|
|
13
|
+
};
|
|
14
|
+
assignees?: {
|
|
15
|
+
nodes: {
|
|
16
|
+
login: string;
|
|
17
|
+
}[];
|
|
18
|
+
};
|
|
19
|
+
milestone?: {
|
|
20
|
+
title: string;
|
|
21
|
+
} | null;
|
|
22
|
+
} | null;
|
|
23
|
+
fieldValues: {
|
|
24
|
+
nodes: Array<{
|
|
25
|
+
name?: string;
|
|
26
|
+
text?: string;
|
|
27
|
+
field?: {
|
|
28
|
+
name: string;
|
|
29
|
+
};
|
|
30
|
+
}>;
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
interface ProjectItemsResponse {
|
|
34
|
+
items: ProjectItem[];
|
|
35
|
+
projectId: string;
|
|
36
|
+
hasNextPage: boolean;
|
|
37
|
+
endCursor: string | null;
|
|
38
|
+
}
|
|
39
|
+
export declare class GitHubService {
|
|
40
|
+
private getToken;
|
|
41
|
+
private getGraphqlClient;
|
|
42
|
+
getProjectId(owner: string, ownerType: string, projectNumber: number): Promise<string>;
|
|
43
|
+
getProjectItems(owner: string, ownerType: string, projectNumber: number, cursor?: string): Promise<ProjectItemsResponse>;
|
|
44
|
+
getAllProjectItems(owner: string, ownerType: string, projectNumber: number): Promise<{
|
|
45
|
+
items: ProjectItem[];
|
|
46
|
+
projectId: string;
|
|
47
|
+
}>;
|
|
48
|
+
getProjectFields(owner: string, ownerType: string, projectNumber: number): Promise<{
|
|
49
|
+
statusFieldId: string;
|
|
50
|
+
statusOptions: {
|
|
51
|
+
id: string;
|
|
52
|
+
name: string;
|
|
53
|
+
}[];
|
|
54
|
+
}>;
|
|
55
|
+
addDraftIssue(projectId: string, title: string, body?: string): Promise<{
|
|
56
|
+
itemId: string;
|
|
57
|
+
}>;
|
|
58
|
+
updateFieldValue(projectId: string, itemId: string, fieldId: string, singleSelectOptionId: string): Promise<void>;
|
|
59
|
+
deleteItem(projectId: string, itemId: string): Promise<void>;
|
|
60
|
+
}
|
|
61
|
+
export {};
|
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.GitHubService = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const graphql_1 = require("@octokit/graphql");
|
|
12
|
+
const child_process_1 = require("child_process");
|
|
13
|
+
let GitHubService = class GitHubService {
|
|
14
|
+
getToken() {
|
|
15
|
+
try {
|
|
16
|
+
return (0, child_process_1.execSync)('gh auth token', { encoding: 'utf-8' }).trim();
|
|
17
|
+
}
|
|
18
|
+
catch {
|
|
19
|
+
throw new Error('GitHub CLI 인증이 필요합니다. gh auth login을 실행하세요.');
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
getGraphqlClient() {
|
|
23
|
+
const token = this.getToken();
|
|
24
|
+
return graphql_1.graphql.defaults({
|
|
25
|
+
headers: { authorization: `token ${token}` },
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
async getProjectId(owner, ownerType, projectNumber) {
|
|
29
|
+
const gql = this.getGraphqlClient();
|
|
30
|
+
const ownerField = ownerType === 'organization' ? 'organization' : 'user';
|
|
31
|
+
const query = `
|
|
32
|
+
query GetProjectId($owner: String!, $number: Int!) {
|
|
33
|
+
${ownerField}(login: $owner) {
|
|
34
|
+
projectV2(number: $number) { id }
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
`;
|
|
38
|
+
const result = await gql(query, { owner, number: projectNumber });
|
|
39
|
+
return result[ownerField].projectV2.id;
|
|
40
|
+
}
|
|
41
|
+
async getProjectItems(owner, ownerType, projectNumber, cursor) {
|
|
42
|
+
const gql = this.getGraphqlClient();
|
|
43
|
+
const ownerField = ownerType === 'organization' ? 'organization' : 'user';
|
|
44
|
+
const query = `
|
|
45
|
+
query GetProjectItems($owner: String!, $number: Int!, $cursor: String) {
|
|
46
|
+
${ownerField}(login: $owner) {
|
|
47
|
+
projectV2(number: $number) {
|
|
48
|
+
id
|
|
49
|
+
items(first: 100, after: $cursor) {
|
|
50
|
+
pageInfo {
|
|
51
|
+
hasNextPage
|
|
52
|
+
endCursor
|
|
53
|
+
}
|
|
54
|
+
nodes {
|
|
55
|
+
id
|
|
56
|
+
content {
|
|
57
|
+
__typename
|
|
58
|
+
... on DraftIssue {
|
|
59
|
+
title
|
|
60
|
+
body
|
|
61
|
+
updatedAt
|
|
62
|
+
}
|
|
63
|
+
... on Issue {
|
|
64
|
+
title
|
|
65
|
+
body
|
|
66
|
+
updatedAt
|
|
67
|
+
labels(first: 20) {
|
|
68
|
+
nodes { name color }
|
|
69
|
+
}
|
|
70
|
+
assignees(first: 10) {
|
|
71
|
+
nodes { login }
|
|
72
|
+
}
|
|
73
|
+
milestone { title }
|
|
74
|
+
}
|
|
75
|
+
... on PullRequest {
|
|
76
|
+
title
|
|
77
|
+
body
|
|
78
|
+
updatedAt
|
|
79
|
+
labels(first: 20) {
|
|
80
|
+
nodes { name color }
|
|
81
|
+
}
|
|
82
|
+
assignees(first: 10) {
|
|
83
|
+
nodes { login }
|
|
84
|
+
}
|
|
85
|
+
milestone { title }
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
fieldValues(first: 20) {
|
|
89
|
+
nodes {
|
|
90
|
+
... on ProjectV2ItemFieldSingleSelectValue {
|
|
91
|
+
name
|
|
92
|
+
field { ... on ProjectV2SingleSelectField { name } }
|
|
93
|
+
}
|
|
94
|
+
... on ProjectV2ItemFieldTextValue {
|
|
95
|
+
text
|
|
96
|
+
field { ... on ProjectV2FieldCommon { name } }
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
`;
|
|
106
|
+
const result = await gql(query, {
|
|
107
|
+
owner,
|
|
108
|
+
number: projectNumber,
|
|
109
|
+
cursor: cursor || null,
|
|
110
|
+
});
|
|
111
|
+
const project = result[ownerField].projectV2;
|
|
112
|
+
return {
|
|
113
|
+
projectId: project.id,
|
|
114
|
+
items: project.items.nodes,
|
|
115
|
+
hasNextPage: project.items.pageInfo.hasNextPage,
|
|
116
|
+
endCursor: project.items.pageInfo.endCursor,
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
async getAllProjectItems(owner, ownerType, projectNumber) {
|
|
120
|
+
const allItems = [];
|
|
121
|
+
let cursor;
|
|
122
|
+
let projectId = '';
|
|
123
|
+
do {
|
|
124
|
+
const result = await this.getProjectItems(owner, ownerType, projectNumber, cursor);
|
|
125
|
+
projectId = result.projectId;
|
|
126
|
+
allItems.push(...result.items);
|
|
127
|
+
cursor = result.hasNextPage ? (result.endCursor ?? undefined) : undefined;
|
|
128
|
+
} while (cursor);
|
|
129
|
+
return { items: allItems, projectId };
|
|
130
|
+
}
|
|
131
|
+
async getProjectFields(owner, ownerType, projectNumber) {
|
|
132
|
+
const gql = this.getGraphqlClient();
|
|
133
|
+
const ownerField = ownerType === 'organization' ? 'organization' : 'user';
|
|
134
|
+
const query = `
|
|
135
|
+
query GetProjectFields($owner: String!, $number: Int!) {
|
|
136
|
+
${ownerField}(login: $owner) {
|
|
137
|
+
projectV2(number: $number) {
|
|
138
|
+
fields(first: 50) {
|
|
139
|
+
nodes {
|
|
140
|
+
... on ProjectV2SingleSelectField {
|
|
141
|
+
id
|
|
142
|
+
name
|
|
143
|
+
options { id name }
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
`;
|
|
151
|
+
const result = await gql(query, { owner, number: projectNumber });
|
|
152
|
+
const fields = result[ownerField].projectV2.fields.nodes;
|
|
153
|
+
const statusField = fields.find((f) => f.name === 'Status' && f.options);
|
|
154
|
+
if (!statusField) {
|
|
155
|
+
throw new Error('Status field not found in GitHub Project');
|
|
156
|
+
}
|
|
157
|
+
return {
|
|
158
|
+
statusFieldId: statusField.id,
|
|
159
|
+
statusOptions: statusField.options,
|
|
160
|
+
};
|
|
161
|
+
}
|
|
162
|
+
async addDraftIssue(projectId, title, body) {
|
|
163
|
+
const gql = this.getGraphqlClient();
|
|
164
|
+
const mutation = `
|
|
165
|
+
mutation AddDraftIssue($projectId: ID!, $title: String!, $body: String) {
|
|
166
|
+
addProjectV2DraftIssue(input: {
|
|
167
|
+
projectId: $projectId
|
|
168
|
+
title: $title
|
|
169
|
+
body: $body
|
|
170
|
+
}) {
|
|
171
|
+
projectItem { id }
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
`;
|
|
175
|
+
const result = await gql(mutation, { projectId, title, body: body || null });
|
|
176
|
+
return { itemId: result.addProjectV2DraftIssue.projectItem.id };
|
|
177
|
+
}
|
|
178
|
+
async updateFieldValue(projectId, itemId, fieldId, singleSelectOptionId) {
|
|
179
|
+
const gql = this.getGraphqlClient();
|
|
180
|
+
const mutation = `
|
|
181
|
+
mutation UpdateFieldValue($projectId: ID!, $itemId: ID!, $fieldId: ID!, $optionId: String!) {
|
|
182
|
+
updateProjectV2ItemFieldValue(input: {
|
|
183
|
+
projectId: $projectId
|
|
184
|
+
itemId: $itemId
|
|
185
|
+
fieldId: $fieldId
|
|
186
|
+
value: { singleSelectOptionId: $optionId }
|
|
187
|
+
}) {
|
|
188
|
+
projectV2Item { id }
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
`;
|
|
192
|
+
await gql(mutation, { projectId, itemId, fieldId, optionId: singleSelectOptionId });
|
|
193
|
+
}
|
|
194
|
+
async deleteItem(projectId, itemId) {
|
|
195
|
+
const gql = this.getGraphqlClient();
|
|
196
|
+
const mutation = `
|
|
197
|
+
mutation DeleteItem($projectId: ID!, $itemId: ID!) {
|
|
198
|
+
deleteProjectV2Item(input: {
|
|
199
|
+
projectId: $projectId
|
|
200
|
+
itemId: $itemId
|
|
201
|
+
}) {
|
|
202
|
+
deletedItemId
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
`;
|
|
206
|
+
await gql(mutation, { projectId, itemId });
|
|
207
|
+
}
|
|
208
|
+
};
|
|
209
|
+
exports.GitHubService = GitHubService;
|
|
210
|
+
exports.GitHubService = GitHubService = __decorate([
|
|
211
|
+
(0, common_1.Injectable)()
|
|
212
|
+
], GitHubService);
|
|
213
|
+
//# sourceMappingURL=github.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"github.service.js","sourceRoot":"","sources":["../../../src/modules/sync/github.service.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAA4C;AAC5C,8CAA2C;AAC3C,iDAAyC;AA8BlC,IAAM,aAAa,GAAnB,MAAM,aAAa;IAChB,QAAQ;QACd,IAAI,CAAC;YACH,OAAO,IAAA,wBAAQ,EAAC,eAAe,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;QACjE,CAAC;QAAC,MAAM,CAAC;YACP,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;QACjE,CAAC;IACH,CAAC;IAEO,gBAAgB;QACtB,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC9B,OAAO,iBAAO,CAAC,QAAQ,CAAC;YACtB,OAAO,EAAE,EAAE,aAAa,EAAE,SAAS,KAAK,EAAE,EAAE;SAC7C,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,YAAY,CAChB,KAAa,EACb,SAAiB,EACjB,aAAqB;QAErB,MAAM,GAAG,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACpC,MAAM,UAAU,GAAG,SAAS,KAAK,cAAc,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,MAAM,CAAC;QAE1E,MAAM,KAAK,GAAG;;UAER,UAAU;;;;KAIf,CAAC;QAEF,MAAM,MAAM,GAAQ,MAAM,GAAG,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,aAAa,EAAE,CAAC,CAAC;QACvE,OAAO,MAAM,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC;IACzC,CAAC;IAED,KAAK,CAAC,eAAe,CACnB,KAAa,EACb,SAAiB,EACjB,aAAqB,EACrB,MAAe;QAEf,MAAM,GAAG,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAEpC,MAAM,UAAU,GAAG,SAAS,KAAK,cAAc,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,MAAM,CAAC;QAE1E,MAAM,KAAK,GAAG;;UAER,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA2Df,CAAC;QAEF,MAAM,MAAM,GAAQ,MAAM,GAAG,CAAC,KAAK,EAAE;YACnC,KAAK;YACL,MAAM,EAAE,aAAa;YACrB,MAAM,EAAE,MAAM,IAAI,IAAI;SACvB,CAAC,CAAC;QAEH,MAAM,OAAO,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC;QAE7C,OAAO;YACL,SAAS,EAAE,OAAO,CAAC,EAAE;YACrB,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,KAAK;YAC1B,WAAW,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,WAAW;YAC/C,SAAS,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,SAAS;SAC5C,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,kBAAkB,CACtB,KAAa,EACb,SAAiB,EACjB,aAAqB;QAErB,MAAM,QAAQ,GAAkB,EAAE,CAAC;QACnC,IAAI,MAA0B,CAAC;QAC/B,IAAI,SAAS,GAAG,EAAE,CAAC;QAEnB,GAAG,CAAC;YACF,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,CAAC,CAAC;YACnF,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC;YAC7B,QAAQ,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;YAC/B,MAAM,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAC5E,CAAC,QAAQ,MAAM,EAAE;QAEjB,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IACxC,CAAC;IAED,KAAK,CAAC,gBAAgB,CACpB,KAAa,EACb,SAAiB,EACjB,aAAqB;QAErB,MAAM,GAAG,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACpC,MAAM,UAAU,GAAG,SAAS,KAAK,cAAc,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,MAAM,CAAC;QAE1E,MAAM,KAAK,GAAG;;UAER,UAAU;;;;;;;;;;;;;;KAcf,CAAC;QAEF,MAAM,MAAM,GAAQ,MAAM,GAAG,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,aAAa,EAAE,CAAC,CAAC;QACvE,MAAM,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC;QACzD,MAAM,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC;QAE9E,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;QAC9D,CAAC;QAED,OAAO;YACL,aAAa,EAAE,WAAW,CAAC,EAAE;YAC7B,aAAa,EAAE,WAAW,CAAC,OAAO;SACnC,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,aAAa,CACjB,SAAiB,EACjB,KAAa,EACb,IAAa;QAEb,MAAM,GAAG,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAEpC,MAAM,QAAQ,GAAG;;;;;;;;;;KAUhB,CAAC;QAEF,MAAM,MAAM,GAAQ,MAAM,GAAG,CAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,IAAI,IAAI,EAAE,CAAC,CAAC;QAClF,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,sBAAsB,CAAC,WAAW,CAAC,EAAE,EAAE,CAAC;IAClE,CAAC;IAED,KAAK,CAAC,gBAAgB,CACpB,SAAiB,EACjB,MAAc,EACd,OAAe,EACf,oBAA4B;QAE5B,MAAM,GAAG,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAEpC,MAAM,QAAQ,GAAG;;;;;;;;;;;KAWhB,CAAC;QAEF,MAAM,GAAG,CAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,oBAAoB,EAAE,CAAC,CAAC;IACtF,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,SAAiB,EAAE,MAAc;QAChD,MAAM,GAAG,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAEpC,MAAM,QAAQ,GAAG;;;;;;;;;KAShB,CAAC;QAEF,MAAM,GAAG,CAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAC;IAC7C,CAAC;CACF,CAAA;AAvPY,sCAAa;wBAAb,aAAa;IADzB,IAAA,mBAAU,GAAE;GACA,aAAa,CAuPzB"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.SyncLog = void 0;
|
|
13
|
+
const typeorm_1 = require("typeorm");
|
|
14
|
+
const project_entity_1 = require("../project/project.entity");
|
|
15
|
+
let SyncLog = class SyncLog {
|
|
16
|
+
id;
|
|
17
|
+
projectId;
|
|
18
|
+
project;
|
|
19
|
+
syncedAt;
|
|
20
|
+
direction;
|
|
21
|
+
itemsSynced;
|
|
22
|
+
status;
|
|
23
|
+
errorMessage;
|
|
24
|
+
};
|
|
25
|
+
exports.SyncLog = SyncLog;
|
|
26
|
+
__decorate([
|
|
27
|
+
(0, typeorm_1.PrimaryGeneratedColumn)(),
|
|
28
|
+
__metadata("design:type", Number)
|
|
29
|
+
], SyncLog.prototype, "id", void 0);
|
|
30
|
+
__decorate([
|
|
31
|
+
(0, typeorm_1.Column)({ name: 'project_id' }),
|
|
32
|
+
__metadata("design:type", Number)
|
|
33
|
+
], SyncLog.prototype, "projectId", void 0);
|
|
34
|
+
__decorate([
|
|
35
|
+
(0, typeorm_1.ManyToOne)(() => project_entity_1.Project, (project) => project.syncLogs, { onDelete: 'CASCADE' }),
|
|
36
|
+
(0, typeorm_1.JoinColumn)({ name: 'project_id' }),
|
|
37
|
+
__metadata("design:type", project_entity_1.Project)
|
|
38
|
+
], SyncLog.prototype, "project", void 0);
|
|
39
|
+
__decorate([
|
|
40
|
+
(0, typeorm_1.CreateDateColumn)({ name: 'synced_at' }),
|
|
41
|
+
__metadata("design:type", Date)
|
|
42
|
+
], SyncLog.prototype, "syncedAt", void 0);
|
|
43
|
+
__decorate([
|
|
44
|
+
(0, typeorm_1.Column)(),
|
|
45
|
+
__metadata("design:type", String)
|
|
46
|
+
], SyncLog.prototype, "direction", void 0);
|
|
47
|
+
__decorate([
|
|
48
|
+
(0, typeorm_1.Column)({ name: 'items_synced', default: 0 }),
|
|
49
|
+
__metadata("design:type", Number)
|
|
50
|
+
], SyncLog.prototype, "itemsSynced", void 0);
|
|
51
|
+
__decorate([
|
|
52
|
+
(0, typeorm_1.Column)(),
|
|
53
|
+
__metadata("design:type", String)
|
|
54
|
+
], SyncLog.prototype, "status", void 0);
|
|
55
|
+
__decorate([
|
|
56
|
+
(0, typeorm_1.Column)({ name: 'error_message', nullable: true }),
|
|
57
|
+
__metadata("design:type", String)
|
|
58
|
+
], SyncLog.prototype, "errorMessage", void 0);
|
|
59
|
+
exports.SyncLog = SyncLog = __decorate([
|
|
60
|
+
(0, typeorm_1.Entity)('sync_log')
|
|
61
|
+
], SyncLog);
|
|
62
|
+
//# sourceMappingURL=sync-log.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sync-log.entity.js","sourceRoot":"","sources":["../../../src/modules/sync/sync-log.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qCAOiB;AACjB,8DAAoD;AAG7C,IAAM,OAAO,GAAb,MAAM,OAAO;IAElB,EAAE,CAAS;IAGX,SAAS,CAAS;IAIlB,OAAO,CAAU;IAGjB,QAAQ,CAAO;IAGf,SAAS,CAAS;IAGlB,WAAW,CAAS;IAGpB,MAAM,CAAS;IAGf,YAAY,CAAS;CACtB,CAAA;AAzBY,0BAAO;AAElB;IADC,IAAA,gCAAsB,GAAE;;mCACd;AAGX;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;;0CACb;AAIlB;IAFC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,wBAAO,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IAChF,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;8BAC1B,wBAAO;wCAAC;AAGjB;IADC,IAAA,0BAAgB,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;8BAC9B,IAAI;yCAAC;AAGf;IADC,IAAA,gBAAM,GAAE;;0CACS;AAGlB;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,cAAc,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;;4CACzB;AAGpB;IADC,IAAA,gBAAM,GAAE;;uCACM;AAGf;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,eAAe,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;6CAC7B;kBAxBV,OAAO;IADnB,IAAA,gBAAM,EAAC,UAAU,CAAC;GACN,OAAO,CAyBnB"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Request } from 'express';
|
|
2
|
+
import { SyncService, SyncResult } from './sync.service';
|
|
3
|
+
export declare class SyncController {
|
|
4
|
+
private readonly syncService;
|
|
5
|
+
constructor(syncService: SyncService);
|
|
6
|
+
private getProject;
|
|
7
|
+
pull(req: Request): Promise<SyncResult>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.SyncController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const sync_service_1 = require("./sync.service");
|
|
18
|
+
let SyncController = class SyncController {
|
|
19
|
+
syncService;
|
|
20
|
+
constructor(syncService) {
|
|
21
|
+
this.syncService = syncService;
|
|
22
|
+
}
|
|
23
|
+
getProject(req) {
|
|
24
|
+
return req.project;
|
|
25
|
+
}
|
|
26
|
+
async pull(req) {
|
|
27
|
+
const project = this.getProject(req);
|
|
28
|
+
return this.syncService.pullSync(project.id);
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
exports.SyncController = SyncController;
|
|
32
|
+
__decorate([
|
|
33
|
+
(0, common_1.Post)('pull'),
|
|
34
|
+
__param(0, (0, common_1.Req)()),
|
|
35
|
+
__metadata("design:type", Function),
|
|
36
|
+
__metadata("design:paramtypes", [Object]),
|
|
37
|
+
__metadata("design:returntype", Promise)
|
|
38
|
+
], SyncController.prototype, "pull", null);
|
|
39
|
+
exports.SyncController = SyncController = __decorate([
|
|
40
|
+
(0, common_1.Controller)('sync'),
|
|
41
|
+
__metadata("design:paramtypes", [sync_service_1.SyncService])
|
|
42
|
+
], SyncController);
|
|
43
|
+
//# sourceMappingURL=sync.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sync.controller.js","sourceRoot":"","sources":["../../../src/modules/sync/sync.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA4D;AAE5D,iDAAyD;AAIlD,IAAM,cAAc,GAApB,MAAM,cAAc;IACI;IAA7B,YAA6B,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;IAAG,CAAC;IAEjD,UAAU,CAAC,GAAY;QAC7B,OAAQ,GAAW,CAAC,OAAO,CAAC;IAC9B,CAAC;IAGK,AAAN,KAAK,CAAC,IAAI,CAAQ,GAAY;QAC5B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;QACrC,OAAO,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC/C,CAAC;CACF,CAAA;AAZY,wCAAc;AAQnB;IADL,IAAA,aAAI,EAAC,MAAM,CAAC;IACD,WAAA,IAAA,YAAG,GAAE,CAAA;;;;0CAGhB;yBAXU,cAAc;IAD1B,IAAA,mBAAU,EAAC,MAAM,CAAC;qCAEyB,0BAAW;GAD1C,cAAc,CAY1B"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.SyncModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
12
|
+
const sync_log_entity_1 = require("./sync-log.entity");
|
|
13
|
+
const task_entity_1 = require("../task/task.entity");
|
|
14
|
+
const github_service_1 = require("./github.service");
|
|
15
|
+
const sync_service_1 = require("./sync.service");
|
|
16
|
+
const sync_controller_1 = require("./sync.controller");
|
|
17
|
+
let SyncModule = class SyncModule {
|
|
18
|
+
};
|
|
19
|
+
exports.SyncModule = SyncModule;
|
|
20
|
+
exports.SyncModule = SyncModule = __decorate([
|
|
21
|
+
(0, common_1.Module)({
|
|
22
|
+
imports: [typeorm_1.TypeOrmModule.forFeature([sync_log_entity_1.SyncLog, task_entity_1.Task])],
|
|
23
|
+
controllers: [sync_controller_1.SyncController],
|
|
24
|
+
providers: [github_service_1.GitHubService, sync_service_1.SyncService],
|
|
25
|
+
exports: [sync_service_1.SyncService, github_service_1.GitHubService],
|
|
26
|
+
})
|
|
27
|
+
], SyncModule);
|
|
28
|
+
//# sourceMappingURL=sync.module.js.map
|