token.go 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239
  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. }
  132. err = cleanToken.Insert()
  133. if err != nil {
  134. c.JSON(http.StatusOK, gin.H{
  135. "success": false,
  136. "message": err.Error(),
  137. })
  138. return
  139. }
  140. c.JSON(http.StatusOK, gin.H{
  141. "success": true,
  142. "message": "",
  143. })
  144. return
  145. }
  146. func DeleteToken(c *gin.Context) {
  147. id, _ := strconv.Atoi(c.Param("id"))
  148. userId := c.GetInt("id")
  149. err := model.DeleteTokenById(id, userId)
  150. if err != nil {
  151. c.JSON(http.StatusOK, gin.H{
  152. "success": false,
  153. "message": err.Error(),
  154. })
  155. return
  156. }
  157. c.JSON(http.StatusOK, gin.H{
  158. "success": true,
  159. "message": "",
  160. })
  161. return
  162. }
  163. func UpdateToken(c *gin.Context) {
  164. userId := c.GetInt("id")
  165. statusOnly := c.Query("status_only")
  166. token := model.Token{}
  167. err := c.ShouldBindJSON(&token)
  168. if err != nil {
  169. c.JSON(http.StatusOK, gin.H{
  170. "success": false,
  171. "message": err.Error(),
  172. })
  173. return
  174. }
  175. if len(token.Name) > 30 {
  176. c.JSON(http.StatusOK, gin.H{
  177. "success": false,
  178. "message": "令牌名称过长",
  179. })
  180. return
  181. }
  182. cleanToken, err := model.GetTokenByIds(token.Id, userId)
  183. if err != nil {
  184. c.JSON(http.StatusOK, gin.H{
  185. "success": false,
  186. "message": err.Error(),
  187. })
  188. return
  189. }
  190. if token.Status == common.TokenStatusEnabled {
  191. if cleanToken.Status == common.TokenStatusExpired && cleanToken.ExpiredTime <= common.GetTimestamp() && cleanToken.ExpiredTime != -1 {
  192. c.JSON(http.StatusOK, gin.H{
  193. "success": false,
  194. "message": "令牌已过期,无法启用,请先修改令牌过期时间,或者设置为永不过期",
  195. })
  196. return
  197. }
  198. if cleanToken.Status == common.TokenStatusExhausted && cleanToken.RemainQuota <= 0 && !cleanToken.UnlimitedQuota {
  199. c.JSON(http.StatusOK, gin.H{
  200. "success": false,
  201. "message": "令牌可用额度已用尽,无法启用,请先修改令牌剩余额度,或者设置为无限额度",
  202. })
  203. return
  204. }
  205. }
  206. if statusOnly != "" {
  207. cleanToken.Status = token.Status
  208. } else {
  209. // If you add more fields, please also update token.Update()
  210. cleanToken.Name = token.Name
  211. cleanToken.ExpiredTime = token.ExpiredTime
  212. cleanToken.RemainQuota = token.RemainQuota
  213. cleanToken.UnlimitedQuota = token.UnlimitedQuota
  214. cleanToken.ModelLimitsEnabled = token.ModelLimitsEnabled
  215. cleanToken.ModelLimits = token.ModelLimits
  216. }
  217. err = cleanToken.Update()
  218. if err != nil {
  219. c.JSON(http.StatusOK, gin.H{
  220. "success": false,
  221. "message": err.Error(),
  222. })
  223. return
  224. }
  225. c.JSON(http.StatusOK, gin.H{
  226. "success": true,
  227. "message": "",
  228. "data": cleanToken,
  229. })
  230. return
  231. }