github-issue-tower-defence-management 1.24.0 → 1.26.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/.github/workflows/test.yml +2 -2
- package/CHANGELOG.md +15 -0
- package/bin/adapter/repositories/GraphqlProjectRepository.js +12 -0
- package/bin/adapter/repositories/GraphqlProjectRepository.js.map +1 -1
- package/bin/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.js +9 -0
- package/bin/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.js.map +1 -1
- package/bin/adapter/repositories/issue/GraphqlProjectItemRepository.js +5 -1
- package/bin/adapter/repositories/issue/GraphqlProjectItemRepository.js.map +1 -1
- package/bin/domain/entities/ClaudeWindowUsage.js +3 -0
- package/bin/domain/entities/ClaudeWindowUsage.js.map +1 -0
- package/bin/domain/entities/Comment.js +3 -0
- package/bin/domain/entities/Comment.js.map +1 -0
- package/bin/domain/usecases/NotifyFinishedIssuePreparationUseCase.js +81 -0
- package/bin/domain/usecases/NotifyFinishedIssuePreparationUseCase.js.map +1 -0
- package/bin/domain/usecases/StartPreparationUseCase.js +104 -0
- package/bin/domain/usecases/StartPreparationUseCase.js.map +1 -0
- package/bin/domain/usecases/adapter-interfaces/ClaudeRepository.js +3 -0
- package/bin/domain/usecases/adapter-interfaces/ClaudeRepository.js.map +1 -0
- package/bin/domain/usecases/adapter-interfaces/IssueCommentRepository.js +3 -0
- package/bin/domain/usecases/adapter-interfaces/IssueCommentRepository.js.map +1 -0
- package/bin/domain/usecases/adapter-interfaces/LocalCommandRunner.js +3 -0
- package/bin/domain/usecases/adapter-interfaces/LocalCommandRunner.js.map +1 -0
- package/package.json +1 -1
- package/src/adapter/repositories/CheerioProjectRepository.test.ts +1 -0
- package/src/adapter/repositories/GraphqlProjectRepository.test.ts +1 -0
- package/src/adapter/repositories/GraphqlProjectRepository.ts +14 -1
- package/src/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.test.ts +1 -0
- package/src/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.ts +15 -1
- package/src/adapter/repositories/issue/GraphqlProjectItemRepository.test.ts +162 -34
- package/src/adapter/repositories/issue/GraphqlProjectItemRepository.ts +6 -0
- package/src/domain/entities/ClaudeWindowUsage.ts +5 -0
- package/src/domain/entities/Comment.ts +5 -0
- package/src/domain/entities/Project.ts +1 -0
- package/src/domain/usecases/GetStoryObjectMapUseCase.test.ts +1 -0
- package/src/domain/usecases/NotifyFinishedIssuePreparationUseCase.test.ts +669 -0
- package/src/domain/usecases/NotifyFinishedIssuePreparationUseCase.ts +132 -0
- package/src/domain/usecases/StartPreparationUseCase.test.ts +716 -0
- package/src/domain/usecases/StartPreparationUseCase.ts +191 -0
- package/src/domain/usecases/adapter-interfaces/ClaudeRepository.ts +5 -0
- package/src/domain/usecases/adapter-interfaces/IssueCommentRepository.ts +7 -0
- package/src/domain/usecases/adapter-interfaces/IssueRepository.ts +11 -0
- package/src/domain/usecases/adapter-interfaces/LocalCommandRunner.ts +7 -0
- package/src/domain/usecases/adapter-interfaces/ProjectRepository.ts +1 -0
- package/types/adapter/repositories/GraphqlProjectRepository.d.ts +2 -1
- package/types/adapter/repositories/GraphqlProjectRepository.d.ts.map +1 -1
- package/types/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.d.ts +4 -1
- package/types/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.d.ts.map +1 -1
- package/types/adapter/repositories/issue/GraphqlProjectItemRepository.d.ts +1 -0
- package/types/adapter/repositories/issue/GraphqlProjectItemRepository.d.ts.map +1 -1
- package/types/domain/entities/ClaudeWindowUsage.d.ts +6 -0
- package/types/domain/entities/ClaudeWindowUsage.d.ts.map +1 -0
- package/types/domain/entities/Comment.d.ts +6 -0
- package/types/domain/entities/Comment.d.ts.map +1 -0
- package/types/domain/entities/Project.d.ts +1 -0
- package/types/domain/entities/Project.d.ts.map +1 -1
- package/types/domain/usecases/NotifyFinishedIssuePreparationUseCase.d.ts +24 -0
- package/types/domain/usecases/NotifyFinishedIssuePreparationUseCase.d.ts.map +1 -0
- package/types/domain/usecases/StartPreparationUseCase.d.ts +37 -0
- package/types/domain/usecases/StartPreparationUseCase.d.ts.map +1 -0
- package/types/domain/usecases/adapter-interfaces/ClaudeRepository.d.ts +5 -0
- package/types/domain/usecases/adapter-interfaces/ClaudeRepository.d.ts.map +1 -0
- package/types/domain/usecases/adapter-interfaces/IssueCommentRepository.d.ts +7 -0
- package/types/domain/usecases/adapter-interfaces/IssueCommentRepository.d.ts.map +1 -0
- package/types/domain/usecases/adapter-interfaces/IssueRepository.d.ts +10 -0
- package/types/domain/usecases/adapter-interfaces/IssueRepository.d.ts.map +1 -1
- package/types/domain/usecases/adapter-interfaces/LocalCommandRunner.d.ts +8 -0
- package/types/domain/usecases/adapter-interfaces/LocalCommandRunner.d.ts.map +1 -0
- package/types/domain/usecases/adapter-interfaces/ProjectRepository.d.ts +1 -0
- package/types/domain/usecases/adapter-interfaces/ProjectRepository.d.ts.map +1 -1
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
import { Issue } from '../entities/Issue';
|
|
2
|
+
import { Project, StoryOption } from '../entities/Project';
|
|
3
|
+
import { IssueRepository } from './adapter-interfaces/IssueRepository';
|
|
4
|
+
import { ProjectRepository } from './adapter-interfaces/ProjectRepository';
|
|
5
|
+
import { LocalCommandRunner } from './adapter-interfaces/LocalCommandRunner';
|
|
6
|
+
import { ClaudeRepository } from './adapter-interfaces/ClaudeRepository';
|
|
7
|
+
|
|
8
|
+
export type StoryObject = {
|
|
9
|
+
story: StoryOption;
|
|
10
|
+
storyIssue: Issue | null;
|
|
11
|
+
issues: Issue[];
|
|
12
|
+
};
|
|
13
|
+
export type StoryObjectMap = Map<
|
|
14
|
+
NonNullable<Project['story']>['stories'][0]['name'],
|
|
15
|
+
StoryObject
|
|
16
|
+
>;
|
|
17
|
+
|
|
18
|
+
export class StartPreparationUseCase {
|
|
19
|
+
constructor(
|
|
20
|
+
readonly projectRepository: Pick<
|
|
21
|
+
ProjectRepository,
|
|
22
|
+
'findProjectIdByUrl' | 'getProject'
|
|
23
|
+
>,
|
|
24
|
+
readonly issueRepository: Pick<
|
|
25
|
+
IssueRepository,
|
|
26
|
+
'getAllIssues' | 'updateStatus'
|
|
27
|
+
>,
|
|
28
|
+
readonly claudeRepository: Pick<ClaudeRepository, 'getUsage'>,
|
|
29
|
+
readonly localCommandRunner: LocalCommandRunner,
|
|
30
|
+
) {}
|
|
31
|
+
|
|
32
|
+
run = async (params: {
|
|
33
|
+
projectUrl: string;
|
|
34
|
+
awaitingWorkspaceStatus: string;
|
|
35
|
+
preparationStatus: string;
|
|
36
|
+
defaultAgentName: string;
|
|
37
|
+
logFilePath?: string;
|
|
38
|
+
maximumPreparingIssuesCount: number | null;
|
|
39
|
+
allowIssueCacheMinutes: number;
|
|
40
|
+
}): Promise<void> => {
|
|
41
|
+
try {
|
|
42
|
+
const claudeUsages = await this.claudeRepository.getUsage();
|
|
43
|
+
if (claudeUsages.some((usage) => usage.utilizationPercentage > 90)) {
|
|
44
|
+
console.warn(
|
|
45
|
+
'Claude usage limit exceeded. Skipping starting preparation.',
|
|
46
|
+
);
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
} catch (error) {
|
|
50
|
+
console.warn('Failed to check Claude usage:', error);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
const maximumPreparingIssuesCount = params.maximumPreparingIssuesCount ?? 6;
|
|
54
|
+
const projectId = await this.projectRepository.findProjectIdByUrl(
|
|
55
|
+
params.projectUrl,
|
|
56
|
+
);
|
|
57
|
+
if (!projectId) {
|
|
58
|
+
throw new Error(`Project not found. projectUrl: ${params.projectUrl}`);
|
|
59
|
+
}
|
|
60
|
+
const project = await this.projectRepository.getProject(projectId);
|
|
61
|
+
if (!project) {
|
|
62
|
+
throw new Error(
|
|
63
|
+
`Project not found. projectId: ${projectId} projectUrl: ${params.projectUrl}`,
|
|
64
|
+
);
|
|
65
|
+
}
|
|
66
|
+
const { issues }: { issues: Issue[] } =
|
|
67
|
+
await this.issueRepository.getAllIssues(
|
|
68
|
+
projectId,
|
|
69
|
+
params.allowIssueCacheMinutes,
|
|
70
|
+
);
|
|
71
|
+
const storyObjectMap: StoryObjectMap = this.createStoryObjectMap({
|
|
72
|
+
project,
|
|
73
|
+
issues,
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
const repositoryBlockerIssues =
|
|
77
|
+
this.createWorkflowBlockerIssues(storyObjectMap);
|
|
78
|
+
|
|
79
|
+
const awaitingWorkspaceIssues: Issue[] = Array.from(storyObjectMap.values())
|
|
80
|
+
.map((storyObject: StoryObject) => storyObject.issues)
|
|
81
|
+
.flat()
|
|
82
|
+
.filter(
|
|
83
|
+
(issue: Issue) => issue.status === params.awaitingWorkspaceStatus,
|
|
84
|
+
);
|
|
85
|
+
const currentPreparationIssueCount = issues.filter(
|
|
86
|
+
(issue: Issue) => issue.status === params.preparationStatus,
|
|
87
|
+
).length;
|
|
88
|
+
let updatedCurrentPreparationIssueCount = currentPreparationIssueCount;
|
|
89
|
+
|
|
90
|
+
const preparationStatusOption = project.status.statuses.find(
|
|
91
|
+
(s) => s.name === params.preparationStatus,
|
|
92
|
+
);
|
|
93
|
+
|
|
94
|
+
for (
|
|
95
|
+
let i = 0;
|
|
96
|
+
i < awaitingWorkspaceIssues.length &&
|
|
97
|
+
updatedCurrentPreparationIssueCount < maximumPreparingIssuesCount;
|
|
98
|
+
i++
|
|
99
|
+
) {
|
|
100
|
+
const issue = awaitingWorkspaceIssues[i];
|
|
101
|
+
const blockerIssueUrls: string[] =
|
|
102
|
+
repositoryBlockerIssues.find((blocker) =>
|
|
103
|
+
issue.url.includes(blocker.orgRepo),
|
|
104
|
+
)?.blockerIssueUrls || [];
|
|
105
|
+
if (
|
|
106
|
+
blockerIssueUrls.length > 0 &&
|
|
107
|
+
!blockerIssueUrls.includes(issue.url)
|
|
108
|
+
) {
|
|
109
|
+
continue;
|
|
110
|
+
}
|
|
111
|
+
const agent =
|
|
112
|
+
issue.labels
|
|
113
|
+
.find((label) => label.startsWith('category:'))
|
|
114
|
+
?.replace('category:', '')
|
|
115
|
+
.trim() || params.defaultAgentName;
|
|
116
|
+
|
|
117
|
+
if (preparationStatusOption) {
|
|
118
|
+
await this.issueRepository.updateStatus(
|
|
119
|
+
project,
|
|
120
|
+
issue,
|
|
121
|
+
preparationStatusOption.id,
|
|
122
|
+
);
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
const logFilePathArg = params.logFilePath
|
|
126
|
+
? `--logFilePath ${params.logFilePath}`
|
|
127
|
+
: '';
|
|
128
|
+
await this.localCommandRunner.runCommand(
|
|
129
|
+
`aw ${issue.url} ${agent} ${params.projectUrl}${logFilePathArg ? ` ${logFilePathArg}` : ''}`,
|
|
130
|
+
);
|
|
131
|
+
updatedCurrentPreparationIssueCount++;
|
|
132
|
+
}
|
|
133
|
+
};
|
|
134
|
+
|
|
135
|
+
createStoryObjectMap = (input: {
|
|
136
|
+
project: Project;
|
|
137
|
+
issues: Issue[];
|
|
138
|
+
}): StoryObjectMap => {
|
|
139
|
+
const summaryStoryIssue: StoryObjectMap = new Map();
|
|
140
|
+
const targetStory = input.project.story?.stories || [];
|
|
141
|
+
for (const story of targetStory) {
|
|
142
|
+
const storyIssue = input.issues.find((issue) =>
|
|
143
|
+
story.name.startsWith(issue.title),
|
|
144
|
+
);
|
|
145
|
+
summaryStoryIssue.set(story.name, {
|
|
146
|
+
story,
|
|
147
|
+
storyIssue: storyIssue || null,
|
|
148
|
+
issues: [],
|
|
149
|
+
});
|
|
150
|
+
for (const issue of input.issues) {
|
|
151
|
+
if (issue.story !== story.name) {
|
|
152
|
+
continue;
|
|
153
|
+
}
|
|
154
|
+
summaryStoryIssue.get(story.name)?.issues.push(issue);
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
return summaryStoryIssue;
|
|
158
|
+
};
|
|
159
|
+
|
|
160
|
+
createWorkflowBlockerIssues = (
|
|
161
|
+
storyObjectMap: StoryObjectMap,
|
|
162
|
+
): {
|
|
163
|
+
orgRepo: string;
|
|
164
|
+
blockerIssueUrls: string[];
|
|
165
|
+
}[] => {
|
|
166
|
+
const workflowBlockerStory: StoryObject['story']['name'][] = Array.from(
|
|
167
|
+
storyObjectMap.keys(),
|
|
168
|
+
).filter((storyName) =>
|
|
169
|
+
storyName.toLowerCase().includes('workflow blocker'),
|
|
170
|
+
);
|
|
171
|
+
if (workflowBlockerStory.length === 0) {
|
|
172
|
+
return [];
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
const result: {
|
|
176
|
+
orgRepo: string;
|
|
177
|
+
blockerIssueUrls: string[];
|
|
178
|
+
}[] =
|
|
179
|
+
storyObjectMap
|
|
180
|
+
.get(workflowBlockerStory[0])
|
|
181
|
+
?.issues.filter((issue) => issue.state === 'OPEN')
|
|
182
|
+
.map((issue) => {
|
|
183
|
+
const orgRepo = issue.url.split('/issues')[0].split('github.com/')[1];
|
|
184
|
+
return {
|
|
185
|
+
orgRepo,
|
|
186
|
+
blockerIssueUrls: [issue.url],
|
|
187
|
+
};
|
|
188
|
+
}) || [];
|
|
189
|
+
return result;
|
|
190
|
+
};
|
|
191
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Issue } from '../../entities/Issue';
|
|
2
|
+
import { Comment } from '../../entities/Comment';
|
|
3
|
+
|
|
4
|
+
export interface IssueCommentRepository {
|
|
5
|
+
getCommentsFromIssue(issue: Issue): Promise<Comment[]>;
|
|
6
|
+
createComment(issue: Issue, commentContent: string): Promise<void>;
|
|
7
|
+
}
|
|
@@ -2,6 +2,14 @@ import { Issue, Label } from '../../entities/Issue';
|
|
|
2
2
|
import { FieldOption, Project } from '../../entities/Project';
|
|
3
3
|
import { Member } from '../../entities/Member';
|
|
4
4
|
|
|
5
|
+
export type RelatedPullRequest = {
|
|
6
|
+
url: string;
|
|
7
|
+
isConflicted: boolean;
|
|
8
|
+
isPassedAllCiJob: boolean;
|
|
9
|
+
isResolvedAllReviewComments: boolean;
|
|
10
|
+
isBranchOutOfDate: boolean;
|
|
11
|
+
};
|
|
12
|
+
|
|
5
13
|
export interface IssueRepository {
|
|
6
14
|
getAllIssues: (
|
|
7
15
|
projectId: Project['id'],
|
|
@@ -59,4 +67,7 @@ export interface IssueRepository {
|
|
|
59
67
|
issue: Issue,
|
|
60
68
|
assigneeList: Member['name'][],
|
|
61
69
|
) => Promise<void>;
|
|
70
|
+
get: (issueUrl: string, project: Project) => Promise<Issue | null>;
|
|
71
|
+
update: (issue: Issue, project: Project) => Promise<void>;
|
|
72
|
+
findRelatedOpenPRs: (issueUrl: string) => Promise<RelatedPullRequest[]>;
|
|
62
73
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { BaseGitHubRepository } from './BaseGitHubRepository';
|
|
2
2
|
import { ProjectRepository } from '../../domain/usecases/adapter-interfaces/ProjectRepository';
|
|
3
3
|
import { Project } from '../../domain/entities/Project';
|
|
4
|
-
export declare class GraphqlProjectRepository extends BaseGitHubRepository implements Pick<ProjectRepository, 'getProject' | 'findProjectIdByUrl'> {
|
|
4
|
+
export declare class GraphqlProjectRepository extends BaseGitHubRepository implements Pick<ProjectRepository, 'getProject' | 'findProjectIdByUrl' | 'getByUrl'> {
|
|
5
5
|
extractProjectFromUrl: (projectUrl: string) => {
|
|
6
6
|
owner: string;
|
|
7
7
|
projectNumber: number;
|
|
@@ -9,5 +9,6 @@ export declare class GraphqlProjectRepository extends BaseGitHubRepository imple
|
|
|
9
9
|
fetchProjectId: (login: string, projectNumber: number) => Promise<string>;
|
|
10
10
|
findProjectIdByUrl: (projectUrl: string) => Promise<Project["id"] | null>;
|
|
11
11
|
getProject: (projectId: Project["id"]) => Promise<Project | null>;
|
|
12
|
+
getByUrl: (url: string) => Promise<Project>;
|
|
12
13
|
}
|
|
13
14
|
//# sourceMappingURL=GraphqlProjectRepository.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GraphqlProjectRepository.d.ts","sourceRoot":"","sources":["../../../src/adapter/repositories/GraphqlProjectRepository.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,4DAA4D,CAAC;AAC/F,OAAO,EAAe,OAAO,EAAE,MAAM,+BAA+B,CAAC;AAGrE,qBAAa,wBACX,SAAQ,oBACR,
|
|
1
|
+
{"version":3,"file":"GraphqlProjectRepository.d.ts","sourceRoot":"","sources":["../../../src/adapter/repositories/GraphqlProjectRepository.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,4DAA4D,CAAC;AAC/F,OAAO,EAAe,OAAO,EAAE,MAAM,+BAA+B,CAAC;AAGrE,qBAAa,wBACX,SAAQ,oBACR,YACE,IAAI,CAAC,iBAAiB,EAAE,YAAY,GAAG,oBAAoB,GAAG,UAAU,CAAC;IAE3E,qBAAqB,eACP,MAAM,KACjB;QACD,KAAK,EAAE,MAAM,CAAC;QACd,aAAa,EAAE,MAAM,CAAC;KACvB,CAMC;IACF,cAAc,UACL,MAAM,iBACE,MAAM,KACpB,OAAO,CAAC,MAAM,CAAC,CAsDhB;IACF,kBAAkB,eACJ,MAAM,KACjB,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAG9B;IACF,UAAU,cAAqB,OAAO,CAAC,IAAI,CAAC,KAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,CAuNpE;IACF,QAAQ,QAAe,MAAM,KAAG,OAAO,CAAC,OAAO,CAAC,CAU9C;CACH"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IssueRepository } from '../../../domain/usecases/adapter-interfaces/IssueRepository';
|
|
1
|
+
import { IssueRepository, RelatedPullRequest } from '../../../domain/usecases/adapter-interfaces/IssueRepository';
|
|
2
2
|
import { Project } from '../../../domain/entities/Project';
|
|
3
3
|
import { Issue } from '../../../domain/entities/Issue';
|
|
4
4
|
import { ApiV3IssueRepository } from './ApiV3IssueRepository';
|
|
@@ -46,5 +46,8 @@ export declare class ApiV3CheerioRestIssueRepository extends BaseGitHubRepositor
|
|
|
46
46
|
updateLabels: (issue: Issue, labels: Issue["labels"]) => Promise<void>;
|
|
47
47
|
removeLabel: (issue: Issue, label: string) => Promise<void>;
|
|
48
48
|
updateAssigneeList: (issue: Issue, assigneeList: Member["name"][]) => Promise<void>;
|
|
49
|
+
get: (_issueUrl: string, _project: Project) => Promise<Issue | null>;
|
|
50
|
+
update: (issue: Issue, _project: Project) => Promise<void>;
|
|
51
|
+
findRelatedOpenPRs: (_issueUrl: string) => Promise<RelatedPullRequest[]>;
|
|
49
52
|
}
|
|
50
53
|
//# sourceMappingURL=ApiV3CheerioRestIssueRepository.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ApiV3CheerioRestIssueRepository.d.ts","sourceRoot":"","sources":["../../../../src/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"ApiV3CheerioRestIssueRepository.d.ts","sourceRoot":"","sources":["../../../../src/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.ts"],"names":[],"mappings":"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"}
|
|
@@ -17,6 +17,7 @@ export type ProjectItem = {
|
|
|
17
17
|
value: string | null;
|
|
18
18
|
}[];
|
|
19
19
|
};
|
|
20
|
+
export declare const PAGINATION_DELAY_MS = 5000;
|
|
20
21
|
export declare class GraphqlProjectItemRepository extends BaseGitHubRepository {
|
|
21
22
|
fetchItemId: (projectId: string, owner: string, repositoryName: string, issueNumber: number) => Promise<string | undefined>;
|
|
22
23
|
fetchProjectItems: (projectId: string) => Promise<ProjectItem[]>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GraphqlProjectItemRepository.d.ts","sourceRoot":"","sources":["../../../../src/adapter/repositories/issue/GraphqlProjectItemRepository.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,EAAE,OAAO,EAAE,MAAM,kCAAkC,CAAC;AAC3D,OAAO,EAAE,KAAK,EAAE,MAAM,gCAAgC,CAAC;AACvD,MAAM,MAAM,WAAW,GAAG;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,GAAG,QAAQ,GAAG,QAAQ,CAAC;IACpC,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE;QACZ,IAAI,EAAE,MAAM,CAAC;QACb,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;KACtB,EAAE,CAAC;CACL,CAAC;AACF,qBAAa,4BAA6B,SAAQ,oBAAoB;IACpE,WAAW,cACE,MAAM,SACV,MAAM,kBACG,MAAM,eACT,MAAM,KAClB,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CA4D5B;IACF,iBAAiB,cAAqB,MAAM,KAAG,OAAO,CAAC,WAAW,EAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"GraphqlProjectItemRepository.d.ts","sourceRoot":"","sources":["../../../../src/adapter/repositories/issue/GraphqlProjectItemRepository.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,EAAE,OAAO,EAAE,MAAM,kCAAkC,CAAC;AAC3D,OAAO,EAAE,KAAK,EAAE,MAAM,gCAAgC,CAAC;AACvD,MAAM,MAAM,WAAW,GAAG;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,GAAG,QAAQ,GAAG,QAAQ,CAAC;IACpC,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE;QACZ,IAAI,EAAE,MAAM,CAAC;QACb,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;KACtB,EAAE,CAAC;CACL,CAAC;AACF,eAAO,MAAM,mBAAmB,OAAO,CAAC;AACxC,qBAAa,4BAA6B,SAAQ,oBAAoB;IACpE,WAAW,cACE,MAAM,SACV,MAAM,kBACG,MAAM,eACT,MAAM,KAClB,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CA4D5B;IACF,iBAAiB,cAAqB,MAAM,KAAG,OAAO,CAAC,WAAW,EAAE,CAAC,CAsRnE;IACF,gCAAgC,aACpB,MAAM,KACf,OAAO,CACR;QACE,SAAS,EAAE,MAAM,CAAC;QAClB,UAAU,EAAE,MAAM,CAAC;KACpB,EAAE,CACJ,CAGC;IAEF,oBAAoB,UACX,MAAM,kBACG,MAAM,eACT,MAAM,KAClB,OAAO,CACR;QACE,SAAS,EAAE,MAAM,CAAC;QAClB,UAAU,EAAE,MAAM,CAAC;KACpB,EAAE,CACJ,CA6IC;IACF,qBAAqB,aACT,MAAM,KACf,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CA8K5B;IACF,iBAAiB,UAAW,MAAM,KAAG,MAAM,GAAG,QAAQ,GAAG,QAAQ,CAQ/D;IAEF,kBAAkB,cACL,MAAM,WACR,MAAM,UACP,MAAM,SAEV;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,GAChB;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE,GAClB;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,GAChB;QAAE,oBAAoB,EAAE,MAAM,CAAA;KAAE,KACnC,OAAO,CAAC,IAAI,CAAC,CAmCd;IAEF,iBAAiB,cACJ,MAAM,WACR,MAAM,UACP,MAAM,KACb,OAAO,CAAC,IAAI,CAAC,CAkCd;IACF,sBAAsB,YACX,OAAO,CAAC,IAAI,CAAC,WACb,MAAM,SACR,KAAK,CAAC,QAAQ,CAAC,QAChB,MAAM,KACX,OAAO,CAAC,IAAI,CAAC,CAEd;IAEF,qBAAqB,cACR,MAAM,UACT,MAAM,KACb,OAAO,CAAC,IAAI,CAAC,CAmCd;IAEF,+BAA+B,aACnB,MAAM,aACL,MAAM,KAChB,OAAO,CAAC,IAAI,CAAC,CASd;CACH"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ClaudeWindowUsage.d.ts","sourceRoot":"","sources":["../../../src/domain/entities/ClaudeWindowUsage.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,iBAAiB,GAAG;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,qBAAqB,EAAE,MAAM,CAAC;IAC9B,QAAQ,EAAE,IAAI,CAAC;CAChB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Comment.d.ts","sourceRoot":"","sources":["../../../src/domain/entities/Comment.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,OAAO,GAAG;IACpB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,IAAI,CAAC;CACjB,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Project.d.ts","sourceRoot":"","sources":["../../../src/domain/entities/Project.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,WAAW,GAAG,WAAW,CAAC;AACtC,MAAM,MAAM,WAAW,GAAG;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EACD,MAAM,GACN,MAAM,GACN,OAAO,GACP,QAAQ,GACR,QAAQ,GACR,KAAK,GACL,MAAM,GACN,QAAQ,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AACF,MAAM,MAAM,OAAO,GAAG;IACpB,EAAE,EAAE,MAAM,CAAC;IACX,UAAU,EAAE,MAAM,CAAC;IACnB,IAAI,EAAE,MAAM,CAAC;IAEb,MAAM,EAAE;QACN,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;QAChB,QAAQ,EAAE,WAAW,EAAE,CAAC;KACzB,CAAC;IACF,cAAc,EAAE;QACd,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;KACjB,GAAG,IAAI,CAAC;IACT,cAAc,EAAE;QACd,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;KACjB,GAAG,IAAI,CAAC;IACT,KAAK,EAAE;QACL,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;QAChB,UAAU,EAAE,MAAM,CAAC;QACnB,OAAO,EAAE,WAAW,EAAE,CAAC;QACvB,uBAAuB,EAAE;YACvB,EAAE,EAAE,MAAM,CAAC;YACX,IAAI,EAAE,MAAM,CAAC;SACd,CAAC;KACH,GAAG,IAAI,CAAC;IACT,0BAA0B,EAAE;QAC1B,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;KACjB,GAAG,IAAI,CAAC;IACT,gCAAgC,EAAE;QAChC,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;KACjB,GAAG,IAAI,CAAC;IACT,iCAAiC,EAAE;QACjC,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;KACjB,GAAG,IAAI,CAAC;CACV,CAAC"}
|
|
1
|
+
{"version":3,"file":"Project.d.ts","sourceRoot":"","sources":["../../../src/domain/entities/Project.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,WAAW,GAAG,WAAW,CAAC;AACtC,MAAM,MAAM,WAAW,GAAG;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EACD,MAAM,GACN,MAAM,GACN,OAAO,GACP,QAAQ,GACR,QAAQ,GACR,KAAK,GACL,MAAM,GACN,QAAQ,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AACF,MAAM,MAAM,OAAO,GAAG;IACpB,EAAE,EAAE,MAAM,CAAC;IACX,GAAG,EAAE,MAAM,CAAC;IACZ,UAAU,EAAE,MAAM,CAAC;IACnB,IAAI,EAAE,MAAM,CAAC;IAEb,MAAM,EAAE;QACN,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;QAChB,QAAQ,EAAE,WAAW,EAAE,CAAC;KACzB,CAAC;IACF,cAAc,EAAE;QACd,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;KACjB,GAAG,IAAI,CAAC;IACT,cAAc,EAAE;QACd,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;KACjB,GAAG,IAAI,CAAC;IACT,KAAK,EAAE;QACL,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;QAChB,UAAU,EAAE,MAAM,CAAC;QACnB,OAAO,EAAE,WAAW,EAAE,CAAC;QACvB,uBAAuB,EAAE;YACvB,EAAE,EAAE,MAAM,CAAC;YACX,IAAI,EAAE,MAAM,CAAC;SACd,CAAC;KACH,GAAG,IAAI,CAAC;IACT,0BAA0B,EAAE;QAC1B,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;KACjB,GAAG,IAAI,CAAC;IACT,gCAAgC,EAAE;QAChC,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;KACjB,GAAG,IAAI,CAAC;IACT,iCAAiC,EAAE;QACjC,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;KACjB,GAAG,IAAI,CAAC;CACV,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { IssueRepository } from './adapter-interfaces/IssueRepository';
|
|
2
|
+
import { ProjectRepository } from './adapter-interfaces/ProjectRepository';
|
|
3
|
+
import { IssueCommentRepository } from './adapter-interfaces/IssueCommentRepository';
|
|
4
|
+
export declare class IssueNotFoundError extends Error {
|
|
5
|
+
constructor(issueUrl: string);
|
|
6
|
+
}
|
|
7
|
+
export declare class IllegalIssueStatusError extends Error {
|
|
8
|
+
constructor(issueUrl: string, currentStatus: string | null, expectedStatus: string | null);
|
|
9
|
+
}
|
|
10
|
+
export declare class NotifyFinishedIssuePreparationUseCase {
|
|
11
|
+
private readonly projectRepository;
|
|
12
|
+
private readonly issueRepository;
|
|
13
|
+
private readonly issueCommentRepository;
|
|
14
|
+
constructor(projectRepository: Pick<ProjectRepository, 'getByUrl'>, issueRepository: Pick<IssueRepository, 'get' | 'update' | 'findRelatedOpenPRs'>, issueCommentRepository: Pick<IssueCommentRepository, 'getCommentsFromIssue' | 'createComment'>);
|
|
15
|
+
run: (params: {
|
|
16
|
+
projectUrl: string;
|
|
17
|
+
issueUrl: string;
|
|
18
|
+
preparationStatus: string;
|
|
19
|
+
awaitingWorkspaceStatus: string;
|
|
20
|
+
awaitingQualityCheckStatus: string;
|
|
21
|
+
thresholdForAutoReject: number;
|
|
22
|
+
}) => Promise<void>;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=NotifyFinishedIssuePreparationUseCase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NotifyFinishedIssuePreparationUseCase.d.ts","sourceRoot":"","sources":["../../../src/domain/usecases/NotifyFinishedIssuePreparationUseCase.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAC3E,OAAO,EAAE,sBAAsB,EAAE,MAAM,6CAA6C,CAAC;AAErF,qBAAa,kBAAmB,SAAQ,KAAK;gBAC/B,QAAQ,EAAE,MAAM;CAI7B;AACD,qBAAa,uBAAwB,SAAQ,KAAK;gBAE9C,QAAQ,EAAE,MAAM,EAChB,aAAa,EAAE,MAAM,GAAG,IAAI,EAC5B,cAAc,EAAE,MAAM,GAAG,IAAI;CAOhC;AASD,qBAAa,qCAAqC;IAE9C,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAClC,OAAO,CAAC,QAAQ,CAAC,eAAe;IAIhC,OAAO,CAAC,QAAQ,CAAC,sBAAsB;gBALtB,iBAAiB,EAAE,IAAI,CAAC,iBAAiB,EAAE,UAAU,CAAC,EACtD,eAAe,EAAE,IAAI,CACpC,eAAe,EACf,KAAK,GAAG,QAAQ,GAAG,oBAAoB,CACxC,EACgB,sBAAsB,EAAE,IAAI,CAC3C,sBAAsB,EACtB,sBAAsB,GAAG,eAAe,CACzC;IAGH,GAAG,WAAkB;QACnB,UAAU,EAAE,MAAM,CAAC;QACnB,QAAQ,EAAE,MAAM,CAAC;QACjB,iBAAiB,EAAE,MAAM,CAAC;QAC1B,uBAAuB,EAAE,MAAM,CAAC;QAChC,0BAA0B,EAAE,MAAM,CAAC;QACnC,sBAAsB,EAAE,MAAM,CAAC;KAChC,KAAG,OAAO,CAAC,IAAI,CAAC,CAgFf;CACH"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { Issue } from '../entities/Issue';
|
|
2
|
+
import { Project, StoryOption } from '../entities/Project';
|
|
3
|
+
import { IssueRepository } from './adapter-interfaces/IssueRepository';
|
|
4
|
+
import { ProjectRepository } from './adapter-interfaces/ProjectRepository';
|
|
5
|
+
import { LocalCommandRunner } from './adapter-interfaces/LocalCommandRunner';
|
|
6
|
+
import { ClaudeRepository } from './adapter-interfaces/ClaudeRepository';
|
|
7
|
+
export type StoryObject = {
|
|
8
|
+
story: StoryOption;
|
|
9
|
+
storyIssue: Issue | null;
|
|
10
|
+
issues: Issue[];
|
|
11
|
+
};
|
|
12
|
+
export type StoryObjectMap = Map<NonNullable<Project['story']>['stories'][0]['name'], StoryObject>;
|
|
13
|
+
export declare class StartPreparationUseCase {
|
|
14
|
+
readonly projectRepository: Pick<ProjectRepository, 'findProjectIdByUrl' | 'getProject'>;
|
|
15
|
+
readonly issueRepository: Pick<IssueRepository, 'getAllIssues' | 'updateStatus'>;
|
|
16
|
+
readonly claudeRepository: Pick<ClaudeRepository, 'getUsage'>;
|
|
17
|
+
readonly localCommandRunner: LocalCommandRunner;
|
|
18
|
+
constructor(projectRepository: Pick<ProjectRepository, 'findProjectIdByUrl' | 'getProject'>, issueRepository: Pick<IssueRepository, 'getAllIssues' | 'updateStatus'>, claudeRepository: Pick<ClaudeRepository, 'getUsage'>, localCommandRunner: LocalCommandRunner);
|
|
19
|
+
run: (params: {
|
|
20
|
+
projectUrl: string;
|
|
21
|
+
awaitingWorkspaceStatus: string;
|
|
22
|
+
preparationStatus: string;
|
|
23
|
+
defaultAgentName: string;
|
|
24
|
+
logFilePath?: string;
|
|
25
|
+
maximumPreparingIssuesCount: number | null;
|
|
26
|
+
allowIssueCacheMinutes: number;
|
|
27
|
+
}) => Promise<void>;
|
|
28
|
+
createStoryObjectMap: (input: {
|
|
29
|
+
project: Project;
|
|
30
|
+
issues: Issue[];
|
|
31
|
+
}) => StoryObjectMap;
|
|
32
|
+
createWorkflowBlockerIssues: (storyObjectMap: StoryObjectMap) => {
|
|
33
|
+
orgRepo: string;
|
|
34
|
+
blockerIssueUrls: string[];
|
|
35
|
+
}[];
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=StartPreparationUseCase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StartPreparationUseCase.d.ts","sourceRoot":"","sources":["../../../src/domain/usecases/StartPreparationUseCase.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAC1C,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAC3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAC;AAC7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,uCAAuC,CAAC;AAEzE,MAAM,MAAM,WAAW,GAAG;IACxB,KAAK,EAAE,WAAW,CAAC;IACnB,UAAU,EAAE,KAAK,GAAG,IAAI,CAAC;IACzB,MAAM,EAAE,KAAK,EAAE,CAAC;CACjB,CAAC;AACF,MAAM,MAAM,cAAc,GAAG,GAAG,CAC9B,WAAW,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EACnD,WAAW,CACZ,CAAC;AAEF,qBAAa,uBAAuB;IAEhC,QAAQ,CAAC,iBAAiB,EAAE,IAAI,CAC9B,iBAAiB,EACjB,oBAAoB,GAAG,YAAY,CACpC;IACD,QAAQ,CAAC,eAAe,EAAE,IAAI,CAC5B,eAAe,EACf,cAAc,GAAG,cAAc,CAChC;IACD,QAAQ,CAAC,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,EAAE,UAAU,CAAC;IAC7D,QAAQ,CAAC,kBAAkB,EAAE,kBAAkB;gBATtC,iBAAiB,EAAE,IAAI,CAC9B,iBAAiB,EACjB,oBAAoB,GAAG,YAAY,CACpC,EACQ,eAAe,EAAE,IAAI,CAC5B,eAAe,EACf,cAAc,GAAG,cAAc,CAChC,EACQ,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,EAAE,UAAU,CAAC,EACpD,kBAAkB,EAAE,kBAAkB;IAGjD,GAAG,WAAkB;QACnB,UAAU,EAAE,MAAM,CAAC;QACnB,uBAAuB,EAAE,MAAM,CAAC;QAChC,iBAAiB,EAAE,MAAM,CAAC;QAC1B,gBAAgB,EAAE,MAAM,CAAC;QACzB,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,2BAA2B,EAAE,MAAM,GAAG,IAAI,CAAC;QAC3C,sBAAsB,EAAE,MAAM,CAAC;KAChC,KAAG,OAAO,CAAC,IAAI,CAAC,CA6Ff;IAEF,oBAAoB,UAAW;QAC7B,OAAO,EAAE,OAAO,CAAC;QACjB,MAAM,EAAE,KAAK,EAAE,CAAC;KACjB,KAAG,cAAc,CAoBhB;IAEF,2BAA2B,mBACT,cAAc,KAC7B;QACD,OAAO,EAAE,MAAM,CAAC;QAChB,gBAAgB,EAAE,MAAM,EAAE,CAAC;KAC5B,EAAE,CAyBD;CACH"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ClaudeRepository.d.ts","sourceRoot":"","sources":["../../../../src/domain/usecases/adapter-interfaces/ClaudeRepository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAErE,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,IAAI,OAAO,CAAC,iBAAiB,EAAE,CAAC,CAAC;CAC1C"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Issue } from '../../entities/Issue';
|
|
2
|
+
import { Comment } from '../../entities/Comment';
|
|
3
|
+
export interface IssueCommentRepository {
|
|
4
|
+
getCommentsFromIssue(issue: Issue): Promise<Comment[]>;
|
|
5
|
+
createComment(issue: Issue, commentContent: string): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=IssueCommentRepository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IssueCommentRepository.d.ts","sourceRoot":"","sources":["../../../../src/domain/usecases/adapter-interfaces/IssueCommentRepository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAC7C,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,MAAM,WAAW,sBAAsB;IACrC,oBAAoB,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;IACvD,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,cAAc,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CACpE"}
|
|
@@ -1,6 +1,13 @@
|
|
|
1
1
|
import { Issue, Label } from '../../entities/Issue';
|
|
2
2
|
import { FieldOption, Project } from '../../entities/Project';
|
|
3
3
|
import { Member } from '../../entities/Member';
|
|
4
|
+
export type RelatedPullRequest = {
|
|
5
|
+
url: string;
|
|
6
|
+
isConflicted: boolean;
|
|
7
|
+
isPassedAllCiJob: boolean;
|
|
8
|
+
isResolvedAllReviewComments: boolean;
|
|
9
|
+
isBranchOutOfDate: boolean;
|
|
10
|
+
};
|
|
4
11
|
export interface IssueRepository {
|
|
5
12
|
getAllIssues: (projectId: Project['id'], allowCacheMinutes: number) => Promise<{
|
|
6
13
|
issues: Issue[];
|
|
@@ -25,5 +32,8 @@ export interface IssueRepository {
|
|
|
25
32
|
updateLabels: (issue: Issue, labels: Issue['labels']) => Promise<void>;
|
|
26
33
|
removeLabel: (issue: Issue, label: Label) => Promise<void>;
|
|
27
34
|
updateAssigneeList: (issue: Issue, assigneeList: Member['name'][]) => Promise<void>;
|
|
35
|
+
get: (issueUrl: string, project: Project) => Promise<Issue | null>;
|
|
36
|
+
update: (issue: Issue, project: Project) => Promise<void>;
|
|
37
|
+
findRelatedOpenPRs: (issueUrl: string) => Promise<RelatedPullRequest[]>;
|
|
28
38
|
}
|
|
29
39
|
//# sourceMappingURL=IssueRepository.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"IssueRepository.d.ts","sourceRoot":"","sources":["../../../../src/domain/usecases/adapter-interfaces/IssueRepository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAE/C,MAAM,WAAW,eAAe;IAC9B,YAAY,EAAE,CACZ,SAAS,EAAE,OAAO,CAAC,IAAI,CAAC,EACxB,iBAAiB,EAAE,MAAM,KACtB,OAAO,CAAC;QAAE,MAAM,EAAE,KAAK,EAAE,CAAC;QAAC,SAAS,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;IACtD,aAAa,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC;IACtD,cAAc,EAAE,CACd,GAAG,EAAE,MAAM,EACX,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,MAAM,EACZ,SAAS,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAC3B,MAAM,EAAE,KAAK,EAAE,KACZ,OAAO,CAAC,MAAM,CAAC,CAAC;IACrB,WAAW,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7C,oBAAoB,EAAE,CACpB,OAAO,EAAE,OAAO,GAAG;QACjB,cAAc,EAAE,WAAW,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC;KACxD,EACD,KAAK,EAAE,KAAK,EACZ,IAAI,EAAE,IAAI,KACP,OAAO,CAAC,IAAI,CAAC,CAAC;IACnB,oBAAoB,EAAE,CACpB,OAAO,EAAE,OAAO,GAAG;QACjB,cAAc,EAAE,WAAW,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC;KACxD,EACD,KAAK,EAAE,KAAK,EACZ,IAAI,EAAE,MAAM,KACT,OAAO,CAAC,IAAI,CAAC,CAAC;IACnB,sBAAsB,EAAE,CACtB,OAAO,EAAE,OAAO,EAChB,OAAO,EAAE,MAAM,EACf,KAAK,EAAE,KAAK,EACZ,IAAI,EAAE,MAAM,KACT,OAAO,CAAC,IAAI,CAAC,CAAC;IACnB,WAAW,EAAE,CACX,OAAO,EAAE,OAAO,GAAG;QAAE,KAAK,EAAE,WAAW,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAA;KAAE,EAC3D,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,WAAW,CAAC,IAAI,CAAC,KACvB,OAAO,CAAC,IAAI,CAAC,CAAC;IACnB,YAAY,EAAE,CACZ,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,MAAM,KACb,OAAO,CAAC,IAAI,CAAC,CAAC;IACnB,iBAAiB,EAAE,CACjB,OAAO,EAAE,OAAO,EAChB,OAAO,EAAE,MAAM,EACf,KAAK,EAAE,KAAK,KACT,OAAO,CAAC,IAAI,CAAC,CAAC;IACnB,aAAa,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACpE,YAAY,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACvE,WAAW,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3D,kBAAkB,EAAE,CAClB,KAAK,EAAE,KAAK,EACZ,YAAY,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,KAC3B,OAAO,CAAC,IAAI,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"IssueRepository.d.ts","sourceRoot":"","sources":["../../../../src/domain/usecases/adapter-interfaces/IssueRepository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LocalCommandRunner.d.ts","sourceRoot":"","sources":["../../../../src/domain/usecases/adapter-interfaces/LocalCommandRunner.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,kBAAkB;IACjC,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC;QACnC,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,MAAM,CAAC;QACf,QAAQ,EAAE,MAAM,CAAC;KAClB,CAAC,CAAC;CACJ"}
|
|
@@ -5,5 +5,6 @@ export interface ProjectRepository {
|
|
|
5
5
|
updateStoryList: (projectId: Project, storyOption: (Omit<FieldOption, 'id'> & {
|
|
6
6
|
id: FieldOption['id'] | null;
|
|
7
7
|
})[]) => Promise<FieldOption[]>;
|
|
8
|
+
getByUrl: (url: string) => Promise<Project>;
|
|
8
9
|
}
|
|
9
10
|
//# sourceMappingURL=ProjectRepository.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProjectRepository.d.ts","sourceRoot":"","sources":["../../../../src/domain/usecases/adapter-interfaces/ProjectRepository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAE9D,MAAM,WAAW,iBAAiB;IAChC,kBAAkB,EAAE,CAAC,UAAU,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;IAC1E,UAAU,EAAE,CAAC,SAAS,EAAE,OAAO,CAAC,IAAI,CAAC,KAAK,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,CAAC;IAClE,eAAe,EAAE,CACf,SAAS,EAAE,OAAO,EAClB,WAAW,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,GAAG;QAAE,EAAE,EAAE,WAAW,CAAC,IAAI,CAAC,GAAG,IAAI,CAAA;KAAE,CAAC,EAAE,KACxE,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"ProjectRepository.d.ts","sourceRoot":"","sources":["../../../../src/domain/usecases/adapter-interfaces/ProjectRepository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAE9D,MAAM,WAAW,iBAAiB;IAChC,kBAAkB,EAAE,CAAC,UAAU,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;IAC1E,UAAU,EAAE,CAAC,SAAS,EAAE,OAAO,CAAC,IAAI,CAAC,KAAK,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,CAAC;IAClE,eAAe,EAAE,CACf,SAAS,EAAE,OAAO,EAClB,WAAW,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,GAAG;QAAE,EAAE,EAAE,WAAW,CAAC,IAAI,CAAC,GAAG,IAAI,CAAA;KAAE,CAAC,EAAE,KACxE,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;IAC5B,QAAQ,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;CAC7C"}
|