mirror of
https://github.com/abhinavxd/libredesk.git
synced 2025-11-02 04:53:41 +00:00
- Translate web template pass i18n dependency - Fix colors in menu card - Show update description if avaialble in AppUpdate component - Remvoe i18n from settings as i18n and settings depend on each other to load initial lang. - Clear inbox password as the update SQL query now returns the config. - Fetch agents and inboxes from the store instead of directly fetching using axios instance.
178 lines
6.0 KiB
Go
178 lines
6.0 KiB
Go
package main
|
|
|
|
import (
|
|
"net/mail"
|
|
"strconv"
|
|
|
|
"github.com/abhinavxd/libredesk/internal/envelope"
|
|
imodels "github.com/abhinavxd/libredesk/internal/inbox/models"
|
|
"github.com/valyala/fasthttp"
|
|
"github.com/zerodha/fastglue"
|
|
)
|
|
|
|
// handleGetInboxes returns all inboxes
|
|
func handleGetInboxes(r *fastglue.Request) error {
|
|
var app = r.Context.(*App)
|
|
inboxes, err := app.inbox.GetAll()
|
|
if err != nil {
|
|
return sendErrorEnvelope(r, err)
|
|
}
|
|
for i := range inboxes {
|
|
if err := inboxes[i].ClearPasswords(); err != nil {
|
|
app.lo.Error("error clearing inbox passwords from response", "error", err)
|
|
return envelope.NewError(envelope.GeneralError, app.i18n.Ts("globals.messages.errorFetching", "name", "{globals.terms.inbox}"), nil)
|
|
}
|
|
}
|
|
return r.SendEnvelope(inboxes)
|
|
}
|
|
|
|
// handleGetInbox returns an inbox by ID
|
|
func handleGetInbox(r *fastglue.Request) error {
|
|
var (
|
|
app = r.Context.(*App)
|
|
id, _ = strconv.Atoi(r.RequestCtx.UserValue("id").(string))
|
|
)
|
|
inbox, err := app.inbox.GetDBRecord(id)
|
|
if err != nil {
|
|
return sendErrorEnvelope(r, err)
|
|
}
|
|
if err := inbox.ClearPasswords(); err != nil {
|
|
app.lo.Error("error clearing inbox passwords from response", "error", err)
|
|
return envelope.NewError(envelope.GeneralError, app.i18n.Ts("globals.messages.errorFetching", "name", "{globals.terms.inbox}"), nil)
|
|
}
|
|
return r.SendEnvelope(inbox)
|
|
}
|
|
|
|
// handleCreateInbox creates a new inbox
|
|
func handleCreateInbox(r *fastglue.Request) error {
|
|
var (
|
|
app = r.Context.(*App)
|
|
inbox = imodels.Inbox{}
|
|
)
|
|
if err := r.Decode(&inbox, "json"); err != nil {
|
|
return r.SendErrorEnvelope(fasthttp.StatusBadRequest, app.i18n.Ts("globals.messages.errorParsing", "name", "{globals.terms.request}"), err.Error(), envelope.InputError)
|
|
}
|
|
|
|
createdInbox, err := app.inbox.Create(inbox)
|
|
if err != nil {
|
|
return sendErrorEnvelope(r, err)
|
|
}
|
|
|
|
if err := validateInbox(app, createdInbox); err != nil {
|
|
return sendErrorEnvelope(r, err)
|
|
}
|
|
|
|
if err := reloadInboxes(app); err != nil {
|
|
return r.SendErrorEnvelope(fasthttp.StatusInternalServerError, app.i18n.Ts("globals.messages.couldNotReload", "name", "{globals.terms.inbox}"), nil, envelope.GeneralError)
|
|
}
|
|
|
|
// Clear passwords before returning.
|
|
if err := createdInbox.ClearPasswords(); err != nil {
|
|
app.lo.Error("error clearing inbox passwords from response", "error", err)
|
|
return envelope.NewError(envelope.GeneralError, app.i18n.Ts("globals.messages.errorFetching", "name", "{globals.terms.inbox}"), nil)
|
|
}
|
|
|
|
return r.SendEnvelope(createdInbox)
|
|
}
|
|
|
|
// handleUpdateInbox updates an inbox
|
|
func handleUpdateInbox(r *fastglue.Request) error {
|
|
var (
|
|
app = r.Context.(*App)
|
|
inbox = imodels.Inbox{}
|
|
)
|
|
id, err := strconv.Atoi(r.RequestCtx.UserValue("id").(string))
|
|
if err != nil || id == 0 {
|
|
return r.SendErrorEnvelope(fasthttp.StatusBadRequest,
|
|
app.i18n.Ts("globals.messages.invalid", "name", "`id`"), nil, envelope.InputError)
|
|
}
|
|
|
|
if err := r.Decode(&inbox, "json"); err != nil {
|
|
return r.SendErrorEnvelope(fasthttp.StatusBadRequest, app.i18n.Ts("globals.messages.errorParsing", "name", "{globals.terms.request}"), err.Error(), envelope.InputError)
|
|
}
|
|
|
|
if err := validateInbox(app, inbox); err != nil {
|
|
return sendErrorEnvelope(r, err)
|
|
}
|
|
|
|
updatedInbox, err := app.inbox.Update(id, inbox)
|
|
if err != nil {
|
|
return sendErrorEnvelope(r, err)
|
|
}
|
|
|
|
if err := reloadInboxes(app); err != nil {
|
|
return r.SendErrorEnvelope(fasthttp.StatusInternalServerError, app.i18n.Ts("globals.messages.couldNotReload", "name", "{globals.terms.inbox}"), nil, envelope.GeneralError)
|
|
}
|
|
|
|
// Clear passwords before returning.
|
|
if err := updatedInbox.ClearPasswords(); err != nil {
|
|
app.lo.Error("error clearing inbox passwords from response", "error", err)
|
|
return envelope.NewError(envelope.GeneralError, app.i18n.Ts("globals.messages.errorFetching", "name", "{globals.terms.inbox}"), nil)
|
|
}
|
|
|
|
return r.SendEnvelope(updatedInbox)
|
|
}
|
|
|
|
// handleToggleInbox toggles an inbox
|
|
func handleToggleInbox(r *fastglue.Request) error {
|
|
var (
|
|
app = r.Context.(*App)
|
|
)
|
|
id, err := strconv.Atoi(r.RequestCtx.UserValue("id").(string))
|
|
if err != nil || id == 0 {
|
|
return r.SendErrorEnvelope(fasthttp.StatusBadRequest,
|
|
app.i18n.Ts("globals.messages.invalid", "name", "`id`"), nil, envelope.InputError)
|
|
}
|
|
|
|
toggledInbox, err := app.inbox.Toggle(id)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := reloadInboxes(app); err != nil {
|
|
return r.SendErrorEnvelope(fasthttp.StatusInternalServerError, app.i18n.Ts("globals.messages.couldNotReload", "name", "{globals.terms.inbox}"), nil, envelope.GeneralError)
|
|
}
|
|
|
|
// Clear passwords before returning
|
|
if err := toggledInbox.ClearPasswords(); err != nil {
|
|
app.lo.Error("error clearing inbox passwords from response", "error", err)
|
|
return envelope.NewError(envelope.GeneralError, app.i18n.Ts("globals.messages.errorFetching", "name", "{globals.terms.inbox}"), nil)
|
|
}
|
|
|
|
return r.SendEnvelope(toggledInbox)
|
|
}
|
|
|
|
// handleDeleteInbox deletes an inbox
|
|
func handleDeleteInbox(r *fastglue.Request) error {
|
|
var (
|
|
app = r.Context.(*App)
|
|
id, _ = strconv.Atoi(r.RequestCtx.UserValue("id").(string))
|
|
)
|
|
err := app.inbox.SoftDelete(id)
|
|
if err != nil {
|
|
return sendErrorEnvelope(r, err)
|
|
}
|
|
if err := reloadInboxes(app); err != nil {
|
|
return r.SendErrorEnvelope(fasthttp.StatusInternalServerError, app.i18n.Ts("globals.messages.couldNotReload", "name", "{globals.terms.inbox}"), nil, envelope.GeneralError)
|
|
}
|
|
return r.SendEnvelope(true)
|
|
}
|
|
|
|
// validateInbox validates the inbox
|
|
func validateInbox(app *App, inbox imodels.Inbox) error {
|
|
// Validate from address.
|
|
if _, err := mail.ParseAddress(inbox.From); err != nil {
|
|
return envelope.NewError(envelope.InputError, app.i18n.Ts("globals.messages.invalidFromAddress"), nil)
|
|
}
|
|
if len(inbox.Config) == 0 {
|
|
return envelope.NewError(envelope.InputError, app.i18n.Ts("globals.messages.empty", "name", "config"), nil)
|
|
}
|
|
if inbox.Name == "" {
|
|
return envelope.NewError(envelope.InputError, app.i18n.Ts("globals.messages.empty", "name", "name"), nil)
|
|
}
|
|
if inbox.Channel == "" {
|
|
return envelope.NewError(envelope.InputError, app.i18n.Ts("globals.messages.empty", "name", "channel"), nil)
|
|
}
|
|
return nil
|
|
}
|