package storage import ( "context" "git.sch9.ru/new_gate/models" "github.com/jmoiron/sqlx" ) type UserStorage struct { db *sqlx.DB } func NewUserStorage(db *sqlx.DB) *UserStorage { return &UserStorage{ db: db, } } func (storage *UserStorage) CreateUser(ctx context.Context, user *models.User) error { query := storage.db.Rebind("INSERT INTO users (user_id, role) VALUES (?, ?)") _, err := storage.db.ExecContext(ctx, query, user.UserId, user.Role) if err != nil { return err } return nil } func (storage *UserStorage) ReadUserById(ctx context.Context, userId int32) (*models.User, error) { query := storage.db.Rebind(` SELECT * FROM users WHERE user_id = ? LIMIT 1; `) var user models.User err := storage.db.GetContext(ctx, &user, query, userId) if err != nil { return nil, err } return &user, nil }