97 lines
2.6 KiB
Go
97 lines
2.6 KiB
Go
package manage
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
"github.com/TicketsBot/GoPanel/config"
|
|
"github.com/TicketsBot/GoPanel/database"
|
|
"github.com/TicketsBot/GoPanel/rpc/cache"
|
|
"github.com/TicketsBot/GoPanel/utils"
|
|
"github.com/TicketsBot/archiverclient"
|
|
"github.com/TicketsBot/common/permission"
|
|
"github.com/gin-gonic/contrib/sessions"
|
|
"github.com/gin-gonic/gin"
|
|
"strconv"
|
|
)
|
|
|
|
var Archiver archiverclient.ArchiverClient
|
|
|
|
func LogViewHandler(ctx *gin.Context) {
|
|
store := sessions.Default(ctx)
|
|
if store == nil {
|
|
return
|
|
}
|
|
|
|
if utils.IsLoggedIn(store) {
|
|
userId := utils.GetUserId(store)
|
|
|
|
// Verify the guild exists
|
|
guildId, err := strconv.ParseUint(ctx.Param("id"), 10, 64)
|
|
if err != nil {
|
|
ctx.Redirect(302, config.Conf.Server.BaseUrl) // TODO: 404 Page
|
|
return
|
|
}
|
|
|
|
// Get object for selected guild
|
|
guild, _ := cache.Instance.GetGuild(guildId, false)
|
|
|
|
// format ticket ID
|
|
ticketId, err := strconv.Atoi(ctx.Param("ticket")); if err != nil {
|
|
ctx.Redirect(302, fmt.Sprintf("/manage/%d/logs", guild.Id))
|
|
return
|
|
}
|
|
|
|
// get ticket object
|
|
ticket, err := database.Client.Tickets.Get(ticketId, guildId)
|
|
if err != nil {
|
|
// TODO: 500 error page
|
|
ctx.AbortWithStatusJSON(500, gin.H{
|
|
"success": false,
|
|
"error": err.Error(),
|
|
})
|
|
return
|
|
}
|
|
|
|
// Verify this is a valid ticket and it is closed
|
|
if ticket.UserId == 0 || ticket.Open {
|
|
ctx.Redirect(302, fmt.Sprintf("/manage/%d/logs", guild.Id))
|
|
return
|
|
}
|
|
|
|
// Verify the user has permissions to be here
|
|
permLevel, err := utils.GetPermissionLevel(guildId, userId)
|
|
if err != nil {
|
|
ctx.JSON(500, utils.ErrorToResponse(err))
|
|
return
|
|
}
|
|
|
|
if permLevel < permission.Support && ticket.UserId != userId {
|
|
ctx.Redirect(302, config.Conf.Server.BaseUrl) // TODO: 403 Page
|
|
return
|
|
}
|
|
|
|
// retrieve ticket messages from bucket
|
|
messages, err := Archiver.Get(guildId, ticketId)
|
|
if err != nil {
|
|
if errors.Is(err, archiverclient.ErrExpired) {
|
|
ctx.String(200, fmt.Sprintf("Failed to retrieve archive - please contact the developers (ErrExpired): %s", err.Error())) // TODO: Actual error page
|
|
return
|
|
}
|
|
|
|
ctx.String(500, fmt.Sprintf("Failed to retrieve archive - please contact the developers: %s", err.Error()))
|
|
return
|
|
}
|
|
|
|
// format to html
|
|
html, err := Archiver.Encode(messages, fmt.Sprintf("ticket-%d", ticketId))
|
|
if err != nil {
|
|
ctx.String(500, fmt.Sprintf("Failed to retrieve archive - please contact the developers: %s", err.Error()))
|
|
return
|
|
}
|
|
|
|
ctx.Data(200, gin.MIMEHTML, html)
|
|
} else {
|
|
ctx.Redirect(302, fmt.Sprintf("/login?noguilds&state=viewlog.%s.%s", ctx.Param("id"), ctx.Param("ticket")))
|
|
}
|
|
}
|