78 lines
2.3 KiB
Go
78 lines
2.3 KiB
Go
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) {
|
|
var query string
|
|
var err error
|
|
webhookLogs := []*model.WebhookLog{}
|
|
params := make(map[string]interface{}, 1)
|
|
paginationClone := pagination
|
|
params["webhookID"] = webhookID
|
|
params["offset"] = paginationClone.Offset
|
|
params["limit"] = paginationClone.Limit
|
|
total, err := p.GetTotalDocs(ctx, models.Collections.WebhookLog)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
paginationClone.Total = total
|
|
if webhookID != "" {
|
|
query = fmt.Sprintf(`SELECT _id, http_status, response, request, webhook_id, created_at, updated_at FROM %s.%s WHERE webhook_id=$webhookID`, p.scopeName, models.Collections.WebhookLog)
|
|
} else {
|
|
query = fmt.Sprintf("SELECT _id, http_status, response, request, webhook_id, created_at, updated_at FROM %s.%s OFFSET $offset LIMIT $limit", p.scopeName, models.Collections.WebhookLog)
|
|
}
|
|
queryResult, err := p.db.Query(query, &gocb.QueryOptions{
|
|
Context: ctx,
|
|
ScanConsistency: gocb.QueryScanConsistencyRequestPlus,
|
|
NamedParameters: params,
|
|
})
|
|
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
|
|
}
|