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.

completion-params.ts 2.5KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. import type { FormValue, ModelParameterRule } from '@/app/components/header/account-setting/model-provider-page/declarations'
  2. export const mergeValidCompletionParams = (
  3. oldParams: FormValue | undefined,
  4. rules: ModelParameterRule[],
  5. ): { params: FormValue; removedDetails: Record<string, string> } => {
  6. if (!oldParams || Object.keys(oldParams).length === 0)
  7. return { params: {}, removedDetails: {} }
  8. const ruleMap: Record<string, ModelParameterRule> = {}
  9. rules.forEach((r) => {
  10. ruleMap[r.name] = r
  11. })
  12. const nextParams: FormValue = {}
  13. const removedDetails: Record<string, string> = {}
  14. Object.entries(oldParams).forEach(([key, value]) => {
  15. const rule = ruleMap[key]
  16. if (!rule) {
  17. removedDetails[key] = 'unsupported'
  18. return
  19. }
  20. switch (rule.type) {
  21. case 'int':
  22. case 'float': {
  23. if (typeof value !== 'number') {
  24. removedDetails[key] = 'invalid type'
  25. return
  26. }
  27. const min = rule.min ?? Number.NEGATIVE_INFINITY
  28. const max = rule.max ?? Number.POSITIVE_INFINITY
  29. if (value < min || value > max) {
  30. removedDetails[key] = `out of range (${min}-${max})`
  31. return
  32. }
  33. nextParams[key] = value
  34. return
  35. }
  36. case 'boolean': {
  37. if (typeof value !== 'boolean') {
  38. removedDetails[key] = 'invalid type'
  39. return
  40. }
  41. nextParams[key] = value
  42. return
  43. }
  44. case 'string':
  45. case 'text': {
  46. if (typeof value !== 'string') {
  47. removedDetails[key] = 'invalid type'
  48. return
  49. }
  50. if (Array.isArray(rule.options) && rule.options.length) {
  51. if (!(rule.options as string[]).includes(value)) {
  52. removedDetails[key] = 'unsupported option'
  53. return
  54. }
  55. }
  56. nextParams[key] = value
  57. return
  58. }
  59. default: {
  60. removedDetails[key] = `unsupported rule type: ${(rule as any)?.type ?? 'unknown'}`
  61. }
  62. }
  63. })
  64. return { params: nextParams, removedDetails }
  65. }
  66. export const fetchAndMergeValidCompletionParams = async (
  67. provider: string,
  68. modelId: string,
  69. oldParams: FormValue | undefined,
  70. ): Promise<{ params: FormValue; removedDetails: Record<string, string> }> => {
  71. const { fetchModelParameterRules } = await import('@/service/common')
  72. const url = `/workspaces/current/model-providers/${provider}/models/parameter-rules?model=${modelId}`
  73. const { data: parameterRules } = await fetchModelParameterRules(url)
  74. return mergeValidCompletionParams(oldParams, parameterRules ?? [])
  75. }