@codeguide/core 0.0.33 → 0.0.35

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.
Files changed (49) hide show
  1. package/__tests__/services/usage/usage-service.test.ts +53 -29
  2. package/codeguide.ts +3 -0
  3. package/dist/codeguide.d.ts +2 -1
  4. package/dist/codeguide.js +1 -0
  5. package/dist/index.d.ts +1 -1
  6. package/dist/services/chat/chat-service.d.ts +44 -0
  7. package/dist/services/chat/chat-service.js +85 -0
  8. package/dist/services/chat/chat-types.d.ts +88 -0
  9. package/dist/services/chat/chat-types.js +5 -0
  10. package/dist/services/chat/index.d.ts +2 -0
  11. package/dist/services/chat/index.js +20 -0
  12. package/dist/services/generation/generation-service.d.ts +7 -1
  13. package/dist/services/generation/generation-service.js +18 -0
  14. package/dist/services/generation/generation-types.d.ts +95 -0
  15. package/dist/services/index.d.ts +4 -0
  16. package/dist/services/index.js +7 -1
  17. package/dist/services/projects/project-service.d.ts +3 -1
  18. package/dist/services/projects/project-service.js +13 -1
  19. package/dist/services/projects/project-types.d.ts +24 -1
  20. package/dist/services/streaming/index.d.ts +2 -0
  21. package/dist/services/streaming/index.js +20 -0
  22. package/dist/services/streaming/streaming-service.d.ts +30 -0
  23. package/dist/services/streaming/streaming-service.js +107 -0
  24. package/dist/services/streaming/streaming-types.d.ts +14 -0
  25. package/dist/services/streaming/streaming-types.js +2 -0
  26. package/dist/services/tasks/task-service.d.ts +3 -1
  27. package/dist/services/tasks/task-service.js +8 -0
  28. package/dist/services/tasks/task-types.d.ts +15 -0
  29. package/dist/services/usage/usage-service.d.ts +35 -1
  30. package/dist/services/usage/usage-service.js +68 -0
  31. package/dist/services/usage/usage-types.d.ts +108 -33
  32. package/index.ts +3 -0
  33. package/package.json +1 -1
  34. package/services/chat/chat-service.ts +110 -0
  35. package/services/chat/chat-types.ts +145 -0
  36. package/services/chat/index.ts +2 -0
  37. package/services/generation/generation-service.ts +40 -0
  38. package/services/generation/generation-types.ts +110 -0
  39. package/services/index.ts +4 -0
  40. package/services/projects/README.md +54 -0
  41. package/services/projects/project-service.ts +20 -1
  42. package/services/projects/project-types.ts +27 -1
  43. package/services/streaming/index.ts +2 -0
  44. package/services/streaming/streaming-service.ts +123 -0
  45. package/services/streaming/streaming-types.ts +15 -0
  46. package/services/tasks/task-service.ts +30 -2
  47. package/services/tasks/task-types.ts +19 -1
  48. package/services/usage/usage-service.ts +81 -0
  49. package/services/usage/usage-types.ts +116 -36
@@ -326,7 +326,7 @@ describe('UsageService', () => {
326
326
  expect(result.data.subscription).not.toBeNull()
327
327
  expect(result.data.subscription?.plan_name).toBe('Monthly Plan')
328
328
  expect(result.data.codespace_task_limit).toBeNull()
329
- expect(result.data.plan_limits.limits.codespace_tasks.is_unlimited).toBe(true)
329
+ expect(result.data.plan_limits?.limits.codespace_tasks.is_unlimited).toBe(true)
330
330
  })
331
331
  })
332
332
 
