init.go 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. package common
  2. import (
  3. "flag"
  4. "fmt"
  5. "log"
  6. "one-api/constant"
  7. "os"
  8. "path/filepath"
  9. "strconv"
  10. "time"
  11. )
  12. var (
  13. Port = flag.Int("port", 3000, "the listening port")
  14. PrintVersion = flag.Bool("version", false, "print version and exit")
  15. PrintHelp = flag.Bool("help", false, "print help and exit")
  16. LogDir = flag.String("log-dir", "./logs", "specify the log directory")
  17. )
  18. func printHelp() {
  19. fmt.Println("New API " + Version + " - All in one API service for OpenAI API.")
  20. fmt.Println("Copyright (C) 2023 JustSong. All rights reserved.")
  21. fmt.Println("GitHub: https://github.com/songquanpeng/one-api")
  22. fmt.Println("Usage: one-api [--port <port>] [--log-dir <log directory>] [--version] [--help]")
  23. }
  24. func InitEnv() {
  25. flag.Parse()
  26. if *PrintVersion {
  27. fmt.Println(Version)
  28. os.Exit(0)
  29. }
  30. if *PrintHelp {
  31. printHelp()
  32. os.Exit(0)
  33. }
  34. if os.Getenv("SESSION_SECRET") != "" {
  35. ss := os.Getenv("SESSION_SECRET")
  36. if ss == "random_string" {
  37. log.Println("WARNING: SESSION_SECRET is set to the default value 'random_string', please change it to a random string.")
  38. log.Println("警告:SESSION_SECRET被设置为默认值'random_string',请修改为随机字符串。")
  39. log.Fatal("Please set SESSION_SECRET to a random string.")
  40. } else {
  41. SessionSecret = ss
  42. }
  43. }
  44. if os.Getenv("CRYPTO_SECRET") != "" {
  45. CryptoSecret = os.Getenv("CRYPTO_SECRET")
  46. } else {
  47. CryptoSecret = SessionSecret
  48. }
  49. if os.Getenv("SQLITE_PATH") != "" {
  50. SQLitePath = os.Getenv("SQLITE_PATH")
  51. }
  52. if *LogDir != "" {
  53. var err error
  54. *LogDir, err = filepath.Abs(*LogDir)
  55. if err != nil {
  56. log.Fatal(err)
  57. }
  58. if _, err := os.Stat(*LogDir); os.IsNotExist(err) {
  59. err = os.Mkdir(*LogDir, 0777)
  60. if err != nil {
  61. log.Fatal(err)
  62. }
  63. }
  64. }
  65. // Initialize variables from constants.go that were using environment variables
  66. DebugEnabled = os.Getenv("DEBUG") == "true"
  67. MemoryCacheEnabled = os.Getenv("MEMORY_CACHE_ENABLED") == "true"
  68. IsMasterNode = os.Getenv("NODE_TYPE") != "slave"
  69. // Parse requestInterval and set RequestInterval
  70. requestInterval, _ = strconv.Atoi(os.Getenv("POLLING_INTERVAL"))
  71. RequestInterval = time.Duration(requestInterval) * time.Second
  72. // Initialize variables with GetEnvOrDefault
  73. SyncFrequency = GetEnvOrDefault("SYNC_FREQUENCY", 60)
  74. BatchUpdateInterval = GetEnvOrDefault("BATCH_UPDATE_INTERVAL", 5)
  75. RelayTimeout = GetEnvOrDefault("RELAY_TIMEOUT", 0)
  76. // Initialize string variables with GetEnvOrDefaultString
  77. GeminiSafetySetting = GetEnvOrDefaultString("GEMINI_SAFETY_SETTING", "BLOCK_NONE")
  78. CohereSafetySetting = GetEnvOrDefaultString("COHERE_SAFETY_SETTING", "NONE")
  79. // Initialize rate limit variables
  80. GlobalApiRateLimitEnable = GetEnvOrDefaultBool("GLOBAL_API_RATE_LIMIT_ENABLE", true)
  81. GlobalApiRateLimitNum = GetEnvOrDefault("GLOBAL_API_RATE_LIMIT", 180)
  82. GlobalApiRateLimitDuration = int64(GetEnvOrDefault("GLOBAL_API_RATE_LIMIT_DURATION", 180))
  83. GlobalWebRateLimitEnable = GetEnvOrDefaultBool("GLOBAL_WEB_RATE_LIMIT_ENABLE", true)
  84. GlobalWebRateLimitNum = GetEnvOrDefault("GLOBAL_WEB_RATE_LIMIT", 60)
  85. GlobalWebRateLimitDuration = int64(GetEnvOrDefault("GLOBAL_WEB_RATE_LIMIT_DURATION", 180))
  86. initConstantEnv()
  87. }
  88. func initConstantEnv() {
  89. constant.StreamingTimeout = GetEnvOrDefault("STREAMING_TIMEOUT", 120)
  90. constant.DifyDebug = GetEnvOrDefaultBool("DIFY_DEBUG", true)
  91. constant.MaxFileDownloadMB = GetEnvOrDefault("MAX_FILE_DOWNLOAD_MB", 20)
  92. // ForceStreamOption 覆盖请求参数,强制返回usage信息
  93. constant.ForceStreamOption = GetEnvOrDefaultBool("FORCE_STREAM_OPTION", true)
  94. constant.GetMediaToken = GetEnvOrDefaultBool("GET_MEDIA_TOKEN", true)
  95. constant.GetMediaTokenNotStream = GetEnvOrDefaultBool("GET_MEDIA_TOKEN_NOT_STREAM", true)
  96. constant.UpdateTask = GetEnvOrDefaultBool("UPDATE_TASK", true)
  97. constant.AzureDefaultAPIVersion = GetEnvOrDefaultString("AZURE_DEFAULT_API_VERSION", "2025-04-01-preview")
  98. constant.GeminiVisionMaxImageNum = GetEnvOrDefault("GEMINI_VISION_MAX_IMAGE_NUM", 16)
  99. constant.NotifyLimitCount = GetEnvOrDefault("NOTIFY_LIMIT_COUNT", 2)
  100. constant.NotificationLimitDurationMinute = GetEnvOrDefault("NOTIFICATION_LIMIT_DURATION_MINUTE", 10)
  101. // GenerateDefaultToken 是否生成初始令牌,默认关闭。
  102. constant.GenerateDefaultToken = GetEnvOrDefaultBool("GENERATE_DEFAULT_TOKEN", false)
  103. // 是否启用错误日志
  104. constant.ErrorLogEnabled = GetEnvOrDefaultBool("ERROR_LOG_ENABLED", false)
  105. }