token.go 5.1 KB

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