mirror of
https://github.com/usememos/memos.git
synced 2025-01-17 10:03:16 +08:00
b44f2b5ffb
* chore: migrate to api v1 package * chore: update
130 lines
2.7 KiB
Go
130 lines
2.7 KiB
Go
package store
|
|
|
|
import (
|
|
"context"
|
|
"database/sql"
|
|
|
|
"github.com/usememos/memos/api"
|
|
)
|
|
|
|
type ActivityMessage struct {
|
|
ID int
|
|
|
|
// Standard fields
|
|
CreatorID int
|
|
CreatedTs int64
|
|
|
|
// Domain specific fields
|
|
Type string
|
|
Level string
|
|
Payload string
|
|
}
|
|
|
|
// CreateActivityV1 creates an instance of Activity.
|
|
func (s *Store) CreateActivityV1(ctx context.Context, create *ActivityMessage) (*ActivityMessage, error) {
|
|
tx, err := s.db.BeginTx(ctx, nil)
|
|
if err != nil {
|
|
return nil, FormatError(err)
|
|
}
|
|
defer tx.Rollback()
|
|
|
|
query := `
|
|
INSERT INTO activity (
|
|
creator_id,
|
|
type,
|
|
level,
|
|
payload
|
|
)
|
|
VALUES (?, ?, ?, ?)
|
|
RETURNING id, created_ts
|
|
`
|
|
if err := tx.QueryRowContext(ctx, query, create.CreatorID, create.Type, create.Level, create.Payload).Scan(
|
|
&create.ID,
|
|
&create.CreatedTs,
|
|
); err != nil {
|
|
return nil, FormatError(err)
|
|
}
|
|
|
|
if err := tx.Commit(); err != nil {
|
|
return nil, FormatError(err)
|
|
}
|
|
activityMessage := create
|
|
return activityMessage, nil
|
|
}
|
|
|
|
// activityRaw is the store model for an Activity.
|
|
// Fields have exactly the same meanings as Activity.
|
|
type activityRaw struct {
|
|
ID int
|
|
|
|
// Standard fields
|
|
CreatorID int
|
|
CreatedTs int64
|
|
|
|
// Domain specific fields
|
|
Type api.ActivityType
|
|
Level api.ActivityLevel
|
|
Payload string
|
|
}
|
|
|
|
// toActivity creates an instance of Activity based on the ActivityRaw.
|
|
func (raw *activityRaw) toActivity() *api.Activity {
|
|
return &api.Activity{
|
|
ID: raw.ID,
|
|
|
|
CreatorID: raw.CreatorID,
|
|
CreatedTs: raw.CreatedTs,
|
|
|
|
Type: raw.Type,
|
|
Level: raw.Level,
|
|
Payload: raw.Payload,
|
|
}
|
|
}
|
|
|
|
// CreateActivity creates an instance of Activity.
|
|
func (s *Store) CreateActivity(ctx context.Context, create *api.ActivityCreate) (*api.Activity, error) {
|
|
tx, err := s.db.BeginTx(ctx, nil)
|
|
if err != nil {
|
|
return nil, FormatError(err)
|
|
}
|
|
defer tx.Rollback()
|
|
|
|
activityRaw, err := createActivity(ctx, tx, create)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if err := tx.Commit(); err != nil {
|
|
return nil, FormatError(err)
|
|
}
|
|
|
|
activity := activityRaw.toActivity()
|
|
return activity, nil
|
|
}
|
|
|
|
// createActivity creates a new activity.
|
|
func createActivity(ctx context.Context, tx *sql.Tx, create *api.ActivityCreate) (*activityRaw, error) {
|
|
query := `
|
|
INSERT INTO activity (
|
|
creator_id,
|
|
type,
|
|
level,
|
|
payload
|
|
)
|
|
VALUES (?, ?, ?, ?)
|
|
RETURNING id, type, level, payload, creator_id, created_ts
|
|
`
|
|
var activityRaw activityRaw
|
|
if err := tx.QueryRowContext(ctx, query, create.CreatorID, create.Type, create.Level, create.Payload).Scan(
|
|
&activityRaw.ID,
|
|
&activityRaw.Type,
|
|
&activityRaw.Level,
|
|
&activityRaw.Payload,
|
|
&activityRaw.CreatorID,
|
|
&activityRaw.CreatedTs,
|
|
); err != nil {
|
|
return nil, FormatError(err)
|
|
}
|
|
|
|
return &activityRaw, nil
|
|
}
|