123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218 |
- package models
- import (
- "eta/eta_forum_admin/utils"
- "github.com/beego/beego/v2/client/orm"
- "github.com/rdlucklib/rdluck_tools/paging"
- "time"
- )
- type User struct {
- UserId int `orm:"column(user_id);pk"`
- BusinessCode string
- EtaBusinessId int
- UserName string `description:"用户名"`
- RealName string `description:"姓名"`
- Mobile string
- Email string
- NickName string `description:"昵称"`
- CountryCode string `description:"区号,86、852、886等"`
- LastLoginTime time.Time
- IsFreeLogin int `description:"是否30天免登录,0否,1是"`
- RegisterTime time.Time
- LastCollectChartTime string `description:"最近收藏图表时间"`
- Enabled int
- DepartmentName string `description:"部门名称"`
- Position string `description:"岗位"`
- PositionStatus int `description:"在职状态:1:在职,0:离职"`
- CreatedTime time.Time
- LastUpdatedTime time.Time `description:"最近一次更新时间"`
- SellerId int `description:"销售ID"`
- SellerName string `description:"销售名称"`
- }
- // 用户详情出参
- type UserResp struct {
- Detail *User
- }
- func AddUser(item *User) (lastId int64, err error) {
- o := orm.NewOrm()
- lastId, err = o.Insert(item)
- return
- }
- func GetUserByMobile(mobile string) (item *User, err error) {
- o := orm.NewOrm()
- sql := `SELECT * FROM user WHERE mobile = ? LIMIT 1`
- err = o.Raw(sql, mobile).QueryRow(&item)
- return
- }
- func GetUserByMobiles(mobiles []string) (items []*User, err error) {
- o := orm.NewOrm()
- sql := `SELECT * FROM user WHERE mobile in (` + utils.GetOrmInReplace(len(mobiles)) + `)`
- _, err = o.Raw(sql, mobiles).QueryRows(&items)
- return
- }
- // GetUserByMobileCountryCode 根据手机号和区号获取用户信息
- func GetUserByMobileCountryCode(mobile, countryCode string) (item *User, err error) {
- o := orm.NewOrm()
- sql := `SELECT * FROM user WHERE mobile = ? `
- sql += ` and country_code =? `
- sql += ` LIMIT 1 `
- err = o.Raw(sql, mobile, countryCode).QueryRow(&item)
- return
- }
- func GetUserByUserId(userId int) (item *User, err error) {
- o := orm.NewOrm()
- sql := `SELECT * FROM user WHERE user_id=? `
- err = o.Raw(sql, userId).QueryRow(&item)
- return
- }
- // 更新User信息
- func (User *User) Update(cols []string) (err error) {
- o := orm.NewOrm()
- _, err = o.Update(User, cols...)
- return
- }
- // 获取该用户数量
- func GetUserCountByCondition(condition string, pars []interface{}) (count int, err error) {
- o := orm.NewOrm()
- tmpSql := `SELECT *
- FROM
- user
- WHERE
- 1=1 `
- if condition != "" {
- tmpSql += condition
- }
- sql := `SELECT COUNT(1) AS count FROM (` + tmpSql + `) AS c `
- err = o.Raw(sql, pars).QueryRow(&count)
- return
- }
- // 获取该用户列表
- func GetUserPageListByCondition(condition string, pars []interface{}, order string, startSize, pageSize int) (items []*User, err error) {
- o := orm.NewOrm()
- tmpSql := `SELECT *
- FROM
- user
- WHERE
- 1=1 `
- if condition != "" {
- tmpSql += condition
- }
- if order != "" {
- tmpSql += ` ORDER BY ` + order + ", user_id DESC"
- } else {
- tmpSql += ` ORDER BY last_updated_time desc, user_id DESC`
- }
- tmpSql += ` Limit ?,?`
- _, err = o.Raw(tmpSql, pars, startSize, pageSize).QueryRows(&items)
- return
- }
- type BusinessUser struct {
- UserId int
- BusinessCode string
- EtaBusinessId int
- BusinessName string
- UserName string `description:"用户名"`
- RealName string `description:"姓名"`
- Mobile string
- Email string
- CountryCode string `description:"区号,86、852、886等"`
- LastLoginTime string
- Enabled int
- DepartmentName string `description:"部门名称"`
- Position string `description:"岗位"`
- PositionStatus int `description:"在职状态:1:在职,0:离职"`
- CreatedTime string
- LastUpdatedTime string `description:"最近一次更新时间"`
- BusinessSellerId int `description:"销售ID"`
- BusinessSellerName string `description:"销售名称"`
- }
- type UserListResp struct {
- Paging *paging.PagingItem
- List []*BusinessUser
- }
- // 新增用户请求参数
- type AddUserReq struct {
- RealName string `description:"姓名"`
- CountryCode string `description:"区号,86、852、886等"`
- Mobile string `description:"手机号"`
- //Email string `description:"邮箱"`
- Position string `description:"职位"`
- PositionStatus int `description:"在职状态:1:在职,0:离职"`
- EtaBusinessId int
- DepartmentName string `description:"联系人部门"`
- }
- // 删除客户请求参数
- type DeleteUserReq struct {
- UserId int
- }
- // 新增客户请求参数
- type EditUserReq struct {
- UserId int
- RealName string `description:"姓名"`
- CountryCode string `description:"区号,86、852、886等"`
- Mobile string `description:"手机号"`
- //Email string `description:"邮箱"`
- Position string `description:"职位"`
- PositionStatus int `description:"在职状态:1:在职,0:离职"`
- EtaBusinessId int
- DepartmentName string `description:"联系人部门"`
- }
- func DeleteUser(userId int) (err error) {
- o := orm.NewOrm()
- sql := ` DELETE FROM user WHERE user_id=? `
- _, err = o.Raw(sql, userId).Exec()
- return
- }
- // 联系人导入预览数据返回
- type ImportListResp struct {
- ValidUser []*BusinessUser `description:"有效客户数据"`
- RepeatUser []*BusinessUser `description:"重复客户数据"`
- }
- // 联系人导入预览数据返回
- type ImportUserReq struct {
- ValidUser []*ImportUserItem `description:"有效客户数据"`
- }
- type ImportUserItem struct {
- BusinessCode string
- EtaBusinessId int
- UserName string `description:"用户名"`
- RealName string `description:"姓名"`
- Mobile string
- NickName string `description:"昵称"`
- CountryCode string `description:"区号,86、852、886等"`
- DepartmentName string `description:"部门名称"`
- Position string `description:"岗位"`
- PositionStatus int `description:"在职状态:1:在职,0:离职"`
- }
- // 新增客户请求参数
- type ChangeUserBusinessReq struct {
- UserId int
- EtaBusinessId int
- //BusinessCode string `description:"商家编码"`
- }
- // UserEditEnabledReq 用户状态编辑
- type UserEditEnabledReq struct {
- UserId int `description:"系统用户id"`
- Enabled int `description:"1:有效,0:禁用"`
- }
|