@@ -706,25 +706,37 @@ describe('UsageService', () => {
706
706
  const response: UsageSummaryResponse = {
707
707
  status: 'success',
708
708
  data: {
709
- current_period: {
709
+ period: {
710
+ start: '2024-01-25',
711
+ end: '2024-01-31',
712
+ },
713
+ usage: {
710
714
  credits_consumed: 13870,
711
715
  cost_usd: 41.61,
712
716
  requests_count: 142,
713
717
  },
714
- previous_period: {
715
- credits_consumed: 11990,
716
- cost_usd: 35.97,
717
- requests_count: 131,
718
- },
719
- billing_cycle: {
720
- total_allotted: 50000,
721
- total_consumed: 28450,
722
- remaining_credits: 21550,
718
+ breakdown: {
719
+ docs: 5230,
720
+ chat: 4120,
721
+ codespace_task: 4520,
723
722
  },
724
- utilization_percentage: 56.9,
725
- remaining_credits: 21550,
726
- daily_average: 1981.43,
727
- projected_monthly: 59443,
723
+ service_breakdown: [
724
+ {
725
+ service_type: 'docs',
726
+ credits_consumed: 5230,
727
+ requests_count: 58,
728
+ },
729
+ {
730
+ service_type: 'chat',
731
+ credits_consumed: 4120,
732
+ requests_count: 47,
733
+ },
734
+ {
735
+ service_type: 'codespace_task',
736
+ credits_consumed: 4520,
737
+ requests_count: 37,
738
+ },
739
+ ],
728
740
  },
729
741
  }
730
742
 
@@ -744,25 +756,37 @@ describe('UsageService', () => {
744
756
  const response: UsageSummaryResponse = {
745
757
  status: 'success',
746
758
  data: {
747
- current_period: {
759
+ period: {
760
+ start: '2024-01-01',
761
+ end: '2024-01-31',
762
+ },
763
+ usage: {
748
764
  credits_consumed: 25000,
749
765
  cost_usd: 75.0,
750
766
  requests_count: 300,
751
767
  },
752
- previous_period: {
753
- credits_consumed: 22000,
754
- cost_usd: 66.0,
755
- requests_count: 275,
756
- },
757
- billing_cycle: {
758
- total_allotted: 50000,
759
- total_consumed: 47000,
760
- remaining_credits: 3000,
768
+ breakdown: {
769
+ docs: 10000,
770
+ chat: 8000,
771
+ codespace_task: 7000,
761
772
  },
762
- utilization_percentage: 94.0,
763
- remaining_credits: 3000,
764
- daily_average: 806.45,
765
- projected_monthly: 25000,
773
+ service_breakdown: [
774
+ {
775
+ service_type: 'docs',
776
+ credits_consumed: 10000,
777
+ requests_count: 120,
778
+ },
779
+ {
780
+ service_type: 'chat',
781
+ credits_consumed: 8000,
782
+ requests_count: 95,
783
+ },
784
+ {
785
+ service_type: 'codespace_task',
786
+ credits_consumed: 7000,
787
+ requests_count: 85,
788
+ },
789
+ ],
766
790
  },
767
791
  }
768
792
 
package/codeguide.ts CHANGED
@@ -20,6 +20,7 @@ import {
20
20
  SecurityKeysService,
21
21
  UserService,
22
22
  StarterKitsService,
23
+ ChatService,
23
24
  } from './services'
24
25
  import { APIServiceConfig, CodeGuideOptions } from './types'
25
26
 
@@ -37,6 +38,7 @@ export class CodeGuide {
37
38
  public securityKeys: SecurityKeysService
38
39
  public users: UserService
39
40
  public starterKits: StarterKitsService
41
+ public chat: ChatService
40
42
  private options: CodeGuideOptions
41
43
 
42
44
  constructor(config: APIServiceConfig, options: CodeGuideOptions = {}) {
@@ -56,6 +58,7 @@ export class CodeGuide {
56
58
  this.securityKeys = new SecurityKeysService(config)
57
59
  this.users = new UserService(config)
58
60
  this.starterKits = new StarterKitsService(config)
61
+ this.chat = new ChatService(config)
59
62
  }
60
63
 
61
64
  // Convenience method for backward compatibility
@@ -1,4 +1,4 @@
1
- import { GenerationService, ProjectService, UsageService, RepositoryAnalysisService, TaskService, ApiKeyEnhancedService, SubscriptionService, CancellationFunnelService, CodespaceService, ExternalTokenService, SecurityKeysService, UserService, StarterKitsService } from './services';
1
+ import { GenerationService, ProjectService, UsageService, RepositoryAnalysisService, TaskService, ApiKeyEnhancedService, SubscriptionService, CancellationFunnelService, CodespaceService, ExternalTokenService, SecurityKeysService, UserService, StarterKitsService, ChatService } from './services';
2
2
  import { APIServiceConfig, CodeGuideOptions } from './types';
3
3
  export declare class CodeGuide {
4
4
  generation: GenerationService;
@@ -14,6 +14,7 @@ export declare class CodeGuide {
14
14
  securityKeys: SecurityKeysService;
15
15
  users: UserService;
16
16
  starterKits: StarterKitsService;
17
+ chat: ChatService;
17
18
  private options;
18
19
  constructor(config: APIServiceConfig, options?: CodeGuideOptions);
19
20
  getGuidance(prompt: string): Promise<any>;
package/dist/codeguide.js CHANGED
@@ -29,6 +29,7 @@ class CodeGuide {
29
29
  this.securityKeys = new services_1.SecurityKeysService(config);
30
30
  this.users = new services_1.UserService(config);
31
31
  this.starterKits = new services_1.StarterKitsService(config);
32
+ this.chat = new services_1.ChatService(config);
32
33
  }
33
34
  // Convenience method for backward compatibility
34
35
  async getGuidance(prompt) {
package/dist/index.d.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  export { CodeGuide } from './codeguide';
2
2
  export * from './services';
3
3
  export * from './types';
4
- export type { ConnectRepositoryRequest, ConnectRepositoryResponse, ProjectRepository, GetProjectsRequest, PaginatedProjectsRequest, PaginatedProjectsResponse, } from './services/projects/project-types';
4
+ export type { ConnectRepositoryRequest, ConnectRepositoryResponse, ProjectRepository, GetProjectsRequest, PaginatedProjectsRequest, PaginatedProjectsResponse, AITool, GetAiToolsRequest, GetAiToolsResponse, } from './services/projects/project-types';
5
5
  export type { CreateCodespaceTaskRequestV2 as CreateCodespaceTaskRequest, CreateCodespaceTaskResponseV2 as CreateCodespaceTaskResponse, CreateBackgroundCodespaceTaskRequest, CreateBackgroundCodespaceTaskResponse, ModelApiKey, Attachment, GetCodespaceTaskResponse, CodespaceTaskData, TechnicalDocument, GetProjectTasksByCodespaceResponse, } from './services/codespace/codespace-types';
6
6
  export type { StoreExternalTokenRequest, StoreExternalTokenResponse, ListTokensQuery, ListTokensResponse, ValidateTokenRequest, ValidateTokenResponse, FindBestMatchRequest, FindBestMatchResponse, Platform, TokenType, } from './services/external-tokens/external-tokens-types';
7
7
  export type { StarterKit, StarterKitMetadata, GetStarterKitsRequest, GetStarterKitsResponse, } from './services/starter-kits/starter-kits-types';
@@ -0,0 +1,44 @@
1
+ import { BaseService } from '../base/base-service';
2
+ import { GetDocumentTypesRequest, GetDocumentTypesResponse, GetChatsByDocumentTypeRequest, GetChatsByDocumentTypeResponse, GetChatHistoryRequest, GetChatHistoryResponse, ListDocumentChatsRequest, ListDocumentChatsResponse, GetChatByDocumentIdRequest, GetChatByDocumentIdResponse } from './chat-types';
3
+ export declare class ChatService extends BaseService {
4
+ /**
5
+ * 1. GET /chat/document/types/{project_id}
6
+ * Get document types for UI grouping
7
+ *
8
+ * @param request - Project ID to get document types for
9
+ * @returns Document types available for the project
10
+ */
11
+ getDocumentTypes(request: GetDocumentTypesRequest): Promise<GetDocumentTypesResponse>;
12
+ /**
13
+ * 2. GET /chat/document/by-type/{project_id}/{document_type}
14
+ * List all chats for a specific document type (PRIMARY endpoint for UI)
15
+ *
16
+ * @param request - Filter parameters for document type chats
17
+ * @returns Paginated list of document chats for the specified type
18
+ */
19
+ getChatsByDocumentType(request: GetChatsByDocumentTypeRequest): Promise<GetChatsByDocumentTypeResponse>;
20
+ /**
21
+ * 3. GET /chat/document/history/{conversation_id}
22
+ * Get full chat history with messages
23
+ *
24
+ * @param request - Conversation ID to get history for
25
+ * @returns Conversation details with all messages
26
+ */
27
+ getChatHistory(request: GetChatHistoryRequest): Promise<GetChatHistoryResponse>;
28
+ /**
29
+ * 4. GET /chat/document/list
30
+ * List all chats for current user (with optional filters)
31
+ *
32
+ * @param request - Filter parameters for listing chats
33
+ * @returns Paginated list of all document chats for the user
34
+ */
35
+ listDocumentChats(request?: ListDocumentChatsRequest): Promise<ListDocumentChatsResponse>;
36
+ /**
37
+ * 5. GET /chat/document/by-document/{document_id}
38
+ * Get chat by specific document version ID (Legacy)
39
+ *
40
+ * @param request - Document ID to get chat for
41
+ * @returns Conversation and messages for the specific document
42
+ */
43
+ getChatByDocumentId(request: GetChatByDocumentIdRequest): Promise<GetChatByDocumentIdResponse>;
44
+ }
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ChatService = void 0;
4
+ const base_service_1 = require("../base/base-service");
5
+ class ChatService extends base_service_1.BaseService {
6
+ /**
7
+ * 1. GET /chat/document/types/{project_id}
8
+ * Get document types for UI grouping
9
+ *
10
+ * @param request - Project ID to get document types for
11
+ * @returns Document types available for the project
12
+ */
13
+ async getDocumentTypes(request) {
14
+ return this.get(`/chat/document/types/${request.project_id}`);
15
+ }
16
+ /**
17
+ * 2. GET /chat/document/by-type/{project_id}/{document_type}
18
+ * List all chats for a specific document type (PRIMARY endpoint for UI)
19
+ *
20
+ * @param request - Filter parameters for document type chats
21
+ * @returns Paginated list of document chats for the specified type
22
+ */
23
+ async getChatsByDocumentType(request) {
24
+ const { project_id, document_type, chat_status = 'active', limit = 50, offset = 0 } = request;
25
+ // Build query parameters
26
+ const params = new URLSearchParams();
27
+ if (chat_status)
28
+ params.append('chat_status', chat_status);
29
+ if (limit !== undefined)
30
+ params.append('limit', limit.toString());
31
+ if (offset !== undefined)
32
+ params.append('offset', offset.toString());
33
+ const queryString = params.toString();
34
+ const url = `/chat/document/by-type/${project_id}/${document_type}${queryString ? `?${queryString}` : ''}`;
35
+ return this.get(url);
36
+ }
37
+ /**
38
+ * 3. GET /chat/document/history/{conversation_id}
39
+ * Get full chat history with messages
40
+ *
41
+ * @param request - Conversation ID to get history for
42
+ * @returns Conversation details with all messages
43
+ */
44
+ async getChatHistory(request) {
45
+ return this.get(`/chat/document/history/${request.conversation_id}`);
46
+ }
47
+ /**
48
+ * 4. GET /chat/document/list
49
+ * List all chats for current user (with optional filters)
50
+ *
51
+ * @param request - Filter parameters for listing chats
52
+ * @returns Paginated list of all document chats for the user
53
+ */
54
+ async listDocumentChats(request = {}) {
55
+ const { project_id, document_type, template, chat_status = 'active', limit = 50, offset = 0, } = request;
56
+ // Build query parameters
57
+ const params = new URLSearchParams();
58
+ if (project_id)
59
+ params.append('project_id', project_id);
60
+ if (document_type)
61
+ params.append('document_type', document_type);
62
+ if (template)
63
+ params.append('template', template);
64
+ if (chat_status)
65
+ params.append('chat_status', chat_status);
66
+ if (limit !== undefined)
67
+ params.append('limit', limit.toString());
68
+ if (offset !== undefined)
69
+ params.append('offset', offset.toString());
70
+ const queryString = params.toString();
71
+ const url = `/chat/document/list${queryString ? `?${queryString}` : ''}`;
72
+ return this.get(url);
73
+ }
74
+ /**
75
+ * 5. GET /chat/document/by-document/{document_id}
76
+ * Get chat by specific document version ID (Legacy)
77
+ *
78
+ * @param request - Document ID to get chat for
79
+ * @returns Conversation and messages for the specific document
80
+ */
81
+ async getChatByDocumentId(request) {
82
+ return this.get(`/chat/document/by-document/${request.document_id}`);
83
+ }
84
+ }
85
+ exports.ChatService = ChatService;
@@ -0,0 +1,88 @@
1
+ export interface GetDocumentTypesRequest {
2
+ project_id: string;
3
+ }
4
+ export interface GetDocumentTypesResponse {
5
+ project_id: string;
6
+ project_name: string;
7
+ document_types: DocumentType[];
8
+ }
9
+ export type DocumentType = 'project_requirements_document' | 'app_flow_document' | 'tech_stack_document' | 'frontend_guidelines_document' | 'database_schema_document' | 'api_documentation_document' | 'deployment_document' | 'testing_document' | 'custom_document';
10
+ export interface GetChatsByDocumentTypeRequest {
11
+ project_id: string;
12
+ document_type: DocumentType;
13
+ chat_status?: ChatStatus;
14
+ limit?: number;
15
+ offset?: number;
16
+ }
17
+ export interface GetChatsByDocumentTypeResponse {
18
+ chats: DocumentChatSummary[];
19
+ count: number;
20
+ project_id: string;
21
+ document_type: DocumentType;
22
+ limit: number;
23
+ offset: number;
24
+ }
25
+ export interface GetChatHistoryRequest {
26
+ conversation_id: string;
27
+ }
28
+ export interface GetChatHistoryResponse {
29
+ conversation: DocumentConversation;
30
+ messages: ChatMessage[];
31
+ }
32
+ export interface ListDocumentChatsRequest {
33
+ project_id?: string;
34
+ document_type?: DocumentType;
35
+ template?: 'blueprint' | 'wireframe';
36
+ chat_status?: ChatStatus;
37
+ limit?: number;
38
+ offset?: number;
39
+ }
40
+ export interface ListDocumentChatsResponse {
41
+ chats: DocumentChatSummary[];
42
+ count: number;
43
+ limit: number;
44
+ offset: number;
45
+ }
46
+ export interface GetChatByDocumentIdRequest {
47
+ document_id: string;
48
+ }
49
+ export interface GetChatByDocumentIdResponse {
50
+ conversation: DocumentConversation;
51
+ messages: ChatMessage[];
52
+ }
53
+ export type ChatStatus = 'active' | 'archived' | 'deleted';
54
+ export interface DocumentChatSummary {
55
+ id: string;
56
+ project_id: string;
57
+ document_type: DocumentType;
58
+ title: string;
59
+ template: 'blueprint' | 'wireframe';
60
+ status: ChatStatus;
61
+ last_message_at: string;
62
+ metadata?: Record<string, any>;
63
+ }
64
+ export interface DocumentConversation {
65
+ id: string;
66
+ project_id: string;
67
+ document_type: DocumentType;
68
+ title: string;
69
+ template: 'blueprint' | 'wireframe';
70
+ status: ChatStatus;
71
+ created_at: string;
72
+ last_message_at: string;
73
+ }
74
+ export interface ChatMessage {
75
+ id: string;
76
+ role: 'user' | 'assistant' | 'system';
77
+ content: string;
78
+ tool_calls?: ChatToolCall[];
79
+ created_at: string;
80
+ }
81
+ export interface ChatToolCall {
82
+ id: string;
83
+ type: string;
84
+ function?: {
85
+ name: string;
86
+ arguments: string;
87
+ };
88
+ }
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ // ============================================================================
3
+ // Document Chat GET Endpoint Types
4
+ // ============================================================================
5
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,2 @@
1
+ export { ChatService } from './chat-service';
2
+ export * from './chat-types';
@@ -0,0 +1,20 @@
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
+ exports.ChatService = void 0;
18
+ var chat_service_1 = require("./chat-service");
19
+ Object.defineProperty(exports, "ChatService", { enumerable: true, get: function () { return chat_service_1.ChatService; } });
20
+ __exportStar(require("./chat-types"), exports);
@@ -1,5 +1,5 @@
1
1
  import { BaseService } from '../base/base-service';
2
- import { RefinePromptRequest, RefinePromptResponse, GenerateTitleRequest, GenerateTitleResponse, GenerateQuestionnaireRequest, GenerateQuestionnaireResponse, GeneratePRDRequest, GeneratePRDResponse, GenerateCategoryRequest, GenerateCategoryResponse, GenerateOutlineRequest, GenerateOutlineResponse, GenerateDocumentRequest, GenerateDocumentResponse, GenerateMultipleDocumentsRequest, GenerateMultipleDocumentsResponse, GenerateMissingDocumentsRequest, GenerateMissingDocumentsResponse, BackgroundGenerationRequest, BackgroundGenerationResponse, BackgroundGenerationStatusResponse } from './generation-types';
2
+ import { RefinePromptRequest, RefinePromptResponse, GenerateTitleRequest, GenerateTitleResponse, GenerateQuestionnaireRequest, GenerateQuestionnaireResponse, GeneratePRDRequest, GeneratePRDResponse, GenerateCategoryRequest, GenerateCategoryResponse, GenerateOutlineRequest, GenerateOutlineResponse, GenerateDocumentRequest, GenerateDocumentResponse, GenerateMultipleDocumentsRequest, GenerateMultipleDocumentsResponse, GenerateMissingDocumentsRequest, GenerateMissingDocumentsResponse, GenerateTechSpecRequest, CustomDocumentResponse, BackgroundGenerationRequest, BackgroundGenerationResponse, BackgroundGenerationStatusResponse, GenerateAnswersRequest, GenerateAnswersResponse, GenerateProjectOutlineRequest, GenerateProjectOutlineResponse, GenerateCoreFeaturesRequest, GenerateCoreFeaturesResponse, GenerateTechStackRequest, GenerateTechStackResponse, GenerateAppFlowRequest, GenerateAppFlowResponse } from './generation-types';
3
3
  export declare class GenerationService extends BaseService {
4
4
  refinePrompt(request: RefinePromptRequest): Promise<RefinePromptResponse>;
5
5
  generateTitle(request: GenerateTitleRequest): Promise<GenerateTitleResponse>;
@@ -12,4 +12,10 @@ export declare class GenerationService extends BaseService {
12
12
  generateMissingDocuments(request: GenerateMissingDocumentsRequest): Promise<GenerateMissingDocumentsResponse>;
13
13
  startBackgroundGeneration(request: BackgroundGenerationRequest): Promise<BackgroundGenerationResponse>;
14
14
  getBackgroundGenerationStatus(jobId: string): Promise<BackgroundGenerationStatusResponse>;
15
+ generateTechSpec(request: GenerateTechSpecRequest): Promise<CustomDocumentResponse>;
16
+ generateAnswers(request: GenerateAnswersRequest): Promise<GenerateAnswersResponse>;
17
+ generateProjectOutline(request: GenerateProjectOutlineRequest): Promise<GenerateProjectOutlineResponse>;
18
+ generateCoreFeatures(request: GenerateCoreFeaturesRequest): Promise<GenerateCoreFeaturesResponse>;
19
+ generateTechStack(request: GenerateTechStackRequest): Promise<GenerateTechStackResponse>;
20
+ generateAppFlow(request: GenerateAppFlowRequest): Promise<GenerateAppFlowResponse>;
15
21
  }
@@ -36,5 +36,23 @@ class GenerationService extends base_service_1.BaseService {
36
36
  async getBackgroundGenerationStatus(jobId) {
37
37
  return this.get(`/generate/background/${jobId}/status`);
38
38
  }
39
+ async generateTechSpec(request) {
40
+ return this.post('/generate/tech-spec', request);
41
+ }
42
+ async generateAnswers(request) {
43
+ return this.post('/generate/answers', request);
44
+ }
45
+ async generateProjectOutline(request) {
46
+ return this.post('/generate/project-outline', request);
47
+ }
48
+ async generateCoreFeatures(request) {
49
+ return this.post('/generate/core-features', request);
50
+ }
51
+ async generateTechStack(request) {
52
+ return this.post('/generate/tech-stack', request);
53
+ }
54
+ async generateAppFlow(request) {
55
+ return this.post('/generate/app-flow', request);
56
+ }
39
57
  }
40
58
  exports.GenerationService = GenerationService;
@@ -53,6 +53,7 @@ export interface GenerateOutlineResponse {
53
53
  outline: string;
54
54
  }
55
55
  export interface GenerateDocumentRequest {
56
+ project_id?: string;
56
57
  project_type?: string;
57
58
  description: string;
58
59
  selected_tools: string[];
@@ -109,3 +110,97 @@ export interface GenerateMissingDocumentsResponse {
109
110
  error?: string;
110
111
  generated_documents?: string[];
111
112
  }
113
+ export interface GenerateTechSpecRequest {
114
+ project_id: string;
115
+ }
116
+ export interface CustomDocumentResponse {
117
+ content: string;
118
+ }
119
+ export interface GenerateAnswersRequest {
120
+ title: string;
121
+ description: string;
122
+ questions: Array<{
123
+ question: string;
124
+ answer: string;
125
+ }>;
126
+ }
127
+ export interface GenerateAnswersResponse {
128
+ answers: Array<{
129
+ question: string;
130
+ answer: string;
131
+ }>;
132
+ }
133
+ export interface GenerateProjectOutlineRequest {
134
+ description: string;
135
+ project_type: string;
136
+ title?: string;
137
+ selected_tools?: string[];
138
+ answers?: Record<string, any>;
139
+ project_id?: string;
140
+ category_id?: string;
141
+ }
142
+ export interface GenerateProjectOutlineResponse {
143
+ outline: string;
144
+ project_id: string;
145
+ project_created: boolean;
146
+ }
147
+ export interface CoreFeature {
148
+ id: number;
149
+ title: string;
150
+ description: string;
151
+ icon_key: string;
152
+ }
153
+ export interface GenerateCoreFeaturesRequest {
154
+ context: string;
155
+ project_id?: string;
156
+ existing_features?: Array<{
157
+ id: number;
158
+ title: string;
159
+ description: string;
160
+ }>;
161
+ }
162
+ export interface GenerateCoreFeaturesResponse {
163
+ core_features: CoreFeature[];
164
+ project_id: string | null;
165
+ }
166
+ export interface TechStackItem {
167
+ id: number;
168
+ type: string;
169
+ name: string;
170
+ icon_key: string;
171
+ }
172
+ export interface GenerateTechStackRequest {
173
+ context: string;
174
+ project_id?: string;
175
+ existing_items?: Array<{
176
+ id: number;
177
+ type: string;
178
+ name: string;
179
+ }>;
180
+ }
181
+ export interface GenerateTechStackResponse {
182
+ tech_stack: TechStackItem[];
183
+ project_id: string | null;
184
+ }
185
+ export interface AppFlowItem {
186
+ id: number;
187
+ title: string;
188
+ page: string;
189
+ description: string;
190
+ index: number;
191
+ icon_key: string;
192
+ }
193
+ export interface GenerateAppFlowRequest {
194
+ context: string;
195
+ project_id?: string;
196
+ existing_items?: Array<{
197
+ id: number;
198
+ title: string;
199
+ page: string;
200
+ description: string;
201
+ }>;
202
+ }
203
+ export interface GenerateAppFlowResponse {
204
+ app_flow: AppFlowItem[];
205
+ project_id: string | null;
206
+ }
@@ -12,6 +12,8 @@ export { ExternalTokenService } from './external-tokens';
12
12
  export { SecurityKeysService } from './security-keys';
13
13
  export { UserService } from './users';
14
14
  export { StarterKitsService } from './starter-kits';
15
+ export { StreamingService } from './streaming';
16
+ export { ChatService } from './chat';
15
17
  export * from './generation';
16
18
  export * from './projects';
17
19
  export * from './usage';
@@ -25,3 +27,5 @@ export * from './external-tokens';
25
27
  export * from './security-keys';
26
28
  export * from './users';
27
29
  export * from './starter-kits';
30
+ export * from './streaming';
31
+ export * from './chat';
@@ -17,7 +17,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
17
17
  return (mod && mod.__esModule) ? mod : { "default": mod };
18
18
  };
19
19
  Object.defineProperty(exports, "__esModule", { value: true });
20
- exports.StarterKitsService = exports.UserService = exports.SecurityKeysService = exports.ExternalTokenService = exports.CodespaceService = exports.CancellationFunnelService = exports.SubscriptionService = exports.ApiKeyEnhancedService = exports.TaskService = exports.RepositoryAnalysisService = exports.UsageService = exports.ProjectService = exports.GenerationService = exports.BaseService = void 0;
20
+ exports.ChatService = exports.StreamingService = exports.StarterKitsService = exports.UserService = exports.SecurityKeysService = exports.ExternalTokenService = exports.CodespaceService = exports.CancellationFunnelService = exports.SubscriptionService = exports.ApiKeyEnhancedService = exports.TaskService = exports.RepositoryAnalysisService = exports.UsageService = exports.ProjectService = exports.GenerationService = exports.BaseService = void 0;
21
21
  const dotenv_1 = __importDefault(require("dotenv"));
22
22
  const path_1 = __importDefault(require("path"));
23
23
  // Load environment variables from project root
@@ -53,6 +53,10 @@ var users_1 = require("./users");
53
53
  Object.defineProperty(exports, "UserService", { enumerable: true, get: function () { return users_1.UserService; } });
54
54
  var starter_kits_1 = require("./starter-kits");
55
55
  Object.defineProperty(exports, "StarterKitsService", { enumerable: true, get: function () { return starter_kits_1.StarterKitsService; } });
56
+ var streaming_1 = require("./streaming");
57
+ Object.defineProperty(exports, "StreamingService", { enumerable: true, get: function () { return streaming_1.StreamingService; } });
58
+ var chat_1 = require("./chat");
59
+ Object.defineProperty(exports, "ChatService", { enumerable: true, get: function () { return chat_1.ChatService; } });
56
60
  // Re-export all types for convenience
57
61
  __exportStar(require("./generation"), exports);
58
62
  __exportStar(require("./projects"), exports);
@@ -67,3 +71,5 @@ __exportStar(require("./external-tokens"), exports);
67
71
  __exportStar(require("./security-keys"), exports);
68
72
  __exportStar(require("./users"), exports);
69
73
  __exportStar(require("./starter-kits"), exports);
74
+ __exportStar(require("./streaming"), exports);
75
+ __exportStar(require("./chat"), exports);
@@ -1,5 +1,5 @@
1
1
  import { BaseService } from '../base/base-service';
2
- import { Project, CreateProjectRequest, UpdateProjectRequest, PaginatedProjectsRequest, PaginatedProjectsResponse, GetProjectsRequest, GetProjectDocumentsRequest, GetProjectDocumentsResponse, ConnectRepositoryRequest, ConnectRepositoryResponse } from './project-types';
2
+ import { Project, CreateProjectRequest, UpdateProjectRequest, PaginatedProjectsRequest, PaginatedProjectsResponse, GetProjectsRequest, GetProjectDocumentsRequest, GetProjectDocumentsResponse, ConnectRepositoryRequest, ConnectRepositoryResponse, GetAiToolsRequest, GetAiToolsResponse } from './project-types';
3
3
  export declare class ProjectService extends BaseService {
4
4
  getAllProjects(params?: GetProjectsRequest): Promise<Project[]>;
5
5
  getPaginatedProjects(params: PaginatedProjectsRequest): Promise<PaginatedProjectsResponse>;
@@ -11,6 +11,8 @@ export declare class ProjectService extends BaseService {
11
11
  message: string;
12
12
  }>;
13
13
  getProjectDocuments(projectId: string, params?: GetProjectDocumentsRequest): Promise<GetProjectDocumentsResponse>;
14
+ getDocumentsByType(projectId: string, documentType: string): Promise<GetProjectDocumentsResponse>;
14
15
  connectRepository(projectId: string, request: ConnectRepositoryRequest): Promise<ConnectRepositoryResponse>;
15
16
  private validateConnectRepositoryRequest;
17
+ getAiTools(params?: GetAiToolsRequest): Promise<GetAiToolsResponse>;
16
18
  }
@@ -38,7 +38,7 @@ class ProjectService extends base_service_1.BaseService {
38
38
  return response.data;
39
39
  }
40
40
  async createProject(request) {
41
- const response = await this.post('/projects', request);
41
+ const response = await this.post('/projects/', request);
42
42
  return response.data;
43
43
  }
44
44
  async updateProject(projectId, request) {
@@ -56,6 +56,9 @@ class ProjectService extends base_service_1.BaseService {
56
56
  const url = `/projects/${projectId}/documents${queryParams.toString() ? `?${queryParams.toString()}` : ''}`;
57
57
  return this.get(url);
58
58
  }
59
+ async getDocumentsByType(projectId, documentType) {
60
+ return this.get(`/projects/${projectId}/documents/type/${documentType}`);
61
+ }
59
62
  async connectRepository(projectId, request) {
60
63
  this.validateConnectRepositoryRequest(request);
61
64
  const response = await this.post(`/projects/${projectId}/repository`, request);
@@ -82,5 +85,14 @@ class ProjectService extends base_service_1.BaseService {
82
85
  throw new Error('GitHub token must be a valid personal access token');
83
86
  }
84
87
  }
88
+ async getAiTools(params) {
89
+ const queryParams = new URLSearchParams();
90
+ if (params?.key)
91
+ queryParams.append('key', params.key);
92
+ if (params?.category)
93
+ queryParams.append('category', params.category);
94
+ const url = `/ai-tools${queryParams.toString() ? `?${queryParams.toString()}` : ''}`;
95
+ return this.get(url);
96
+ }
85
97
  }
86
98
  exports.ProjectService = ProjectService;