feat: implement change password service method with validation; fix: correct ErrorIsOneOf function logic to return true on match; refactor: rename 'log_out_accounts' to 'log_out_sessions' for clarity; refactor: update session termination to return GUIDs and cache in Redis; fix: ensure RollbackOnError only rolls back uncommitted transactions; fix: handle transaction commit errors properly in dbHelper; refactor: add helper methods for session termination and registration; refactor: pass client info to login and registration complete methods; fix: improve token validation error handling in refresh endpoint; refactor: update auth middleware to set session info correctly; chore: remove unused ClientInfo DTO; fix: correct password reset complete to use session termination helper; refactor: adjust database queries for session management; chore: update SQL schema and queries for sessions; docs: update swagger docs with new endpoint and model changes
39 lines
1.4 KiB
Go
39 lines
1.4 KiB
Go
// Copyright (c) 2025 Nikolai Papin
|
|
//
|
|
// This file is part of Easywish
|
|
//
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See
|
|
// the GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
package errors
|
|
|
|
import (
|
|
"errors"
|
|
)
|
|
|
|
var (
|
|
ErrUnauthorized = errors.New("User is not authorized")
|
|
ErrUsernameTaken = errors.New("Provided username is already in use")
|
|
ErrEmailTaken = errors.New("Provided email is already in use")
|
|
ErrUserNotFound = errors.New("User was not found")
|
|
ErrInvalidCredentials = errors.New("Invalid username, password or TOTP code")
|
|
ErrInvalidToken = errors.New("Token is invalid or expired")
|
|
ErrServerError = errors.New("Internal server error")
|
|
|
|
ErrTokenExpired = errors.New("Token is expired")
|
|
ErrTokenInvalid = ErrInvalidToken
|
|
ErrWrongTokenType = errors.New("Invalid token type")
|
|
ErrSessionNotFound = errors.New("Could not find session in database")
|
|
ErrSessionTerminated = errors.New("Session is terminated")
|
|
)
|