|
- package db
-
- import (
- "applet/app/db/model"
- "applet/app/utils/logx"
- "fmt"
- "xorm.io/xorm"
- )
-
- // UserisExistByUsernameAndPassword is usernameAndPassword exist
- func UserisExistByUsernameAndPassword(Db *xorm.Engine, username, password, zone string) (bool, error) {
- sess := Db.Where("(username = ? or phone=?) AND password = ?", username, username, password)
- if zone != "" && zone != "86" {
- sess = sess.And("zone=?", zone)
- }
- has, err := sess.Exist(&model.User{})
-
- if err != nil {
- return false, err
- }
- return has, nil
- }
-
- // UserisExistByMobile is exist
- func UserisExistByMobile(Db *xorm.Engine, n string) (bool, error) {
- has, err := Db.Where("phone = ? and phone<>''", n).Exist(&model.User{})
-
- if err != nil {
- return false, err
- }
- return has, nil
- }
-
- // UserInByUIDByLevel is In查询 以及是否是有效用户
- func UserInByUIDByLevel(Db *xorm.Engine, ids []int, levelID interface{}) (*[]model.User, error) {
- var m []model.User
- if err := Db.In("uid", ids).Where("level = ?", levelID).
- Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
-
- // UserFindByMobile search user by mobile
- func UserFindByMobile(Db *xorm.Engine, mobile string) (*model.User, error) {
- var m model.User
- if has, err := Db.Where("phone LIKE ? AND delete_at = 0", "%"+mobile).
- Get(&m); err != nil || has == false {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
-
- // UserFindExistByMobile search user by mobile
- func UserFindExistByMobile(Db *xorm.Engine, mobile string) (*model.User, bool, error) {
- var m model.User
- has, err := Db.Where("(phone = ? OR uid = ?) AND delete_at = 0", mobile, mobile).Get(&m)
- if err != nil {
- logx.Infof("UserFindExistByMobile err")
- return nil, false, logx.Warn(err)
- }
- return &m, has, nil
- }
-
- // UserFindByMobile search user by mobile
- func UserFindByMobileAll(Db *xorm.Engine, mobile string) (*model.User, error) {
- var m model.User
- if has, err := Db.Where("(phone = ? OR uid = ?)", mobile, mobile).
- Get(&m); err != nil || has == false {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
-
- // UserGetByMobileIgnoreDelete search user by mobile ignore delete
- func UserGetByMobileIgnoreDelete(Db *xorm.Engine, mobile, zone string) (*model.User, bool, error) {
- m := new(model.User)
- sess := Db.Where("phone = ?", mobile)
- if zone != "" && zone != "86" {
- sess = sess.And("zone=?", zone)
- }
- has, err := sess.Get(m)
- if err != nil {
- return nil, false, logx.Warn(err)
- }
- return m, has, nil
- }
-
- // UsersFindByMobileLike search users by mobile
- func UsersFindByMobileLike(Db *xorm.Engine, mobile string) (*[]model.User, error) {
- var m []model.User
- if err := Db.Where("phone like ?", "%"+mobile+"%").
- Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
-
- // UsersFindByNickNameLike search users by nickname
- func UsersFindByNickNameLike(Db *xorm.Engine, nickname string) (*[]model.User, error) {
- var m []model.User
- if err := Db.Where("nickname like ?", "%"+nickname+"%").
- Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
-
- // UsersInByIds is 根据ids 查找users
- func UsersInByIds(Db *xorm.Engine, ids []int, limit, start int) (*[]model.User, error) {
- var m []model.User
- if limit == 0 && start == 0 {
- if err := Db.In("uid", ids).
- Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
- if err := Db.In("uid", ids).Limit(limit, start).
- Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
-
- // UsersInByIdsWhereLv is 根据ids和 lv会员等级 查找users
- func UsersInByIdsWhereLv(Db *xorm.Engine, ids []int, lv interface{}, limit, start int) (*[]model.User, error) {
- var m []model.User
- if limit == 0 && start == 0 {
- if err := Db.Where("level = ?", lv).In("uid", ids).
- Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
- if err := Db.Where("level = ?", lv).In("uid", ids).Limit(limit, start).
- Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
-
- // UsersInByIdsByAscWhereLv is 根据ids和 lv会员等级 查找users 升排序
- func UsersInByIdsByAscWhereLv(Db *xorm.Engine, ids []int, lv interface{}, limit, start int, c string) (*[]model.User, error) {
- var m []model.User
- if limit == 0 && start == 0 {
- if err := Db.Where("level = ?", lv).In("uid", ids).Asc(c).
- Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
- if err := Db.Where("level = ?", lv).In("uid", ids).Asc(c).Limit(limit, start).
- Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
-
- // UsersInByIdsByDescWhereLv is 根据ids和 lv会员等级 查找users 降排序
- func UsersInByIdsByDescWhereLv(Db *xorm.Engine, ids []int, lv interface{}, limit, start int, c string) (*[]model.User, error) {
- var m []model.User
- if limit == 0 && start == 0 {
- if err := Db.Where("level = ?", lv).In("uid", ids).Desc(c).
- Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
- if err := Db.Where("level = ?", lv).In("uid", ids).Desc(c).Limit(limit, start).
- Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
-
- // UserFindByArkidUserName search user by mobile
- func UserFindByArkidUserName(Db *xorm.Engine, name string) (*model.User, error) {
- var m model.User
- if has, err := Db.Where("username = ?", name).
- Get(&m); err != nil || has == false {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
-
- // UserFindByID is find user byid
- func UserFindByID(Db *xorm.Engine, id interface{}) (*model.User, error) {
- var m model.User
- if _, err := Db.Where("uid = ?", id).
- Get(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
-
- func UserFindByIDs(Db *xorm.Engine, uids []int) (*[]model.User, error) {
- var m []model.User
- if err := Db.In("uid", uids).Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
-
- // UsersInByIdsByDesc is 根据某列 降序
- func UsersInByIdsByDesc(Db *xorm.Engine, ids []int, limit, start int, c string) (*[]model.User, error) {
- var m []model.User
- if limit == 0 && start == 0 {
- if err := Db.In("uid", ids).Desc(c).
- Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
- if err := Db.In("uid", ids).Desc(c).Limit(limit, start).
- Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
-
- // UsersInByIdsByAsc is 根据某列 升序
- func UsersInByIdsByAsc(Db *xorm.Engine, ids []int, limit, start int, c string) (*[]model.User, error) {
- var m []model.User
- if limit == 0 && start == 0 {
- if err := Db.In("uid", ids).Asc(c).
- Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
- if err := Db.In("uid", ids).Asc(c).Limit(limit, start).
- Find(&m); err != nil {
- return nil, logx.Warn(err)
- }
- return &m, nil
- }
-
- // UserInsert is insert user
- func UserInsert(Db *xorm.Engine, user *model.User) (int64, error) {
- affected, err := Db.Insert(user)
- if err != nil {
- return 0, err
- }
- return affected, nil
- }
-
- // UserIsExistByMobile is mobile exist
- func UserIsExistByMobile(Db *xorm.Engine, mobile string) (bool, error) {
- //fmt.Println(mobile)
- has, err := Db.Where("phone = ? OR uid = ?", mobile, mobile).Exist(&model.User{})
- fmt.Println(has, mobile)
- if err != nil {
- return false, err
- }
- return has, nil
- }
-
- // UserIsExistByID is mobile exist by id
- func UserIsExistByID(Db *xorm.Engine, id string) (bool, error) {
- has, err := Db.Where("uid = ?", id).Exist(&model.User{})
- if err != nil {
- return false, err
- }
- return has, nil
- }
-
- // UserUpdate is update user
- func UserUpdate(Db *xorm.Engine, uid interface{}, user *model.User, forceColums ...string) (int64, error) {
- var (
- affected int64
- err error
- )
- if forceColums != nil {
- affected, err = Db.Where("uid=?", uid).Cols(forceColums...).Update(user)
- } else {
- affected, err = Db.Where("uid=?", uid).Update(user)
- }
- if err != nil {
- return 0, err
- }
- return affected, nil
- }
-
- func UpdateUserFinValid() {
-
- }
-
- // UserDelete is delete user
- func UserDelete(Db *xorm.Engine, uid interface{}) (int64, error) {
- return Db.Where("uid = ?", uid).Delete(model.User{})
- }
-
- func UserDeleteWithSess(sess *xorm.Session, uid interface{}) (int64, error) {
- return sess.Where("uid = ?", uid).Delete(model.User{})
- }
-
- func UserFindByLevel(eg *xorm.Engine, level int) []model.User {
- var data []model.User
- eg.Where("level=?", level).Find(&data)
- return data
- }
|