summaryrefslogtreecommitdiffstats
path: root/app/controllers
ModeNameSize
-rw-r--r--account_controller.rb5787logstatsplain
-rw-r--r--admin_controller.rb2916logstatsplain
-rw-r--r--application.rb5332logstatsplain
-rw-r--r--attachments_controller.rb1422logstatsplain
-rw-r--r--auth_sources_controller.rb2455logstatsplain
-rw-r--r--boards_controller.rb2925logstatsplain
-rw-r--r--custom_fields_controller.rb2632logstatsplain
-rw-r--r--documents_controller.rb2466logstatsplain
-rw-r--r--enumerations_controller.rb2461logstatsplain
-rw-r--r--feeds_controller.rb3856logstatsplain
-rw-r--r--help_controller.rb1746logstatsplain
-rw-r--r--issue_categories_controller.rb1992logstatsplain
-rw-r--r--issue_relations_controller.rb2069logstatsplain
-rw-r--r--issue_statuses_controller.rb2480logstatsplain
-rw-r--r--issues_controller.rb7995logstatsplain
-rw-r--r--members_controller.rb2296logstatsplain
-rw-r--r--messages_controller.rb2122logstatsplain
-rw-r--r--my_controller.rb4911logstatsplain
-rw-r--r--news_controller.rb1804logstatsplain
-rw-r--r--projects_controller.rb26845logstatsplain
-rw-r--r--queries_controller.rb2991logstatsplain
-rw-r--r--reports_controller.rb9717logstatsplain
-rw-r--r--repositories_controller.rb8312logstatsplain
-rw-r--r--roles_controller.rb3509logstatsplain
-rw-r--r--search_controller.rb4035logstatsplain
-rw-r--r--settings_controller.rb1626logstatsplain
-rw-r--r--sys_controller.rb1458logstatsplain
-rw-r--r--timelog_controller.rb6928logstatsplain
-rw-r--r--trackers_controller.rb2585logstatsplain
-rw-r--r--users_controller.rb4721logstatsplain
-rw-r--r--versions_controller.rb2129logstatsplain
-rw-r--r--watchers_controller.rb1765logstatsplain
-rw-r--r--welcome_controller.rb964logstatsplain
-rw-r--r--wiki_controller.rb6520logstatsplain
-rw-r--r--wikis_controller.rb1574logstatsplain
an class="nb">len(t.Token)-8:] _, err = db.GetEngine(db.DefaultContext).Insert(t) return err } func getAccessTokenIDFromCache(token string) int64 { if successfulAccessTokenCache == nil { return 0 } tInterface, ok := successfulAccessTokenCache.Get(token) if !ok { return 0 } t, ok := tInterface.(int64) if !ok { return 0 } return t } // GetAccessTokenBySHA returns access token by given token value func GetAccessTokenBySHA(token string) (*AccessToken, error) { if token == "" { return nil, ErrAccessTokenEmpty{} } // A token is defined as being SHA1 sum these are 40 hexadecimal bytes long if len(token) != 40 { return nil, ErrAccessTokenNotExist{token} } for _, x := range []byte(token) { if x < '0' || (x > '9' && x < 'a') || x > 'f' { return nil, ErrAccessTokenNotExist{token} } } lastEight := token[len(token)-8:] if id := getAccessTokenIDFromCache(token); id > 0 { token := &AccessToken{ TokenLastEight: lastEight, } // Re-get the token from the db in case it has been deleted in the intervening period has, err := db.GetEngine(db.DefaultContext).ID(id).Get(token) if err != nil { return nil, err } if has { return token, nil } successfulAccessTokenCache.Remove(token) } var tokens []AccessToken err := db.GetEngine(db.DefaultContext).Table(&AccessToken{}).Where("token_last_eight = ?", lastEight).Find(&tokens) if err != nil { return nil, err } else if len(tokens) == 0 { return nil, ErrAccessTokenNotExist{token} } for _, t := range tokens { tempHash := login.HashToken(token, t.TokenSalt) if subtle.ConstantTimeCompare([]byte(t.TokenHash), []byte(tempHash)) == 1 { if successfulAccessTokenCache != nil { successfulAccessTokenCache.Add(token, t.ID) } return &t, nil } } return nil, ErrAccessTokenNotExist{token} } // AccessTokenByNameExists checks if a token name has been used already by a user. func AccessTokenByNameExists(token *AccessToken) (bool, error) { return db.GetEngine(db.DefaultContext).Table("access_token").Where("name = ?", token.Name).And("uid = ?", token.UID).Exist() } // ListAccessTokensOptions contain filter options type ListAccessTokensOptions struct { db.ListOptions Name string UserID int64 } // ListAccessTokens returns a list of access tokens belongs to given user. func ListAccessTokens(opts ListAccessTokensOptions) ([]*AccessToken, error) { sess := db.GetEngine(db.DefaultContext).Where("uid=?", opts.UserID) if len(opts.Name) != 0 { sess = sess.Where("name=?", opts.Name) } sess = sess.Desc("created_unix") if opts.Page != 0 { sess = db.SetSessionPagination(sess, &opts) tokens := make([]*AccessToken, 0, opts.PageSize) return tokens, sess.Find(&tokens) } tokens := make([]*AccessToken, 0, 5) return tokens, sess.Find(&tokens) } // UpdateAccessToken updates information of access token. func UpdateAccessToken(t *AccessToken) error { _, err := db.GetEngine(db.DefaultContext).ID(t.ID).AllCols().Update(t) return err } // CountAccessTokens count access tokens belongs to given user by options func CountAccessTokens(opts ListAccessTokensOptions) (int64, error) { sess := db.GetEngine(db.DefaultContext).Where("uid=?", opts.UserID) if len(opts.Name) != 0 { sess = sess.Where("name=?", opts.Name) } return sess.Count(&AccessToken{}) } // DeleteAccessTokenByID deletes access token by given ID. func DeleteAccessTokenByID(id, userID int64) error { cnt, err := db.GetEngine(db.DefaultContext).ID(id).Delete(&AccessToken{ UID: userID, }) if err != nil { return err } else if cnt != 1 { return ErrAccessTokenNotExist{} } return nil }