package couchbase import ( "context" "fmt" "log" "time" "github.com/authorizerdev/authorizer/server/db/models" "github.com/authorizerdev/authorizer/server/graph/model" "github.com/couchbase/gocb/v2" "github.com/google/uuid" ) // AddWebhookLog to add webhook log func (p *provider) AddWebhookLog(ctx context.Context, webhookLog models.WebhookLog) (*model.WebhookLog, error) { if webhookLog.ID == "" { webhookLog.ID = uuid.New().String() } webhookLog.Key = webhookLog.ID webhookLog.CreatedAt = time.Now().Unix() webhookLog.UpdatedAt = time.Now().Unix() insertOpt := gocb.InsertOptions{ Context: ctx, } _, err := p.db.Collection(models.Collections.WebhookLog).Insert(webhookLog.ID, webhookLog, &insertOpt) if err != nil { return webhookLog.AsAPIWebhookLog(), err } return webhookLog.AsAPIWebhookLog(), nil } // ListWebhookLogs to list webhook logs func (p *provider) ListWebhookLogs(ctx context.Context, pagination model.Pagination, webhookID string) (*model.WebhookLogs, error) { webhookLogs := []*model.WebhookLog{} scope := p.db.Scope("_default") paginationClone := pagination query := fmt.Sprintf("SELECT _id, env, created_at, updated_at FROM auth._default.%s OFFSET %d LIMIT %d", models.Collections.Env, paginationClone.Offset, paginationClone.Limit) queryResult, err := scope.Query(query, &gocb.QueryOptions{}) if err != nil { return nil, err } for queryResult.Next() { var webhookLog models.WebhookLog err := queryResult.Row(&webhookLog) if err != nil { log.Fatal(err) } webhookLogs = append(webhookLogs, webhookLog.AsAPIWebhookLog()) } if err := queryResult.Err(); err != nil { return nil, err } return &model.WebhookLogs{ Pagination: &paginationClone, WebhookLogs: webhookLogs, }, nil }