Skip to main content
Glama

Storyden

by Southclaws
Mozilla Public License 2.0
227
like_writer.go1.14 kB
package like_writer import ( "context" "entgo.io/ent/dialect/sql" "github.com/Southclaws/fault" "github.com/Southclaws/fault/fctx" "github.com/rs/xid" "github.com/Southclaws/storyden/app/resources/account" "github.com/Southclaws/storyden/app/resources/post" "github.com/Southclaws/storyden/internal/ent" "github.com/Southclaws/storyden/internal/ent/likepost" ) type LikeWriter struct { db *ent.Client } func New(db *ent.Client) *LikeWriter { return &LikeWriter{db: db} } func (l *LikeWriter) AddPostLike(ctx context.Context, accountID account.AccountID, postID post.ID) error { err := l.db.LikePost.Create(). SetPostID(xid.ID(postID)). SetAccountID(xid.ID(accountID)). OnConflict(sql.DoNothing()). Exec(ctx) if err != nil { return fault.Wrap(err, fctx.With(ctx)) } return nil } func (l *LikeWriter) RemovePostLike(ctx context.Context, accountID account.AccountID, postID post.ID) error { _, err := l.db.LikePost. Delete(). Where( likepost.AccountIDEQ(xid.ID(accountID)), likepost.PostIDEQ(xid.ID(postID)), ). Exec(ctx) if err != nil { return fault.Wrap(err, fctx.With(ctx)) } return nil }

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/Southclaws/storyden'

If you have feedback or need assistance with the MCP directory API, please join our Discord server