You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. import type { Fetcher } from 'swr'
  2. import { del, get, patch, post, put } from './base'
  3. import type { ApiKeysListResponse, AppDailyConversationsResponse, AppDailyEndUsersResponse, AppDailyMessagesResponse, AppDetailResponse, AppListResponse, AppStatisticsResponse, AppTemplatesResponse, AppTokenCostsResponse, AppVoicesListResponse, CreateApiKeyResponse, DSLImportMode, DSLImportResponse, GenerationIntroductionResponse, TracingConfig, TracingStatus, UpdateAppModelConfigResponse, UpdateAppSiteCodeResponse, UpdateOpenAIKeyResponse, ValidateOpenAIKeyResponse, WorkflowDailyConversationsResponse } from '@/models/app'
  4. import type { CommonResponse } from '@/models/common'
  5. import type { AppIconType, AppMode, ModelConfig } from '@/types/app'
  6. import type { TracingProvider } from '@/app/(commonLayout)/app/(appDetailLayout)/[appId]/overview/tracing/type'
  7. export const fetchAppList: Fetcher<AppListResponse, { url: string; params?: Record<string, any> }> = ({ url, params }) => {
  8. return get<AppListResponse>(url, { params })
  9. }
  10. export const fetchAppDetail: Fetcher<AppDetailResponse, { url: string; id: string }> = ({ url, id }) => {
  11. return get<AppDetailResponse>(`${url}/${id}`)
  12. }
  13. // Direct API call function for non-SWR usage
  14. export const fetchAppDetailDirect = async ({ url, id }: { url: string; id: string }): Promise<AppDetailResponse> => {
  15. return get<AppDetailResponse>(`${url}/${id}`)
  16. }
  17. export const fetchAppTemplates: Fetcher<AppTemplatesResponse, { url: string }> = ({ url }) => {
  18. return get<AppTemplatesResponse>(url)
  19. }
  20. export const createApp: Fetcher<AppDetailResponse, { name: string; icon_type?: AppIconType; icon?: string; icon_background?: string; mode: AppMode; description?: string; config?: ModelConfig }> = ({ name, icon_type, icon, icon_background, mode, description, config }) => {
  21. return post<AppDetailResponse>('apps', { body: { name, icon_type, icon, icon_background, mode, description, model_config: config } })
  22. }
  23. export const updateAppInfo: Fetcher<AppDetailResponse, { appID: string; name: string; icon_type: AppIconType; icon: string; icon_background?: string; description: string; use_icon_as_answer_icon?: boolean; max_active_requests?: number | null }> = ({ appID, name, icon_type, icon, icon_background, description, use_icon_as_answer_icon, max_active_requests }) => {
  24. const body = { name, icon_type, icon, icon_background, description, use_icon_as_answer_icon, max_active_requests }
  25. return put<AppDetailResponse>(`apps/${appID}`, { body })
  26. }
  27. export const copyApp: Fetcher<AppDetailResponse, { appID: string; name: string; icon_type: AppIconType; icon: string; icon_background?: string | null; mode: AppMode; description?: string }> = ({ appID, name, icon_type, icon, icon_background, mode, description }) => {
  28. return post<AppDetailResponse>(`apps/${appID}/copy`, { body: { name, icon_type, icon, icon_background, mode, description } })
  29. }
  30. export const exportAppConfig: Fetcher<{ data: string }, { appID: string; include?: boolean }> = ({ appID, include = false }) => {
  31. return get<{ data: string }>(`apps/${appID}/export?include_secret=${include}`)
  32. }
  33. // TODO: delete
  34. export const importApp: Fetcher<AppDetailResponse, { data: string; name?: string; description?: string; icon_type?: AppIconType; icon?: string; icon_background?: string }> = ({ data, name, description, icon_type, icon, icon_background }) => {
  35. return post<AppDetailResponse>('apps/import', { body: { data, name, description, icon_type, icon, icon_background } })
  36. }
  37. // TODO: delete
  38. export const importAppFromUrl: Fetcher<AppDetailResponse, { url: string; name?: string; description?: string; icon?: string; icon_background?: string }> = ({ url, name, description, icon, icon_background }) => {
  39. return post<AppDetailResponse>('apps/import/url', { body: { url, name, description, icon, icon_background } })
  40. }
  41. export const importDSL: Fetcher<DSLImportResponse, { mode: DSLImportMode; yaml_content?: string; yaml_url?: string; app_id?: string; name?: string; description?: string; icon_type?: AppIconType; icon?: string; icon_background?: string }> = ({ mode, yaml_content, yaml_url, app_id, name, description, icon_type, icon, icon_background }) => {
  42. return post<DSLImportResponse>('apps/imports', { body: { mode, yaml_content, yaml_url, app_id, name, description, icon, icon_type, icon_background } })
  43. }
  44. export const importDSLConfirm: Fetcher<DSLImportResponse, { import_id: string }> = ({ import_id }) => {
  45. return post<DSLImportResponse>(`apps/imports/${import_id}/confirm`, { body: {} })
  46. }
  47. export const switchApp: Fetcher<{ new_app_id: string }, { appID: string; name: string; icon_type: AppIconType; icon: string; icon_background?: string | null }> = ({ appID, name, icon_type, icon, icon_background }) => {
  48. return post<{ new_app_id: string }>(`apps/${appID}/convert-to-workflow`, { body: { name, icon_type, icon, icon_background } })
  49. }
  50. export const deleteApp: Fetcher<CommonResponse, string> = (appID) => {
  51. return del<CommonResponse>(`apps/${appID}`)
  52. }
  53. export const updateAppSiteStatus: Fetcher<AppDetailResponse, { url: string; body: Record<string, any> }> = ({ url, body }) => {
  54. return post<AppDetailResponse>(url, { body })
  55. }
  56. export const updateAppApiStatus: Fetcher<AppDetailResponse, { url: string; body: Record<string, any> }> = ({ url, body }) => {
  57. return post<AppDetailResponse>(url, { body })
  58. }
  59. // path: /apps/{appId}/rate-limit
  60. export const updateAppRateLimit: Fetcher<AppDetailResponse, { url: string; body: Record<string, any> }> = ({ url, body }) => {
  61. return post<AppDetailResponse>(url, { body })
  62. }
  63. export const updateAppSiteAccessToken: Fetcher<UpdateAppSiteCodeResponse, { url: string }> = ({ url }) => {
  64. return post<UpdateAppSiteCodeResponse>(url)
  65. }
  66. export const updateAppSiteConfig = ({ url, body }: { url: string; body: Record<string, any> }) => {
  67. return post<AppDetailResponse>(url, { body })
  68. }
  69. export const getAppDailyMessages: Fetcher<AppDailyMessagesResponse, { url: string; params: Record<string, any> }> = ({ url, params }) => {
  70. return get<AppDailyMessagesResponse>(url, { params })
  71. }
  72. export const getAppDailyConversations: Fetcher<AppDailyConversationsResponse, { url: string; params: Record<string, any> }> = ({ url, params }) => {
  73. return get<AppDailyConversationsResponse>(url, { params })
  74. }
  75. export const getWorkflowDailyConversations: Fetcher<WorkflowDailyConversationsResponse, { url: string; params: Record<string, any> }> = ({ url, params }) => {
  76. return get<WorkflowDailyConversationsResponse>(url, { params })
  77. }
  78. export const getAppStatistics: Fetcher<AppStatisticsResponse, { url: string; params: Record<string, any> }> = ({ url, params }) => {
  79. return get<AppStatisticsResponse>(url, { params })
  80. }
  81. export const getAppDailyEndUsers: Fetcher<AppDailyEndUsersResponse, { url: string; params: Record<string, any> }> = ({ url, params }) => {
  82. return get<AppDailyEndUsersResponse>(url, { params })
  83. }
  84. export const getAppTokenCosts: Fetcher<AppTokenCostsResponse, { url: string; params: Record<string, any> }> = ({ url, params }) => {
  85. return get<AppTokenCostsResponse>(url, { params })
  86. }
  87. export const updateAppModelConfig: Fetcher<UpdateAppModelConfigResponse, { url: string; body: Record<string, any> }> = ({ url, body }) => {
  88. return post<UpdateAppModelConfigResponse>(url, { body })
  89. }
  90. // For temp testing
  91. export const fetchAppListNoMock: Fetcher<AppListResponse, { url: string; params: Record<string, any> }> = ({ url, params }) => {
  92. return get<AppListResponse>(url, params)
  93. }
  94. export const fetchApiKeysList: Fetcher<ApiKeysListResponse, { url: string; params: Record<string, any> }> = ({ url, params }) => {
  95. return get<ApiKeysListResponse>(url, params)
  96. }
  97. export const delApikey: Fetcher<CommonResponse, { url: string; params: Record<string, any> }> = ({ url, params }) => {
  98. return del<CommonResponse>(url, params)
  99. }
  100. export const createApikey: Fetcher<CreateApiKeyResponse, { url: string; body: Record<string, any> }> = ({ url, body }) => {
  101. return post<CreateApiKeyResponse>(url, body)
  102. }
  103. export const validateOpenAIKey: Fetcher<ValidateOpenAIKeyResponse, { url: string; body: { token: string } }> = ({ url, body }) => {
  104. return post<ValidateOpenAIKeyResponse>(url, { body })
  105. }
  106. export const updateOpenAIKey: Fetcher<UpdateOpenAIKeyResponse, { url: string; body: { token: string } }> = ({ url, body }) => {
  107. return post<UpdateOpenAIKeyResponse>(url, { body })
  108. }
  109. export const generationIntroduction: Fetcher<GenerationIntroductionResponse, { url: string; body: { prompt_template: string } }> = ({ url, body }) => {
  110. return post<GenerationIntroductionResponse>(url, { body })
  111. }
  112. export const fetchAppVoices: Fetcher<AppVoicesListResponse, { appId: string; language?: string }> = ({ appId, language }) => {
  113. language = language || 'en-US'
  114. return get<AppVoicesListResponse>(`apps/${appId}/text-to-audio/voices?language=${language}`)
  115. }
  116. // Tracing
  117. export const fetchTracingStatus: Fetcher<TracingStatus, { appId: string }> = ({ appId }) => {
  118. return get(`/apps/${appId}/trace`)
  119. }
  120. export const updateTracingStatus: Fetcher<CommonResponse, { appId: string; body: Record<string, any> }> = ({ appId, body }) => {
  121. return post(`/apps/${appId}/trace`, { body })
  122. }
  123. export const fetchTracingConfig: Fetcher<TracingConfig & { has_not_configured: true }, { appId: string; provider: TracingProvider }> = ({ appId, provider }) => {
  124. return get(`/apps/${appId}/trace-config`, {
  125. params: {
  126. tracing_provider: provider,
  127. },
  128. })
  129. }
  130. export const addTracingConfig: Fetcher<CommonResponse, { appId: string; body: TracingConfig }> = ({ appId, body }) => {
  131. return post(`/apps/${appId}/trace-config`, { body })
  132. }
  133. export const updateTracingConfig: Fetcher<CommonResponse, { appId: string; body: TracingConfig }> = ({ appId, body }) => {
  134. return patch(`/apps/${appId}/trace-config`, { body })
  135. }
  136. export const removeTracingConfig: Fetcher<CommonResponse, { appId: string; provider: TracingProvider }> = ({ appId, provider }) => {
  137. return del(`/apps/${appId}/trace-config?tracing_provider=${provider}`)
  138. }