123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167 |
- package archive
- import (
- "context"
- "database/sql"
- "encoding/json"
- "strconv"
- "strings"
- "go-common/app/admin/main/videoup/model/archive"
- "go-common/library/log"
- "go-common/library/xstr"
- )
- const (
- _confSQL = "SELECT value FROM archive_config WHERE state=0 AND name=?"
- _upconfSQL = "UPDATE archive_config SET value=?,remark=? WHERE name=?"
- _inconfSQL = "INSERT archive_config(value,remark,name,state) VALUE (?,?,?,0)"
- )
- // FansConf is fan round check types config.
- func (d *Dao) FansConf(c context.Context) (fans int64, err error) {
- row := d.rddb.QueryRow(c, _confSQL, archive.ConfForClick)
- var val string
- if err = row.Scan(&val); err != nil {
- if err == sql.ErrNoRows {
- err = nil
- } else {
- log.Error("row.Scan error(%v)", err)
- }
- return
- }
- if fans, err = strconv.ParseInt(val, 10, 64); err != nil {
- log.Error("strconv.ParseInt(%s) error(%v)", val, err)
- }
- return
- }
- // RoundTypeConf is typeid round check types config.
- func (d *Dao) RoundTypeConf(c context.Context) (roundTypes map[int16]struct{}, err error) {
- roundTypes = map[int16]struct{}{}
- row := d.rddb.QueryRow(c, _confSQL, archive.ConfForRoundType)
- var (
- val string
- tids []string
- tid int64
- )
- if err = row.Scan(&val); err != nil {
- if err == sql.ErrNoRows {
- err = nil
- } else {
- log.Error("row.Scan error(%v)", err)
- }
- return
- }
- tids = strings.Split(val, ",")
- for _, tidStr := range tids {
- if tid, err = strconv.ParseInt(tidStr, 10, 64); err != nil {
- log.Error("strconv.ParseInt(%s) error(%v)", tid, err)
- return
- }
- roundTypes[int16(tid)] = struct{}{}
- }
- return
- }
- // ThresholdConf is second types opposite first types.
- func (d *Dao) ThresholdConf(c context.Context) (tpThr map[int16]int, err error) {
- row := d.rddb.QueryRow(c, _confSQL, archive.ConfForThreshold)
- var value string
- if err = row.Scan(&value); err != nil {
- if err == sql.ErrNoRows {
- err = nil
- } else {
- log.Error("row.Scan() error(%v)", err)
- }
- return
- }
- if err = json.Unmarshal([]byte(value), &tpThr); err != nil {
- log.Error("json.Unmarshal(%s) error(%v)", value, err)
- return
- }
- return
- }
- // AuditTypesConf is audit types.
- func (d *Dao) AuditTypesConf(c context.Context) (atps map[int16]struct{}, err error) {
- row := d.rddb.QueryRow(c, _confSQL, archive.ConfForWaitAudit)
- var (
- value string
- typeIDs []int64
- )
- if err = row.Scan(&value); err != nil {
- if err == sql.ErrNoRows {
- err = nil
- } else {
- log.Error("row.Scan error(%v)", err)
- }
- return
- }
- typeIDs, err = xstr.SplitInts(value)
- if err != nil {
- log.Error("archive_config value(%s) xstr.SplitInts error(%v)", value, err)
- return
- }
- atps = map[int16]struct{}{}
- for _, typeid := range typeIDs {
- atps[int16(typeid)] = struct{}{}
- }
- return
- }
- // WeightVC 获取权重分值
- func (d *Dao) WeightVC(c context.Context) (wvc *archive.WeightVC, err error) {
- var value []byte
- row := d.rddb.QueryRow(c, _confSQL, archive.ConfForWeightVC)
- if err = row.Scan(&value); err != nil {
- if err == sql.ErrNoRows {
- err = nil
- } else {
- log.Error("row.Scan error(%v)", err)
- }
- return
- }
- wvc = new(archive.WeightVC)
- if err = json.Unmarshal(value, wvc); err != nil {
- log.Error("json.Unmarshal error(%v)", err)
- wvc = nil
- }
- return
- }
- // SetWeightVC 设置权重分值
- func (d *Dao) SetWeightVC(c context.Context, wvc *archive.WeightVC, desc string) (rows int64, err error) {
- var (
- valueb []byte
- res sql.Result
- )
- if valueb, err = json.Marshal(wvc); err != nil {
- log.Error("json.Marshal(%+v) error(%v)", wvc, err)
- return
- }
- if res, err = d.db.Exec(c, _upconfSQL, string(valueb), desc, archive.ConfForWeightVC); err != nil {
- log.Error("d.db.Exec(%s, %s, %s, %s) error(%v)", _upconfSQL, string(valueb), desc, archive.ConfForWeightVC, err)
- return
- }
- return res.RowsAffected()
- }
- // InWeightVC 插入
- func (d *Dao) InWeightVC(c context.Context, wvc *archive.WeightVC, desc string) (rows int64, err error) {
- var (
- valueb []byte
- res sql.Result
- )
- if valueb, err = json.Marshal(wvc); err != nil {
- log.Error("json.Marshal(%+v) error(%v)", wvc, err)
- return
- }
- if res, err = d.db.Exec(c, _inconfSQL, string(valueb), desc, archive.ConfForWeightVC); err != nil {
- log.Error("d.db.Exec(%s, %s, %s, %s) error(%v)", _inconfSQL, string(valueb), desc, archive.ConfForWeightVC, err)
- return
- }
- return res.LastInsertId()
- }
|