egress.go 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. package schema
  2. import (
  3. "context"
  4. "time"
  5. "github.com/gravitl/netmaker/db"
  6. "gorm.io/datatypes"
  7. )
  8. const egressTable = "egresses"
  9. type Egress struct {
  10. ID string `gorm:"primaryKey" json:"id"`
  11. Name string `gorm:"name" json:"name"`
  12. Network string `gorm:"network" json:"network"`
  13. Description string `gorm:"description" json:"description"`
  14. Nodes datatypes.JSONMap `gorm:"nodes" json:"nodes"`
  15. Tags datatypes.JSONMap `gorm:"tags" json:"tags"`
  16. Range string `gorm:"range" json:"range"`
  17. DomainAns datatypes.JSONSlice[string] `gorm:"domain_ans" json:"domain_ans"`
  18. Domain string `gorm:"domain" json:"domain"`
  19. Nat bool `gorm:"nat" json:"nat"`
  20. //IsInetGw bool `gorm:"is_inet_gw" json:"is_internet_gateway"`
  21. Status bool `gorm:"status" json:"status"`
  22. CreatedBy string `gorm:"created_by" json:"created_by"`
  23. CreatedAt time.Time `gorm:"created_at" json:"created_at"`
  24. UpdatedAt time.Time `gorm:"updated_at" json:"updated_at"`
  25. }
  26. func (e *Egress) Table() string {
  27. return egressTable
  28. }
  29. func (e *Egress) Get(ctx context.Context) error {
  30. return db.FromContext(ctx).Table(e.Table()).First(&e).Where("id = ?", e.ID).Error
  31. }
  32. func (e *Egress) Update(ctx context.Context) error {
  33. return db.FromContext(ctx).Table(e.Table()).Where("id = ?", e.ID).Updates(&e).Error
  34. }
  35. func (e *Egress) UpdateNatStatus(ctx context.Context) error {
  36. return db.FromContext(ctx).Table(e.Table()).Where("id = ?", e.ID).Updates(map[string]any{
  37. "nat": e.Nat,
  38. }).Error
  39. }
  40. func (e *Egress) UpdateEgressStatus(ctx context.Context) error {
  41. return db.FromContext(ctx).Table(e.Table()).Where("id = ?", e.ID).Updates(map[string]any{
  42. "status": e.Status,
  43. }).Error
  44. }
  45. func (e *Egress) DoesEgressRouteExists(ctx context.Context) error {
  46. return db.FromContext(ctx).Table(e.Table()).Where("range = ?", e.Range).First(&e).Error
  47. }
  48. func (e *Egress) Create(ctx context.Context) error {
  49. return db.FromContext(ctx).Table(e.Table()).Create(&e).Error
  50. }
  51. func (e *Egress) ListByNetwork(ctx context.Context) (egs []Egress, err error) {
  52. err = db.FromContext(ctx).Table(e.Table()).Where("network = ?", e.Network).Find(&egs).Error
  53. return
  54. }
  55. func (e *Egress) Count(ctx context.Context) (int, error) {
  56. var count int64
  57. err := db.FromContext(ctx).Model(&Egress{}).Count(&count).Error
  58. return int(count), err
  59. }
  60. func (e *Egress) Delete(ctx context.Context) error {
  61. return db.FromContext(ctx).Table(e.Table()).Where("id = ?", e.ID).Delete(&e).Error
  62. }