Update provider template for sms verification
This commit is contained in:
parent
9ae616b6b5
commit
6cef9064c3
|
@ -4,20 +4,19 @@ import (
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
"github.com/authorizerdev/authorizer/server/db/models"
|
"github.com/authorizerdev/authorizer/server/db/models"
|
||||||
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// SMS verification Request
|
// UpsertSMSRequest adds/updates SMS verification request
|
||||||
func (p *provider) UpsertSMSRequest(ctx context.Context, sms_code *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error) {
|
func (p *provider) UpsertSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error) {
|
||||||
return sms_code, nil
|
return nil, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetCodeByPhone to get code for a given phone number
|
||||||
func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error) {
|
func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error) {
|
||||||
var sms_verification_request models.SMSVerificationRequest
|
return nil, nil
|
||||||
|
|
||||||
return &sms_verification_request, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func(p *provider) DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error {
|
// DeleteSMSRequest to delete SMS verification request
|
||||||
|
func (p *provider) DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,20 +4,19 @@ import (
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
"github.com/authorizerdev/authorizer/server/db/models"
|
"github.com/authorizerdev/authorizer/server/db/models"
|
||||||
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// SMS verification Request
|
// UpsertSMSRequest adds/updates SMS verification request
|
||||||
func (p *provider) UpsertSMSRequest(ctx context.Context, sms_code *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error) {
|
func (p *provider) UpsertSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error) {
|
||||||
return sms_code, nil
|
return nil, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetCodeByPhone to get code for a given phone number
|
||||||
func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error) {
|
func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error) {
|
||||||
var sms_verification_request models.SMSVerificationRequest
|
return nil, nil
|
||||||
|
|
||||||
return &sms_verification_request, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func(p *provider) DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error {
|
// DeleteSMSRequest to delete SMS verification request
|
||||||
|
func (p *provider) DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,20 +4,19 @@ import (
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
"github.com/authorizerdev/authorizer/server/db/models"
|
"github.com/authorizerdev/authorizer/server/db/models"
|
||||||
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// SMS verification Request
|
// UpsertSMSRequest adds/updates SMS verification request
|
||||||
func (p *provider) UpsertSMSRequest(ctx context.Context, sms_code *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error) {
|
func (p *provider) UpsertSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error) {
|
||||||
return sms_code, nil
|
return nil, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetCodeByPhone to get code for a given phone number
|
||||||
func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error) {
|
func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error) {
|
||||||
var sms_verification_request models.SMSVerificationRequest
|
return nil, nil
|
||||||
|
|
||||||
return &sms_verification_request, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func(p *provider) DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error {
|
// DeleteSMSRequest to delete SMS verification request
|
||||||
|
func (p *provider) DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,20 +4,19 @@ import (
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
"github.com/authorizerdev/authorizer/server/db/models"
|
"github.com/authorizerdev/authorizer/server/db/models"
|
||||||
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// SMS verification Request
|
// UpsertSMSRequest adds/updates SMS verification request
|
||||||
func (p *provider) UpsertSMSRequest(ctx context.Context, sms_code *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error) {
|
func (p *provider) UpsertSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error) {
|
||||||
return sms_code, nil
|
return nil, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetCodeByPhone to get code for a given phone number
|
||||||
func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error) {
|
func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error) {
|
||||||
var sms_verification_request models.SMSVerificationRequest
|
return nil, nil
|
||||||
|
|
||||||
return &sms_verification_request, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func(p *provider) DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error {
|
// DeleteSMSRequest to delete SMS verification request
|
||||||
|
func (p *provider) DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,14 +10,16 @@ import (
|
||||||
"go.mongodb.org/mongo-driver/mongo/options"
|
"go.mongodb.org/mongo-driver/mongo/options"
|
||||||
)
|
)
|
||||||
|
|
||||||
// SMS verification Request
|
// UpsertSMSRequest adds/updates SMS verification request
|
||||||
func (p *provider) UpsertSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error) {
|
func (p *provider) UpsertSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error) {
|
||||||
smsVerificationRequest, _ := p.GetCodeByPhone(ctx, smsRequest.PhoneNumber)
|
smsVerificationRequest, err := p.GetCodeByPhone(ctx, smsRequest.PhoneNumber)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
// Boolean to check if we should create a new record or update the existing one
|
||||||
shouldCreate := false
|
shouldCreate := false
|
||||||
|
|
||||||
if smsVerificationRequest == nil {
|
if smsVerificationRequest == nil {
|
||||||
id := uuid.NewString()
|
id := uuid.NewString()
|
||||||
|
|
||||||
smsVerificationRequest = &models.SMSVerificationRequest{
|
smsVerificationRequest = &models.SMSVerificationRequest{
|
||||||
ID: id,
|
ID: id,
|
||||||
CreatedAt: time.Now().Unix(),
|
CreatedAt: time.Now().Unix(),
|
||||||
|
@ -30,21 +32,18 @@ func (p *provider) UpsertSMSRequest(ctx context.Context, smsRequest *models.SMSV
|
||||||
|
|
||||||
smsVerificationRequest.UpdatedAt = time.Now().Unix()
|
smsVerificationRequest.UpdatedAt = time.Now().Unix()
|
||||||
smsRequestCollection := p.db.Collection(models.Collections.SMSVerificationRequest, options.Collection())
|
smsRequestCollection := p.db.Collection(models.Collections.SMSVerificationRequest, options.Collection())
|
||||||
|
|
||||||
var err error
|
|
||||||
if shouldCreate {
|
if shouldCreate {
|
||||||
_, err = smsRequestCollection.InsertOne(ctx, smsVerificationRequest)
|
_, err = smsRequestCollection.InsertOne(ctx, smsVerificationRequest)
|
||||||
} else {
|
} else {
|
||||||
_, err = smsRequestCollection.UpdateOne(ctx, bson.M{"phone_number": bson.M{"$eq": smsRequest.PhoneNumber}}, bson.M{"$set": smsVerificationRequest}, options.MergeUpdateOptions())
|
_, err = smsRequestCollection.UpdateOne(ctx, bson.M{"phone_number": bson.M{"$eq": smsRequest.PhoneNumber}}, bson.M{"$set": smsVerificationRequest}, options.MergeUpdateOptions())
|
||||||
}
|
}
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
return smsVerificationRequest, nil
|
return smsVerificationRequest, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetCodeByPhone to get code for a given phone number
|
||||||
func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error) {
|
func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error) {
|
||||||
var smsVerificationRequest models.SMSVerificationRequest
|
var smsVerificationRequest models.SMSVerificationRequest
|
||||||
|
|
||||||
|
@ -58,6 +57,7 @@ func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*mod
|
||||||
return &smsVerificationRequest, nil
|
return &smsVerificationRequest, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// DeleteSMSRequest to delete SMS verification request
|
||||||
func (p *provider) DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error {
|
func (p *provider) DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error {
|
||||||
smsVerificationRequests := p.db.Collection(models.Collections.SMSVerificationRequest, options.Collection())
|
smsVerificationRequests := p.db.Collection(models.Collections.SMSVerificationRequest, options.Collection())
|
||||||
_, err := smsVerificationRequests.DeleteOne(nil, bson.M{"_id": smsRequest.ID}, options.Delete())
|
_, err := smsVerificationRequests.DeleteOne(nil, bson.M{"_id": smsRequest.ID}, options.Delete())
|
||||||
|
|
|
@ -0,0 +1,22 @@
|
||||||
|
package provider_template
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
|
||||||
|
"github.com/authorizerdev/authorizer/server/db/models"
|
||||||
|
)
|
||||||
|
|
||||||
|
// UpsertSMSRequest adds/updates SMS verification request
|
||||||
|
func (p *provider) UpsertSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error) {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetCodeByPhone to get code for a given phone number
|
||||||
|
func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error) {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// DeleteSMSRequest to delete SMS verification request
|
||||||
|
func (p *provider) DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error {
|
||||||
|
return nil
|
||||||
|
}
|
|
@ -85,10 +85,10 @@ type Provider interface {
|
||||||
// DeleteOTP to delete otp
|
// DeleteOTP to delete otp
|
||||||
DeleteOTP(ctx context.Context, otp *models.OTP) error
|
DeleteOTP(ctx context.Context, otp *models.OTP) error
|
||||||
|
|
||||||
// Upsert SMS code request
|
// UpsertSMSRequest adds/updates SMS verification request
|
||||||
UpsertSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error)
|
UpsertSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error)
|
||||||
// Get sms code by phone number
|
// GetCodeByPhone to get code for a given phone number
|
||||||
GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error)
|
GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error)
|
||||||
// Delete sms
|
// DeleteSMSRequest to delete SMS verification request
|
||||||
DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error
|
DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,27 +9,24 @@ import (
|
||||||
"gorm.io/gorm/clause"
|
"gorm.io/gorm/clause"
|
||||||
)
|
)
|
||||||
|
|
||||||
// SMS verification Request
|
// UpsertSMSRequest adds/updates SMS verification request
|
||||||
func (p *provider) UpsertSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error) {
|
func (p *provider) UpsertSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) (*models.SMSVerificationRequest, error) {
|
||||||
if smsRequest.ID == "" {
|
if smsRequest.ID == "" {
|
||||||
smsRequest.ID = uuid.New().String()
|
smsRequest.ID = uuid.New().String()
|
||||||
}
|
}
|
||||||
|
|
||||||
smsRequest.CreatedAt = time.Now().Unix()
|
smsRequest.CreatedAt = time.Now().Unix()
|
||||||
smsRequest.UpdatedAt = time.Now().Unix()
|
smsRequest.UpdatedAt = time.Now().Unix()
|
||||||
|
|
||||||
res := p.db.Clauses(clause.OnConflict{
|
res := p.db.Clauses(clause.OnConflict{
|
||||||
Columns: []clause.Column{{Name: "phone_number"}},
|
Columns: []clause.Column{{Name: "phone_number"}},
|
||||||
DoUpdates: clause.AssignmentColumns([]string{"code", "code_expires_at"}),
|
DoUpdates: clause.AssignmentColumns([]string{"code", "code_expires_at", "updated_at"}),
|
||||||
}).Create(smsRequest)
|
}).Create(smsRequest)
|
||||||
if res.Error != nil {
|
if res.Error != nil {
|
||||||
return nil, res.Error
|
return nil, res.Error
|
||||||
}
|
}
|
||||||
|
|
||||||
return smsRequest, nil
|
return smsRequest, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetOTPByEmail to get otp for a given email address
|
// GetCodeByPhone to get code for a given phone number
|
||||||
func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error) {
|
func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*models.SMSVerificationRequest, error) {
|
||||||
var sms_verification_request models.SMSVerificationRequest
|
var sms_verification_request models.SMSVerificationRequest
|
||||||
|
|
||||||
|
@ -40,7 +37,8 @@ func (p *provider) GetCodeByPhone(ctx context.Context, phoneNumber string) (*mod
|
||||||
return &sms_verification_request, nil
|
return &sms_verification_request, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func(p *provider) DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error {
|
// DeleteSMSRequest to delete SMS verification request
|
||||||
|
func (p *provider) DeleteSMSRequest(ctx context.Context, smsRequest *models.SMSVerificationRequest) error {
|
||||||
result := p.db.Delete(&models.SMSVerificationRequest{
|
result := p.db.Delete(&models.SMSVerificationRequest{
|
||||||
ID: smsRequest.ID,
|
ID: smsRequest.ID,
|
||||||
})
|
})
|
||||||
|
|
Loading…
Reference in New Issue
Block a user