mirror of
https://github.com/abhinavxd/libredesk.git
synced 2025-11-02 04:53:41 +00:00
105 lines
3.4 KiB
Go
105 lines
3.4 KiB
Go
// Package businesshours handles the management of business hours and holidays.
|
|
package businesshours
|
|
|
|
import (
|
|
"embed"
|
|
|
|
"github.com/abhinavxd/libredesk/internal/business_hours/models"
|
|
"github.com/abhinavxd/libredesk/internal/dbutil"
|
|
"github.com/abhinavxd/libredesk/internal/envelope"
|
|
"github.com/jmoiron/sqlx"
|
|
"github.com/jmoiron/sqlx/types"
|
|
"github.com/volatiletech/null/v9"
|
|
"github.com/zerodha/logf"
|
|
)
|
|
|
|
var (
|
|
//go:embed queries.sql
|
|
efs embed.FS
|
|
)
|
|
|
|
// Manager manages business hours.
|
|
type Manager struct {
|
|
q queries
|
|
lo *logf.Logger
|
|
}
|
|
|
|
// Opts contains options for initializing the Manager.
|
|
type Opts struct {
|
|
DB *sqlx.DB
|
|
Lo *logf.Logger
|
|
}
|
|
|
|
// queries contains prepared SQL queries.
|
|
type queries struct {
|
|
GetBusinessHours *sqlx.Stmt `query:"get-business-hours"`
|
|
GetAllBusinessHours *sqlx.Stmt `query:"get-all-business-hours"`
|
|
InsertBusinessHours *sqlx.Stmt `query:"insert-business-hours"`
|
|
DeleteBusinessHours *sqlx.Stmt `query:"delete-business-hours"`
|
|
UpdateBusinessHours *sqlx.Stmt `query:"update-business-hours"`
|
|
InsertHoliday *sqlx.Stmt `query:"insert-holiday"`
|
|
DeleteHoliday *sqlx.Stmt `query:"delete-holiday"`
|
|
GetAllHolidays *sqlx.Stmt `query:"get-all-holidays"`
|
|
}
|
|
|
|
// New creates and returns a new instance of the Manager.
|
|
func New(opts Opts) (*Manager, error) {
|
|
var q queries
|
|
|
|
if err := dbutil.ScanSQLFile("queries.sql", &q, opts.DB, efs); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &Manager{
|
|
q: q,
|
|
lo: opts.Lo,
|
|
}, nil
|
|
}
|
|
|
|
// Get retrieves business hours by ID.
|
|
func (m *Manager) Get(id int) (models.BusinessHours, error) {
|
|
var bh models.BusinessHours
|
|
if err := m.q.GetBusinessHours.Get(&bh, id); err != nil {
|
|
m.lo.Error("error fetching business hours", "error", err)
|
|
return bh, envelope.NewError(envelope.GeneralError, "Error fetching business hours", nil)
|
|
}
|
|
return bh, nil
|
|
}
|
|
|
|
// GetAll retrieves all business hours.
|
|
func (m *Manager) GetAll() ([]models.BusinessHours, error) {
|
|
var hours = make([]models.BusinessHours, 0)
|
|
if err := m.q.GetAllBusinessHours.Select(&hours); err != nil {
|
|
m.lo.Error("error fetching business hours", "error", err)
|
|
return nil, envelope.NewError(envelope.GeneralError, "Error fetching business hours", nil)
|
|
}
|
|
return hours, nil
|
|
}
|
|
|
|
// Create creates new business hours.
|
|
func (m *Manager) Create(name string, description null.String, isAlwaysOpen bool, workingHrs, holidays types.JSONText) error {
|
|
if _, err := m.q.InsertBusinessHours.Exec(name, description, isAlwaysOpen, workingHrs, holidays); err != nil {
|
|
m.lo.Error("error inserting business hours", "error", err)
|
|
return envelope.NewError(envelope.GeneralError, "Error creating business hours", nil)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// Delete deletes business hours by ID.
|
|
func (m *Manager) Delete(id int) error {
|
|
if _, err := m.q.DeleteBusinessHours.Exec(id); err != nil {
|
|
m.lo.Error("error deleting business hours", "error", err)
|
|
return envelope.NewError(envelope.GeneralError, "Error deleting business hours", nil)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// Update updates business hours by ID.
|
|
func (m *Manager) Update(id int, name string, description null.String, isAlwaysOpen bool, workingHrs, holidays types.JSONText) error {
|
|
if _, err := m.q.UpdateBusinessHours.Exec(id, name, description, isAlwaysOpen, workingHrs, holidays); err != nil {
|
|
m.lo.Error("error updating business hours", "error", err)
|
|
return envelope.NewError(envelope.GeneralError, "Error updating business hours", nil)
|
|
}
|
|
return nil
|
|
}
|