token.go 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  1. package controller
  2. import (
  3. "github.com/gin-gonic/gin"
  4. "net/http"
  5. "one-api/common"
  6. "one-api/model"
  7. "strconv"
  8. )
  9. func GetAllTokens(c *gin.Context) {
  10. userId := c.GetInt("id")
  11. p, _ := strconv.Atoi(c.Query("p"))
  12. size, _ := strconv.Atoi(c.Query("size"))
  13. if p < 0 {
  14. p = 0
  15. }
  16. if size <= 0 {
  17. size = common.ItemsPerPage
  18. } else if size > 100 {
  19. size = 100
  20. }
  21. tokens, err := model.GetAllUserTokens(userId, p*size, size)
  22. if err != nil {
  23. c.JSON(http.StatusOK, gin.H{
  24. "success": false,
  25. "message": err.Error(),
  26. })
  27. return
  28. }
  29. c.JSON(http.StatusOK, gin.H{
  30. "success": true,
  31. "message": "",
  32. "data": tokens,
  33. })
  34. return
  35. }
  36. func SearchTokens(c *gin.Context) {
  37. userId := c.GetInt("id")
  38. keyword := c.Query("keyword")
  39. token := c.Query("token")
  40. tokens, err := model.SearchUserTokens(userId, keyword, token)
  41. if err != nil {
  42. c.JSON(http.StatusOK, gin.H{
  43. "success": false,
  44. "message": err.Error(),
  45. })
  46. return
  47. }
  48. c.JSON(http.StatusOK, gin.H{
  49. "success": true,
  50. "message": "",
  51. "data": tokens,
  52. })
  53. return
  54. }
  55. func GetToken(c *gin.Context) {
  56. id, err := strconv.Atoi(c.Param("id"))
  57. userId := c.GetInt("id")
  58. if err != nil {
  59. c.JSON(http.StatusOK, gin.H{
  60. "success": false,
  61. "message": err.Error(),
  62. })
  63. return
  64. }
  65. token, err := model.GetTokenByIds(id, userId)
  66. if err != nil {
  67. c.JSON(http.StatusOK, gin.H{
  68. "success": false,
  69. "message": err.Error(),
  70. })
  71. return
  72. }
  73. c.JSON(http.StatusOK, gin.H{
  74. "success": true,
  75. "message": "",
  76. "data": token,
  77. })
  78. return
  79. }
  80. func GetTokenStatus(c *gin.Context) {
  81. tokenId := c.GetInt("token_id")
  82. userId := c.GetInt("id")
  83. token, err := model.GetTokenByIds(tokenId, userId)
  84. if err != nil {
  85. c.JSON(http.StatusOK, gin.H{
  86. "success": false,
  87. "message": err.Error(),
  88. })
  89. return
  90. }
  91. expiredAt := token.ExpiredTime
  92. if expiredAt == -1 {
  93. expiredAt = 0
  94. }
  95. c.JSON(http.StatusOK, gin.H{
  96. "object": "credit_summary",
  97. "total_granted": token.RemainQuota,
  98. "total_used": 0, // not supported currently
  99. "total_available": token.RemainQuota,
  100. "expires_at": expiredAt * 1000,
  101. })
  102. }
  103. func AddToken(c *gin.Context) {
  104. token := model.Token{}
  105. err := c.ShouldBindJSON(&token)
  106. if err != nil {
  107. c.JSON(http.StatusOK, gin.H{
  108. "success": false,
  109. "message": err.Error(),
  110. })
  111. return
  112. }
  113. if len(token.Name) > 30 {
  114. c.JSON(http.StatusOK, gin.H{
  115. "success": false,
  116. "message": "令牌名称过长",
  117. })
  118. return
  119. }
  120. cleanToken := model.Token{
  121. UserId: c.GetInt("id"),
  122. Name: token.Name,
  123. Key: common.GenerateKey(),
  124. CreatedTime: common.GetTimestamp(),
  125. AccessedTime: common.GetTimestamp(),
  126. ExpiredTime: token.ExpiredTime,
  127. RemainQuota: token.RemainQuota,
  128. UnlimitedQuota: token.UnlimitedQuota,
  129. ModelLimitsEnabled: token.ModelLimitsEnabled,
  130. ModelLimits: token.ModelLimits,
  131. AllowIps: token.AllowIps,
  132. Group: token.Group,
  133. }
  134. err = cleanToken.Insert()
  135. if err != nil {
  136. c.JSON(http.StatusOK, gin.H{
  137. "success": false,
  138. "message": err.Error(),
  139. })
  140. return
  141. }
  142. c.JSON(http.StatusOK, gin.H{
  143. "success": true,
  144. "message": "",
  145. })
  146. return
  147. }
  148. func DeleteToken(c *gin.Context) {
  149. id, _ := strconv.Atoi(c.Param("id"))
  150. userId := c.GetInt("id")
  151. err := model.DeleteTokenById(id, userId)
  152. if err != nil {
  153. c.JSON(http.StatusOK, gin.H{
  154. "success": false,
  155. "message": err.Error(),
  156. })
  157. return
  158. }
  159. c.JSON(http.StatusOK, gin.H{
  160. "success": true,
  161. "message": "",
  162. })
  163. return
  164. }
  165. func UpdateToken(c *gin.Context) {
  166. userId := c.GetInt("id")
  167. statusOnly := c.Query("status_only")
  168. token := model.Token{}
  169. err := c.ShouldBindJSON(&token)
  170. if err != nil {
  171. c.JSON(http.StatusOK, gin.H{
  172. "success": false,
  173. "message": err.Error(),
  174. })
  175. return
  176. }
  177. if len(token.Name) > 30 {
  178. c.JSON(http.StatusOK, gin.H{
  179. "success": false,
  180. "message": "令牌名称过长",
  181. })
  182. return
  183. }
  184. cleanToken, err := model.GetTokenByIds(token.Id, userId)
  185. if err != nil {
  186. c.JSON(http.StatusOK, gin.H{
  187. "success": false,
  188. "message": err.Error(),
  189. })
  190. return
  191. }
  192. if token.Status == common.TokenStatusEnabled {
  193. if cleanToken.Status == common.TokenStatusExpired && cleanToken.ExpiredTime <= common.GetTimestamp() && cleanToken.ExpiredTime != -1 {
  194. c.JSON(http.StatusOK, gin.H{
  195. "success": false,
  196. "message": "令牌已过期,无法启用,请先修改令牌过期时间,或者设置为永不过期",
  197. })
  198. return
  199. }
  200. if cleanToken.Status == common.TokenStatusExhausted && cleanToken.RemainQuota <= 0 && !cleanToken.UnlimitedQuota {
  201. c.JSON(http.StatusOK, gin.H{
  202. "success": false,
  203. "message": "令牌可用额度已用尽,无法启用,请先修改令牌剩余额度,或者设置为无限额度",
  204. })
  205. return
  206. }
  207. }
  208. if statusOnly != "" {
  209. cleanToken.Status = token.Status
  210. } else {
  211. // If you add more fields, please also update token.Update()
  212. cleanToken.Name = token.Name
  213. cleanToken.ExpiredTime = token.ExpiredTime
  214. cleanToken.RemainQuota = token.RemainQuota
  215. cleanToken.UnlimitedQuota = token.UnlimitedQuota
  216. cleanToken.ModelLimitsEnabled = token.ModelLimitsEnabled
  217. cleanToken.ModelLimits = token.ModelLimits
  218. cleanToken.AllowIps = token.AllowIps
  219. cleanToken.Group = token.Group
  220. }
  221. err = cleanToken.Update()
  222. if err != nil {
  223. c.JSON(http.StatusOK, gin.H{
  224. "success": false,
  225. "message": err.Error(),
  226. })
  227. return
  228. }
  229. c.JSON(http.StatusOK, gin.H{
  230. "success": true,
  231. "message": "",
  232. "data": cleanToken,
  233. })
  234. return
  235. }