2022-04-21 07:06:22 +00:00
|
|
|
package cassandradb
|
2022-03-19 12:11:27 +00:00
|
|
|
|
|
|
|
import (
|
2022-07-10 16:19:33 +00:00
|
|
|
"context"
|
2022-04-22 06:22:15 +00:00
|
|
|
"fmt"
|
2022-03-19 12:11:27 +00:00
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/authorizerdev/authorizer/server/db/models"
|
|
|
|
"github.com/authorizerdev/authorizer/server/graph/model"
|
2022-04-22 06:22:15 +00:00
|
|
|
"github.com/gocql/gocql"
|
2022-03-19 12:11:27 +00:00
|
|
|
"github.com/google/uuid"
|
|
|
|
)
|
|
|
|
|
|
|
|
// AddVerification to save verification request in database
|
2023-07-31 11:12:11 +00:00
|
|
|
func (p *provider) AddVerificationRequest(ctx context.Context, verificationRequest *models.VerificationRequest) (*models.VerificationRequest, error) {
|
2022-03-19 12:11:27 +00:00
|
|
|
if verificationRequest.ID == "" {
|
|
|
|
verificationRequest.ID = uuid.New().String()
|
|
|
|
}
|
|
|
|
|
|
|
|
verificationRequest.CreatedAt = time.Now().Unix()
|
|
|
|
verificationRequest.UpdatedAt = time.Now().Unix()
|
|
|
|
|
2022-04-22 06:22:15 +00:00
|
|
|
query := fmt.Sprintf("INSERT INTO %s (id, jwt_token, identifier, expires_at, email, nonce, redirect_uri, created_at, updated_at) VALUES ('%s', '%s', '%s', %d, '%s', '%s', '%s', %d, %d)", KeySpace+"."+models.Collections.VerificationRequest, verificationRequest.ID, verificationRequest.Token, verificationRequest.Identifier, verificationRequest.ExpiresAt, verificationRequest.Email, verificationRequest.Nonce, verificationRequest.RedirectURI, verificationRequest.CreatedAt, verificationRequest.UpdatedAt)
|
|
|
|
err := p.db.Query(query).Exec()
|
|
|
|
if err != nil {
|
|
|
|
return verificationRequest, err
|
|
|
|
}
|
2022-03-19 12:11:27 +00:00
|
|
|
return verificationRequest, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetVerificationRequestByToken to get verification request from database using token
|
2023-07-31 11:12:11 +00:00
|
|
|
func (p *provider) GetVerificationRequestByToken(ctx context.Context, token string) (*models.VerificationRequest, error) {
|
2023-08-01 10:39:17 +00:00
|
|
|
var verificationRequest models.VerificationRequest
|
2022-04-22 06:22:15 +00:00
|
|
|
query := fmt.Sprintf(`SELECT id, jwt_token, identifier, expires_at, email, nonce, redirect_uri, created_at, updated_at FROM %s WHERE jwt_token = '%s' LIMIT 1`, KeySpace+"."+models.Collections.VerificationRequest, token)
|
2022-04-22 14:26:55 +00:00
|
|
|
|
2022-04-22 06:22:15 +00:00
|
|
|
err := p.db.Query(query).Consistency(gocql.One).Scan(&verificationRequest.ID, &verificationRequest.Token, &verificationRequest.Identifier, &verificationRequest.ExpiresAt, &verificationRequest.Email, &verificationRequest.Nonce, &verificationRequest.RedirectURI, &verificationRequest.CreatedAt, &verificationRequest.UpdatedAt)
|
|
|
|
if err != nil {
|
2023-08-01 10:39:17 +00:00
|
|
|
return nil, err
|
2022-04-22 06:22:15 +00:00
|
|
|
}
|
2023-08-01 10:39:17 +00:00
|
|
|
return &verificationRequest, nil
|
2022-03-19 12:11:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetVerificationRequestByEmail to get verification request by email from database
|
2023-07-31 11:12:11 +00:00
|
|
|
func (p *provider) GetVerificationRequestByEmail(ctx context.Context, email string, identifier string) (*models.VerificationRequest, error) {
|
2023-08-01 10:39:17 +00:00
|
|
|
var verificationRequest models.VerificationRequest
|
2022-04-22 14:26:55 +00:00
|
|
|
query := fmt.Sprintf(`SELECT id, jwt_token, identifier, expires_at, email, nonce, redirect_uri, created_at, updated_at FROM %s WHERE email = '%s' AND identifier = '%s' LIMIT 1 ALLOW FILTERING`, KeySpace+"."+models.Collections.VerificationRequest, email, identifier)
|
|
|
|
|
2022-04-22 06:22:15 +00:00
|
|
|
err := p.db.Query(query).Consistency(gocql.One).Scan(&verificationRequest.ID, &verificationRequest.Token, &verificationRequest.Identifier, &verificationRequest.ExpiresAt, &verificationRequest.Email, &verificationRequest.Nonce, &verificationRequest.RedirectURI, &verificationRequest.CreatedAt, &verificationRequest.UpdatedAt)
|
|
|
|
if err != nil {
|
2023-08-01 10:39:17 +00:00
|
|
|
return nil, err
|
2022-04-22 06:22:15 +00:00
|
|
|
}
|
2022-03-19 12:11:27 +00:00
|
|
|
|
2023-08-01 10:39:17 +00:00
|
|
|
return &verificationRequest, nil
|
2022-03-19 12:11:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// ListVerificationRequests to get list of verification requests from database
|
2023-07-31 11:12:11 +00:00
|
|
|
func (p *provider) ListVerificationRequests(ctx context.Context, pagination *model.Pagination) (*model.VerificationRequests, error) {
|
2022-04-22 06:22:15 +00:00
|
|
|
var verificationRequests []*model.VerificationRequest
|
|
|
|
paginationClone := pagination
|
|
|
|
totalCountQuery := fmt.Sprintf(`SELECT COUNT(*) FROM %s`, KeySpace+"."+models.Collections.VerificationRequest)
|
2023-08-01 10:39:17 +00:00
|
|
|
err := p.db.Query(totalCountQuery).Consistency(gocql.One).Scan(&paginationClone.Total)
|
2022-04-22 06:22:15 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
// there is no offset in cassandra
|
|
|
|
// so we fetch till limit + offset
|
|
|
|
// and return the results from offset to limit
|
2022-04-22 14:26:55 +00:00
|
|
|
query := fmt.Sprintf(`SELECT id, jwt_token, identifier, expires_at, email, nonce, redirect_uri, created_at, updated_at FROM %s LIMIT %d`, KeySpace+"."+models.Collections.VerificationRequest, pagination.Limit+pagination.Offset)
|
|
|
|
|
2022-04-22 06:22:15 +00:00
|
|
|
scanner := p.db.Query(query).Iter().Scanner()
|
|
|
|
counter := int64(0)
|
|
|
|
for scanner.Next() {
|
|
|
|
if counter >= pagination.Offset {
|
2023-08-01 10:39:17 +00:00
|
|
|
var verificationRequest models.VerificationRequest
|
2022-04-22 06:22:15 +00:00
|
|
|
err := scanner.Scan(&verificationRequest.ID, &verificationRequest.Token, &verificationRequest.Identifier, &verificationRequest.ExpiresAt, &verificationRequest.Email, &verificationRequest.Nonce, &verificationRequest.RedirectURI, &verificationRequest.CreatedAt, &verificationRequest.UpdatedAt)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
verificationRequests = append(verificationRequests, verificationRequest.AsAPIVerificationRequest())
|
|
|
|
}
|
|
|
|
counter++
|
|
|
|
}
|
|
|
|
|
|
|
|
return &model.VerificationRequests{
|
|
|
|
VerificationRequests: verificationRequests,
|
2023-07-31 11:12:11 +00:00
|
|
|
Pagination: paginationClone,
|
2022-04-22 06:22:15 +00:00
|
|
|
}, nil
|
2022-03-19 12:11:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// DeleteVerificationRequest to delete verification request from database
|
2023-07-31 11:12:11 +00:00
|
|
|
func (p *provider) DeleteVerificationRequest(ctx context.Context, verificationRequest *models.VerificationRequest) error {
|
2022-04-22 06:22:15 +00:00
|
|
|
query := fmt.Sprintf("DELETE FROM %s WHERE id = '%s'", KeySpace+"."+models.Collections.VerificationRequest, verificationRequest.ID)
|
|
|
|
err := p.db.Query(query).Exec()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2022-03-19 12:11:27 +00:00
|
|
|
return nil
|
|
|
|
}
|