2022-05-11 22:47:31 +00:00
|
|
|
package host
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"npm/internal/database"
|
|
|
|
"npm/internal/entity/certificate"
|
2022-07-21 08:02:07 +00:00
|
|
|
"npm/internal/entity/hosttemplate"
|
2022-05-11 22:47:31 +00:00
|
|
|
"npm/internal/entity/user"
|
|
|
|
"npm/internal/types"
|
|
|
|
"npm/internal/util"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
tableName = "host"
|
|
|
|
|
|
|
|
// ProxyHostType is self explanatory
|
|
|
|
ProxyHostType = "proxy"
|
|
|
|
// RedirectionHostType is self explanatory
|
|
|
|
RedirectionHostType = "redirection"
|
|
|
|
// DeadHostType is self explanatory
|
|
|
|
DeadHostType = "dead"
|
2022-07-14 22:52:38 +00:00
|
|
|
// StatusReady means a host is ready to configure
|
|
|
|
StatusReady = "ready"
|
|
|
|
// StatusOK means a host is configured within Nginx
|
|
|
|
StatusOK = "ok"
|
|
|
|
// StatusError is self explanatory
|
|
|
|
StatusError = "error"
|
2022-05-11 22:47:31 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// Model is the user model
|
|
|
|
type Model struct {
|
|
|
|
ID int `json:"id" db:"id" filter:"id,integer"`
|
|
|
|
CreatedOn types.DBDate `json:"created_on" db:"created_on" filter:"created_on,integer"`
|
|
|
|
ModifiedOn types.DBDate `json:"modified_on" db:"modified_on" filter:"modified_on,integer"`
|
|
|
|
UserID int `json:"user_id" db:"user_id" filter:"user_id,integer"`
|
|
|
|
Type string `json:"type" db:"type" filter:"type,string"`
|
|
|
|
HostTemplateID int `json:"host_template_id" db:"host_template_id" filter:"host_template_id,integer"`
|
|
|
|
ListenInterface string `json:"listen_interface" db:"listen_interface" filter:"listen_interface,string"`
|
|
|
|
DomainNames types.JSONB `json:"domain_names" db:"domain_names" filter:"domain_names,string"`
|
|
|
|
UpstreamID int `json:"upstream_id" db:"upstream_id" filter:"upstream_id,integer"`
|
|
|
|
CertificateID int `json:"certificate_id" db:"certificate_id" filter:"certificate_id,integer"`
|
|
|
|
AccessListID int `json:"access_list_id" db:"access_list_id" filter:"access_list_id,integer"`
|
|
|
|
SSLForced bool `json:"ssl_forced" db:"ssl_forced" filter:"ssl_forced,boolean"`
|
|
|
|
CachingEnabled bool `json:"caching_enabled" db:"caching_enabled" filter:"caching_enabled,boolean"`
|
|
|
|
BlockExploits bool `json:"block_exploits" db:"block_exploits" filter:"block_exploits,boolean"`
|
|
|
|
AllowWebsocketUpgrade bool `json:"allow_websocket_upgrade" db:"allow_websocket_upgrade" filter:"allow_websocket_upgrade,boolean"`
|
|
|
|
HTTP2Support bool `json:"http2_support" db:"http2_support" filter:"http2_support,boolean"`
|
|
|
|
HSTSEnabled bool `json:"hsts_enabled" db:"hsts_enabled" filter:"hsts_enabled,boolean"`
|
|
|
|
HSTSSubdomains bool `json:"hsts_subdomains" db:"hsts_subdomains" filter:"hsts_subdomains,boolean"`
|
|
|
|
Paths string `json:"paths" db:"paths" filter:"paths,string"`
|
|
|
|
UpstreamOptions string `json:"upstream_options" db:"upstream_options" filter:"upstream_options,string"`
|
|
|
|
AdvancedConfig string `json:"advanced_config" db:"advanced_config" filter:"advanced_config,string"`
|
2022-07-14 22:52:38 +00:00
|
|
|
Status string `json:"status" db:"status" filter:"status,string"`
|
|
|
|
ErrorMessage string `json:"error_message" db:"error_message" filter:"error_message,string"`
|
2022-05-11 22:47:31 +00:00
|
|
|
IsDisabled bool `json:"is_disabled" db:"is_disabled" filter:"is_disabled,boolean"`
|
|
|
|
IsDeleted bool `json:"is_deleted,omitempty" db:"is_deleted"`
|
|
|
|
// Expansions
|
2022-07-21 08:02:07 +00:00
|
|
|
Certificate *certificate.Model `json:"certificate,omitempty"`
|
|
|
|
HostTemplate *hosttemplate.Model `json:"host_template,omitempty"`
|
|
|
|
User *user.Model `json:"user,omitempty"`
|
2022-05-11 22:47:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (m *Model) getByQuery(query string, params []interface{}) error {
|
|
|
|
return database.GetByQuery(m, query, params)
|
|
|
|
}
|
|
|
|
|
|
|
|
// LoadByID will load from an ID
|
|
|
|
func (m *Model) LoadByID(id int) error {
|
|
|
|
query := fmt.Sprintf("SELECT * FROM `%s` WHERE id = ? AND is_deleted = ? LIMIT 1", tableName)
|
|
|
|
params := []interface{}{id, 0}
|
|
|
|
return m.getByQuery(query, params)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Touch will update model's timestamp(s)
|
|
|
|
func (m *Model) Touch(created bool) {
|
|
|
|
var d types.DBDate
|
|
|
|
d.Time = time.Now()
|
|
|
|
if created {
|
|
|
|
m.CreatedOn = d
|
|
|
|
}
|
|
|
|
m.ModifiedOn = d
|
|
|
|
}
|
|
|
|
|
|
|
|
// Save will save this model to the DB
|
2022-07-21 08:02:07 +00:00
|
|
|
func (m *Model) Save(skipConfiguration bool) error {
|
2022-05-11 22:47:31 +00:00
|
|
|
var err error
|
|
|
|
|
|
|
|
if m.UserID == 0 {
|
|
|
|
return fmt.Errorf("User ID must be specified")
|
|
|
|
}
|
|
|
|
|
2022-07-21 08:02:07 +00:00
|
|
|
if !skipConfiguration {
|
|
|
|
// Set this host as requiring reconfiguration
|
|
|
|
m.Status = StatusReady
|
|
|
|
}
|
2022-07-14 22:52:38 +00:00
|
|
|
|
2022-05-11 22:47:31 +00:00
|
|
|
if m.ID == 0 {
|
|
|
|
m.ID, err = create(m)
|
|
|
|
} else {
|
|
|
|
err = update(m)
|
|
|
|
}
|
|
|
|
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Delete will mark a host as deleted
|
|
|
|
func (m *Model) Delete() bool {
|
|
|
|
m.Touch(false)
|
|
|
|
m.IsDeleted = true
|
2022-07-21 08:02:07 +00:00
|
|
|
if err := m.Save(false); err != nil {
|
2022-05-11 22:47:31 +00:00
|
|
|
return false
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
// Expand will fill in more properties
|
|
|
|
func (m *Model) Expand(items []string) error {
|
|
|
|
var err error
|
|
|
|
|
|
|
|
if util.SliceContainsItem(items, "user") && m.ID > 0 {
|
|
|
|
var usr user.Model
|
|
|
|
usr, err = user.GetByID(m.UserID)
|
|
|
|
m.User = &usr
|
|
|
|
}
|
|
|
|
|
|
|
|
if util.SliceContainsItem(items, "certificate") && m.CertificateID > 0 {
|
|
|
|
var cert certificate.Model
|
|
|
|
cert, err = certificate.GetByID(m.CertificateID)
|
|
|
|
m.Certificate = &cert
|
|
|
|
}
|
|
|
|
|
2022-07-21 08:02:07 +00:00
|
|
|
if util.SliceContainsItem(items, "hosttemplate") && m.HostTemplateID > 0 {
|
|
|
|
var templ hosttemplate.Model
|
|
|
|
templ, err = hosttemplate.GetByID(m.HostTemplateID)
|
|
|
|
m.HostTemplate = &templ
|
|
|
|
}
|
|
|
|
|
2022-05-11 22:47:31 +00:00
|
|
|
return err
|
|
|
|
}
|