Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

utils.ts 5.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  1. import { ValidatedStatus } from '../key-validator/declarations'
  2. import type {
  3. CredentialFormSchemaTextInput,
  4. FormValue,
  5. ModelLoadBalancingConfig,
  6. } from './declarations'
  7. import {
  8. ConfigurationMethodEnum,
  9. FormTypeEnum,
  10. MODEL_TYPE_TEXT,
  11. ModelTypeEnum,
  12. } from './declarations'
  13. import {
  14. deleteModelProvider,
  15. setModelProvider,
  16. validateModelLoadBalancingCredentials,
  17. validateModelProvider,
  18. } from '@/service/common'
  19. export const MODEL_PROVIDER_QUOTA_GET_PAID = ['langgenius/anthropic/anthropic', 'langgenius/openai/openai', 'langgenius/azure_openai/azure_openai']
  20. export const isNullOrUndefined = (value: any) => {
  21. return value === undefined || value === null
  22. }
  23. export const validateCredentials = async (predefined: boolean, provider: string, v: FormValue) => {
  24. let body, url
  25. if (predefined) {
  26. body = {
  27. credentials: v,
  28. }
  29. url = `/workspaces/current/model-providers/${provider}/credentials/validate`
  30. }
  31. else {
  32. const { __model_name, __model_type, ...credentials } = v
  33. body = {
  34. model: __model_name,
  35. model_type: __model_type,
  36. credentials,
  37. }
  38. url = `/workspaces/current/model-providers/${provider}/models/credentials/validate`
  39. }
  40. try {
  41. const res = await validateModelProvider({ url, body })
  42. if (res.result === 'success')
  43. return Promise.resolve({ status: ValidatedStatus.Success })
  44. else
  45. return Promise.resolve({ status: ValidatedStatus.Error, message: res.error || 'error' })
  46. }
  47. catch (e: any) {
  48. return Promise.resolve({ status: ValidatedStatus.Error, message: e.message })
  49. }
  50. }
  51. export const validateLoadBalancingCredentials = async (predefined: boolean, provider: string, v: FormValue, id?: string): Promise<{
  52. status: ValidatedStatus
  53. message?: string
  54. }> => {
  55. const { __model_name, __model_type, ...credentials } = v
  56. try {
  57. const res = await validateModelLoadBalancingCredentials({
  58. url: `/workspaces/current/model-providers/${provider}/models/load-balancing-configs/${id ? `${id}/` : ''}credentials-validate`,
  59. body: {
  60. model: __model_name,
  61. model_type: __model_type,
  62. credentials,
  63. },
  64. })
  65. if (res.result === 'success')
  66. return Promise.resolve({ status: ValidatedStatus.Success })
  67. else
  68. return Promise.resolve({ status: ValidatedStatus.Error, message: res.error || 'error' })
  69. }
  70. catch (e: any) {
  71. return Promise.resolve({ status: ValidatedStatus.Error, message: e.message })
  72. }
  73. }
  74. export const saveCredentials = async (predefined: boolean, provider: string, v: FormValue, loadBalancing?: ModelLoadBalancingConfig) => {
  75. let body, url
  76. if (predefined) {
  77. const { __authorization_name__, ...rest } = v
  78. body = {
  79. config_from: ConfigurationMethodEnum.predefinedModel,
  80. credentials: rest,
  81. load_balancing: loadBalancing,
  82. name: __authorization_name__,
  83. }
  84. url = `/workspaces/current/model-providers/${provider}/credentials`
  85. }
  86. else {
  87. const { __model_name, __model_type, ...credentials } = v
  88. body = {
  89. model: __model_name,
  90. model_type: __model_type,
  91. credentials,
  92. load_balancing: loadBalancing,
  93. }
  94. url = `/workspaces/current/model-providers/${provider}/models`
  95. }
  96. return setModelProvider({ url, body })
  97. }
  98. export const savePredefinedLoadBalancingConfig = async (provider: string, v: FormValue, loadBalancing?: ModelLoadBalancingConfig) => {
  99. const { __model_name, __model_type, ...credentials } = v
  100. const body = {
  101. config_from: ConfigurationMethodEnum.predefinedModel,
  102. model: __model_name,
  103. model_type: __model_type,
  104. credentials,
  105. load_balancing: loadBalancing,
  106. }
  107. const url = `/workspaces/current/model-providers/${provider}/models`
  108. return setModelProvider({ url, body })
  109. }
  110. export const removeCredentials = async (predefined: boolean, provider: string, v: FormValue, credentialId?: string) => {
  111. let url = ''
  112. let body
  113. if (predefined) {
  114. url = `/workspaces/current/model-providers/${provider}/credentials`
  115. if (credentialId) {
  116. body = {
  117. credential_id: credentialId,
  118. }
  119. }
  120. }
  121. else {
  122. if (v) {
  123. const { __model_name, __model_type } = v
  124. body = {
  125. model: __model_name,
  126. model_type: __model_type,
  127. }
  128. url = `/workspaces/current/model-providers/${provider}/models`
  129. }
  130. }
  131. return deleteModelProvider({ url, body })
  132. }
  133. export const sizeFormat = (size: number) => {
  134. const remainder = Math.floor(size / 1000)
  135. if (remainder < 1)
  136. return `${size}`
  137. else
  138. return `${remainder}K`
  139. }
  140. export const modelTypeFormat = (modelType: ModelTypeEnum) => {
  141. if (modelType === ModelTypeEnum.textEmbedding)
  142. return 'TEXT EMBEDDING'
  143. return modelType.toLocaleUpperCase()
  144. }
  145. export const genModelTypeFormSchema = (modelTypes: ModelTypeEnum[]) => {
  146. return {
  147. type: FormTypeEnum.radio,
  148. label: {
  149. zh_Hans: '模型类型',
  150. en_US: 'Model Type',
  151. },
  152. variable: '__model_type',
  153. default: modelTypes[0],
  154. required: true,
  155. show_on: [],
  156. options: modelTypes.map((modelType: ModelTypeEnum) => {
  157. return {
  158. value: modelType,
  159. label: {
  160. zh_Hans: MODEL_TYPE_TEXT[modelType],
  161. en_US: MODEL_TYPE_TEXT[modelType],
  162. },
  163. show_on: [],
  164. }
  165. }),
  166. } as any
  167. }
  168. export const genModelNameFormSchema = (model?: Pick<CredentialFormSchemaTextInput, 'label' | 'placeholder'>) => {
  169. return {
  170. type: FormTypeEnum.textInput,
  171. label: model?.label || {
  172. zh_Hans: '模型名称',
  173. en_US: 'Model Name',
  174. },
  175. variable: '__model_name',
  176. required: true,
  177. show_on: [],
  178. placeholder: model?.placeholder || {
  179. zh_Hans: '请输入模型名称',
  180. en_US: 'Please enter model name',
  181. },
  182. } as any
  183. }