
* fix: * removed hasReversedValue in playground * feat: * added totp methods in db's providers * adding totp in login method * feat: * added toggle in dashboard * fixing issue with env set * feat: * integrated totp * feat: * encrypted userid * added totp_verified column in user table * started test for totp * feat: * test cases totp * test-cases: * completed test cases * tested for all dbs * fixes: * return variable to snake case * import refactoring * feat: * created seperate folder for authenticator with totp subfolder * refactored code * created new table for authenticators * added recovery code for totp * feat: * adding functions to different db providers * feat: * added authenticators method for all db * feat: * added logic for updating mfa in user_profile update * fix: * merge conflict * fix: * resolved mongodb, dynamodb and arangodb test case bug * added new condition for checking first time totp user or not * feat: * changes in all respective db with authenticator * fix: * PR suggested changes * fix(cassandra): list users * Update verify otp * fix totp login api --------- Co-authored-by: lemonScaletech <anand.panigrahi@scaletech.xyz>
138 lines
4.8 KiB
Go
138 lines
4.8 KiB
Go
package mongodb
|
|
|
|
import (
|
|
"context"
|
|
"time"
|
|
|
|
"github.com/authorizerdev/authorizer/server/db/models"
|
|
"github.com/authorizerdev/authorizer/server/memorystore"
|
|
"go.mongodb.org/mongo-driver/bson"
|
|
"go.mongodb.org/mongo-driver/mongo"
|
|
"go.mongodb.org/mongo-driver/mongo/options"
|
|
"go.mongodb.org/mongo-driver/mongo/readpref"
|
|
)
|
|
|
|
type provider struct {
|
|
db *mongo.Database
|
|
}
|
|
|
|
// NewProvider to initialize mongodb connection
|
|
func NewProvider() (*provider, error) {
|
|
dbURL := memorystore.RequiredEnvStoreObj.GetRequiredEnv().DatabaseURL
|
|
mongodbOptions := options.Client().ApplyURI(dbURL)
|
|
maxWait := time.Duration(5 * time.Second)
|
|
mongodbOptions.ConnectTimeout = &maxWait
|
|
mongoClient, err := mongo.NewClient(mongodbOptions)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
ctx, _ := context.WithTimeout(context.Background(), 30*time.Second)
|
|
err = mongoClient.Connect(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
err = mongoClient.Ping(ctx, readpref.Primary())
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
dbName := memorystore.RequiredEnvStoreObj.GetRequiredEnv().DatabaseName
|
|
mongodb := mongoClient.Database(dbName, options.Database())
|
|
|
|
mongodb.CreateCollection(ctx, models.Collections.User, options.CreateCollection())
|
|
userCollection := mongodb.Collection(models.Collections.User, options.Collection())
|
|
userCollection.Indexes().CreateMany(ctx, []mongo.IndexModel{
|
|
{
|
|
Keys: bson.M{"email": 1},
|
|
Options: options.Index().SetUnique(true).SetSparse(true),
|
|
},
|
|
{
|
|
Keys: bson.M{"phone_number": 1},
|
|
Options: options.Index().SetUnique(true).SetSparse(true).SetPartialFilterExpression(map[string]interface{}{
|
|
"phone_number": map[string]string{"$type": "string"},
|
|
}),
|
|
},
|
|
}, options.CreateIndexes())
|
|
mongodb.CreateCollection(ctx, models.Collections.VerificationRequest, options.CreateCollection())
|
|
verificationRequestCollection := mongodb.Collection(models.Collections.VerificationRequest, options.Collection())
|
|
verificationRequestCollection.Indexes().CreateMany(ctx, []mongo.IndexModel{
|
|
{
|
|
Keys: bson.M{"email": 1, "identifier": 1},
|
|
Options: options.Index().SetUnique(true).SetSparse(true),
|
|
},
|
|
}, options.CreateIndexes())
|
|
verificationRequestCollection.Indexes().CreateMany(ctx, []mongo.IndexModel{
|
|
{
|
|
Keys: bson.M{"token": 1},
|
|
Options: options.Index().SetSparse(true),
|
|
},
|
|
}, options.CreateIndexes())
|
|
|
|
mongodb.CreateCollection(ctx, models.Collections.Session, options.CreateCollection())
|
|
sessionCollection := mongodb.Collection(models.Collections.Session, options.Collection())
|
|
sessionCollection.Indexes().CreateMany(ctx, []mongo.IndexModel{
|
|
{
|
|
Keys: bson.M{"user_id": 1},
|
|
Options: options.Index().SetSparse(true),
|
|
},
|
|
}, options.CreateIndexes())
|
|
|
|
mongodb.CreateCollection(ctx, models.Collections.Env, options.CreateCollection())
|
|
|
|
mongodb.CreateCollection(ctx, models.Collections.Webhook, options.CreateCollection())
|
|
webhookCollection := mongodb.Collection(models.Collections.Webhook, options.Collection())
|
|
webhookCollection.Indexes().CreateMany(ctx, []mongo.IndexModel{
|
|
{
|
|
Keys: bson.M{"event_name": 1},
|
|
Options: options.Index().SetUnique(true).SetSparse(true),
|
|
},
|
|
}, options.CreateIndexes())
|
|
|
|
mongodb.CreateCollection(ctx, models.Collections.WebhookLog, options.CreateCollection())
|
|
webhookLogCollection := mongodb.Collection(models.Collections.WebhookLog, options.Collection())
|
|
webhookLogCollection.Indexes().CreateMany(ctx, []mongo.IndexModel{
|
|
{
|
|
Keys: bson.M{"webhook_id": 1},
|
|
Options: options.Index().SetSparse(true),
|
|
},
|
|
}, options.CreateIndexes())
|
|
|
|
mongodb.CreateCollection(ctx, models.Collections.EmailTemplate, options.CreateCollection())
|
|
emailTemplateCollection := mongodb.Collection(models.Collections.EmailTemplate, options.Collection())
|
|
emailTemplateCollection.Indexes().CreateMany(ctx, []mongo.IndexModel{
|
|
{
|
|
Keys: bson.M{"event_name": 1},
|
|
Options: options.Index().SetUnique(true).SetSparse(true),
|
|
},
|
|
}, options.CreateIndexes())
|
|
|
|
mongodb.CreateCollection(ctx, models.Collections.OTP, options.CreateCollection())
|
|
otpCollection := mongodb.Collection(models.Collections.OTP, options.Collection())
|
|
otpCollection.Indexes().CreateMany(ctx, []mongo.IndexModel{
|
|
{
|
|
Keys: bson.M{"email": 1},
|
|
Options: options.Index().SetUnique(true).SetSparse(true),
|
|
},
|
|
}, options.CreateIndexes())
|
|
otpCollection.Indexes().CreateMany(ctx, []mongo.IndexModel{
|
|
{
|
|
Keys: bson.M{"phone_number": 1},
|
|
Options: options.Index().SetUnique(true).SetSparse(true),
|
|
},
|
|
}, options.CreateIndexes())
|
|
|
|
mongodb.CreateCollection(ctx, models.Collections.Authenticators, options.CreateCollection())
|
|
authenticatorsCollection := mongodb.Collection(models.Collections.Authenticators, options.Collection())
|
|
authenticatorsCollection.Indexes().CreateMany(ctx, []mongo.IndexModel{
|
|
{
|
|
Keys: bson.M{"user_id": 1},
|
|
Options: options.Index().SetSparse(true),
|
|
},
|
|
}, options.CreateIndexes())
|
|
|
|
return &provider{
|
|
db: mongodb,
|
|
}, nil
|
|
}
|