SQL Related dbs CRUD implementation for SMS
This commit is contained in:
parent
9028682e93
commit
c525ad92f2
51
server/db/providers/sql/sms_verification_requests.go
Normal file
51
server/db/providers/sql/sms_verification_requests.go
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
package sql
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/authorizerdev/authorizer/server/db/models"
|
||||||
|
"github.com/google/uuid"
|
||||||
|
"gorm.io/gorm/clause"
|
||||||
|
)
|
||||||
|
|
||||||
|
// SMS verification Request
|
||||||
|
func (p *provider) UpsertSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error) {
|
||||||
|
if smsRequest.ID == "" {
|
||||||
|
smsRequest.ID = uuid.New().String()
|
||||||
|
}
|
||||||
|
|
||||||
|
smsRequest.CreatedAt = time.Now().Unix()
|
||||||
|
smsRequest.UpdatedAt = time.Now().Unix()
|
||||||
|
|
||||||
|
res := p.db.Clauses(clause.OnConflict{
|
||||||
|
Columns: []clause.Column{{Name: "phone_number"}},
|
||||||
|
DoUpdates: clause.AssignmentColumns([]string{"code", "code_expires_at"}),
|
||||||
|
}).Create(smsRequest)
|
||||||
|
if res.Error != nil {
|
||||||
|
return nil, res.Error
|
||||||
|
}
|
||||||
|
|
||||||
|
return smsRequest, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetOTPByEmail to get otp for a given email address
|
||||||
|
func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error) {
|
||||||
|
var sms_verification_request models.SMSVerificationRequest
|
||||||
|
|
||||||
|
result := p.db.Where("phone_number = ?", phoneNumber).First(&sms_verification_request)
|
||||||
|
if result.Error != nil {
|
||||||
|
return nil, result.Error
|
||||||
|
}
|
||||||
|
return &sms_verification_request, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func(p *provider) DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error {
|
||||||
|
result := p.db.Delete(&models.SMSVerificationRequest{
|
||||||
|
ID: smsRequest.ID,
|
||||||
|
})
|
||||||
|
if result.Error != nil {
|
||||||
|
return result.Error
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user