gocron/models/host.go

80 lines
2.0 KiB
Go
Raw Normal View History

2017-03-10 09:24:06 +00:00
package models
// 主机
type Host struct {
2017-04-02 02:38:49 +00:00
Id int16 `xorm:"smallint pk autoincr"`
Name string `xorm:"varchar(128) notnull"` // 主机名称
Alias string `xorm:"varchar(32) notnull default '' "` // 主机别名
Username string `xorm:"varchar(32) notnull default '' "` // ssh 用户名
Password string `xorm:"varchar(64) notnull default ''"` // ssh 密码
Port int `xorm:"notnull default 22"` // 主机端口
Remark string `xorm:"varchar(512) notnull default '' "` // 备注
Page int `xorm:"-"`
PageSize int `xorm:"-"`
2017-03-10 09:24:06 +00:00
}
// 新增
2017-04-02 02:19:52 +00:00
func (host *Host) Create() (insertId int16, err error) {
2017-04-02 02:38:49 +00:00
_, err = Db.Insert(host)
if err == nil {
insertId = host.Id
}
2017-03-24 09:55:44 +00:00
2017-04-02 02:38:49 +00:00
return
2017-03-10 09:24:06 +00:00
}
// 更新
2017-04-02 02:19:52 +00:00
func (host *Host) Update(id int, data CommonMap) (int64, error) {
2017-04-02 02:38:49 +00:00
return Db.Table(host).ID(id).Update(data)
2017-03-10 09:24:06 +00:00
}
// 删除
2017-04-02 02:19:52 +00:00
func (host *Host) Delete(id int) (int64, error) {
2017-04-02 02:38:49 +00:00
return Db.Id(id).Delete(host)
2017-03-10 09:24:06 +00:00
}
2017-04-16 08:24:09 +00:00
func (host *Host) Find(id int) error {
_, err := Db.Id(id).Get(host)
return err
}
2017-04-13 09:35:59 +00:00
func (host *Host) NameExists(name string) (bool, error) {
count, err := Db.Where("name = ?", name).Count(host);
return count > 0, err
}
2017-04-02 02:19:52 +00:00
func (host *Host) List() ([]Host, error) {
2017-04-02 02:38:49 +00:00
host.parsePageAndPageSize()
list := make([]Host, 0)
err := Db.Desc("id").Limit(host.PageSize, host.pageLimitOffset()).Find(&list)
2017-03-10 09:24:06 +00:00
2017-04-02 02:38:49 +00:00
return list, err
2017-03-10 09:24:06 +00:00
}
func (host *Host) AllList() ([]Host, error) {
host.parsePageAndPageSize()
list := make([]Host, 0)
err := Db.Desc("id").Find(&list)
return list, err
}
2017-04-02 02:19:52 +00:00
func (host *Host) Total() (int64, error) {
2017-04-02 02:38:49 +00:00
return Db.Count(host)
2017-03-10 09:24:06 +00:00
}
2017-04-02 02:19:52 +00:00
func (host *Host) parsePageAndPageSize() {
2017-04-02 02:38:49 +00:00
if host.Page <= 0 {
host.Page = Page
}
if host.PageSize >= 0 || host.PageSize > MaxPageSize {
host.PageSize = PageSize
}
2017-03-10 09:24:06 +00:00
}
2017-04-02 02:19:52 +00:00
func (host *Host) pageLimitOffset() int {
2017-04-02 02:38:49 +00:00
return (host.Page - 1) * host.PageSize
2017-04-02 02:19:52 +00:00
}