Initial commit: Open sourcing all of the Maple Open Technologies code.
This commit is contained in:
commit
755d54a99d
2010 changed files with 448675 additions and 0 deletions
|
|
@ -0,0 +1,88 @@
|
|||
// monorepo/cloud/maplefile-backend/internal/maplefile/repo/storageusageevent/create.go
|
||||
package storageusageevent
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
"time"
|
||||
|
||||
"github.com/gocql/gocql"
|
||||
"go.uber.org/zap"
|
||||
|
||||
"codeberg.org/mapleopentech/monorepo/cloud/maplefile-backend/internal/domain/storageusageevent"
|
||||
)
|
||||
|
||||
func (impl *storageUsageEventRepositoryImpl) Create(ctx context.Context, event *storageusageevent.StorageUsageEvent) error {
|
||||
if event == nil {
|
||||
return fmt.Errorf("storage usage event cannot be nil")
|
||||
}
|
||||
|
||||
// Ensure event day is truncated to date only
|
||||
event.EventDay = event.EventDay.Truncate(24 * time.Hour)
|
||||
|
||||
// Set event time if not provided
|
||||
if event.EventTime.IsZero() {
|
||||
event.EventTime = time.Now()
|
||||
}
|
||||
|
||||
query := `INSERT INTO maplefile.storage_usage_events_by_user_id_and_event_day_with_asc_event_time
|
||||
(user_id, event_day, event_time, file_size, operation)
|
||||
VALUES (?, ?, ?, ?, ?)`
|
||||
|
||||
err := impl.Session.Query(query,
|
||||
event.UserID,
|
||||
event.EventDay,
|
||||
event.EventTime,
|
||||
event.FileSize,
|
||||
event.Operation).WithContext(ctx).Exec()
|
||||
|
||||
if err != nil {
|
||||
impl.Logger.Error("failed to create storage usage event",
|
||||
zap.String("user_id", event.UserID.String()),
|
||||
zap.String("operation", event.Operation),
|
||||
zap.Int64("file_size", event.FileSize),
|
||||
zap.Error(err))
|
||||
return fmt.Errorf("failed to create storage usage event: %w", err)
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (impl *storageUsageEventRepositoryImpl) CreateMany(ctx context.Context, events []*storageusageevent.StorageUsageEvent) error {
|
||||
if len(events) == 0 {
|
||||
return nil
|
||||
}
|
||||
|
||||
batch := impl.Session.NewBatch(gocql.LoggedBatch).WithContext(ctx)
|
||||
|
||||
for _, event := range events {
|
||||
if event == nil {
|
||||
continue
|
||||
}
|
||||
|
||||
// Ensure event day is truncated to date only
|
||||
event.EventDay = event.EventDay.Truncate(24 * time.Hour)
|
||||
|
||||
// Set event time if not provided
|
||||
if event.EventTime.IsZero() {
|
||||
event.EventTime = time.Now()
|
||||
}
|
||||
|
||||
batch.Query(`INSERT INTO maplefile.storage_usage_events_by_user_id_and_event_day_with_asc_event_time
|
||||
(user_id, event_day, event_time, file_size, operation)
|
||||
VALUES (?, ?, ?, ?, ?)`,
|
||||
event.UserID,
|
||||
event.EventDay,
|
||||
event.EventTime,
|
||||
event.FileSize,
|
||||
event.Operation)
|
||||
}
|
||||
|
||||
err := impl.Session.ExecuteBatch(batch)
|
||||
if err != nil {
|
||||
impl.Logger.Error("failed to create multiple storage usage events", zap.Error(err))
|
||||
return fmt.Errorf("failed to create multiple storage usage events: %w", err)
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue