Dragonfly2

Форк
0
/
personal_access_token.go 
99 строк · 3.2 Кб
1
/*
2
 *     Copyright 2023 The Dragonfly Authors
3
 *
4
 * Licensed under the Apache License, Version 2.0 (the "License");
5
 * you may not use this file except in compliance with the License.
6
 * You may obtain a copy of the License at
7
 *
8
 *      http://www.apache.org/licenses/LICENSE-2.0
9
 *
10
 * Unless required by applicable law or agreed to in writing, software
11
 * distributed under the License is distributed on an "AS IS" BASIS,
12
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
 * See the License for the specific language governing permissions and
14
 * limitations under the License.
15
 */
16

17
package service
18

19
import (
20
	"context"
21
	"encoding/base64"
22

23
	"github.com/google/uuid"
24

25
	"d7y.io/dragonfly/v2/manager/models"
26
	"d7y.io/dragonfly/v2/manager/types"
27
)
28

29
func (s *service) CreatePersonalAccessToken(ctx context.Context, json types.CreatePersonalAccessTokenRequest) (*models.PersonalAccessToken, error) {
30
	personalAccessToken := models.PersonalAccessToken{
31
		Name:      json.Name,
32
		BIO:       json.BIO,
33
		Token:     s.generatePersonalAccessToken(),
34
		Scopes:    json.Scopes,
35
		State:     models.PersonalAccessTokenStateActive,
36
		ExpiredAt: json.ExpiredAt,
37
		UserID:    json.UserID,
38
	}
39

40
	if err := s.db.WithContext(ctx).Create(&personalAccessToken).Error; err != nil {
41
		return nil, err
42
	}
43

44
	return &personalAccessToken, nil
45
}
46

47
func (s *service) DestroyPersonalAccessToken(ctx context.Context, id uint) error {
48
	personalAccessToken := models.PersonalAccessToken{}
49
	if err := s.db.WithContext(ctx).First(&personalAccessToken, id).Error; err != nil {
50
		return err
51
	}
52

53
	if err := s.db.WithContext(ctx).Unscoped().Delete(&models.PersonalAccessToken{}, id).Error; err != nil {
54
		return err
55
	}
56

57
	return nil
58
}
59

60
func (s *service) UpdatePersonalAccessToken(ctx context.Context, id uint, json types.UpdatePersonalAccessTokenRequest) (*models.PersonalAccessToken, error) {
61
	personalAccessToken := models.PersonalAccessToken{}
62
	if err := s.db.WithContext(ctx).Preload("User").First(&personalAccessToken, id).Updates(models.PersonalAccessToken{
63
		BIO:       json.BIO,
64
		Scopes:    json.Scopes,
65
		State:     json.State,
66
		ExpiredAt: json.ExpiredAt,
67
		UserID:    json.UserID,
68
	}).Error; err != nil {
69
		return nil, err
70
	}
71

72
	return &personalAccessToken, nil
73
}
74

75
func (s *service) GetPersonalAccessToken(ctx context.Context, id uint) (*models.PersonalAccessToken, error) {
76
	personalAccessToken := models.PersonalAccessToken{}
77
	if err := s.db.WithContext(ctx).Preload("User").First(&personalAccessToken, id).Error; err != nil {
78
		return nil, err
79
	}
80

81
	return &personalAccessToken, nil
82
}
83

84
func (s *service) GetPersonalAccessTokens(ctx context.Context, q types.GetPersonalAccessTokensQuery) ([]models.PersonalAccessToken, int64, error) {
85
	var count int64
86
	personalAccessToken := []models.PersonalAccessToken{}
87
	if err := s.db.WithContext(ctx).Scopes(models.Paginate(q.Page, q.PerPage)).Where(&models.PersonalAccessToken{
88
		State:  q.State,
89
		UserID: q.UserID,
90
	}).Preload("User").Find(&personalAccessToken).Limit(-1).Offset(-1).Count(&count).Error; err != nil {
91
		return nil, 0, err
92
	}
93

94
	return personalAccessToken, count, nil
95
}
96

97
func (s *service) generatePersonalAccessToken() string {
98
	return base64.RawURLEncoding.EncodeToString([]byte(uuid.NewString()))
99
}
100

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.