2021-10-18 08:31:17 +00:00
|
|
|
package joke
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2022-05-11 14:47:53 +00:00
|
|
|
"strconv"
|
2021-10-30 03:24:53 +00:00
|
|
|
"jokes-bapak2-api/core/schema"
|
2021-10-18 08:31:17 +00:00
|
|
|
|
|
|
|
"github.com/Masterminds/squirrel"
|
|
|
|
"github.com/allegro/bigcache/v3"
|
|
|
|
"github.com/jackc/pgx/v4/pgxpool"
|
|
|
|
"github.com/pquerna/ffjson/ffjson"
|
|
|
|
)
|
|
|
|
|
|
|
|
// SetAllJSONJoke fetches jokes data from GetAllJSONJokes then set it to memory cache.
|
|
|
|
func SetAllJSONJoke(db *pgxpool.Pool, ctx context.Context, memory *bigcache.BigCache) error {
|
|
|
|
jokes, err := GetAllJSONJokes(db, ctx)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
err = memory.Set("jokes", jokes)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func SetTotalJoke(db *pgxpool.Pool, ctx context.Context, memory *bigcache.BigCache) error {
|
|
|
|
check, err := CheckJokesCache(memory)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if !check {
|
|
|
|
err = SetAllJSONJoke(db, ctx, memory)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
jokes, err := memory.Get("jokes")
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
var data []schema.Joke
|
|
|
|
err = ffjson.Unmarshal(jokes, &data)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2022-05-11 14:35:14 +00:00
|
|
|
var total = []byte(strconv.Itoa(len(data)))
|
2021-10-18 08:31:17 +00:00
|
|
|
err = memory.Set("total", total)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func InsertJokeIntoDB(db *pgxpool.Pool, ctx context.Context, joke schema.Joke) error {
|
|
|
|
conn, err := db.Acquire(ctx)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer conn.Release()
|
|
|
|
|
|
|
|
var query = squirrel.StatementBuilder.PlaceholderFormat(squirrel.Dollar)
|
|
|
|
sql, args, err := query.
|
|
|
|
Insert("jokesbapak2").
|
|
|
|
Columns("link", "creator").
|
|
|
|
Values(joke.Link, joke.Creator).
|
|
|
|
ToSql()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2021-11-01 12:32:33 +00:00
|
|
|
r, err := conn.Query(ctx, sql, args...)
|
2021-10-18 08:31:17 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer r.Close()
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func DeleteSingleJoke(db *pgxpool.Pool, ctx context.Context, id int) error {
|
|
|
|
conn, err := db.Acquire(ctx)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer conn.Release()
|
|
|
|
|
|
|
|
var query = squirrel.StatementBuilder.PlaceholderFormat(squirrel.Dollar)
|
|
|
|
sql, args, err := query.
|
|
|
|
Delete("jokesbapak2").
|
|
|
|
Where(squirrel.Eq{"id": id}).
|
|
|
|
ToSql()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2021-11-01 12:32:33 +00:00
|
|
|
r, err := conn.Query(ctx, sql, args...)
|
2021-10-18 08:31:17 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer r.Close()
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2021-11-06 17:45:18 +00:00
|
|
|
func UpdateJoke(db *pgxpool.Pool, ctx context.Context, newJoke schema.Joke) error {
|
2021-10-18 08:31:17 +00:00
|
|
|
conn, err := db.Acquire(ctx)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer conn.Release()
|
|
|
|
|
|
|
|
var query = squirrel.StatementBuilder.PlaceholderFormat(squirrel.Dollar)
|
|
|
|
sql, args, err := query.
|
|
|
|
Update("jokesbapak2").
|
2021-11-06 17:45:18 +00:00
|
|
|
Set("link", newJoke.Link).
|
|
|
|
Set("creator", newJoke.Creator).
|
|
|
|
Where(squirrel.Eq{"id": newJoke.ID}).
|
2021-10-18 08:31:17 +00:00
|
|
|
ToSql()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2021-11-01 12:32:33 +00:00
|
|
|
r, err := conn.Query(ctx, sql, args...)
|
2021-10-18 08:31:17 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer r.Close()
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|