mirror of
https://github.com/hrfee/jfa-go.git
synced 2026-03-18 21:50:33 +01:00
only supports queries of fields actually in Activity. The web UI only directly queries two of these, ID and Time (mistakenly referneced as date in the web ui previously). Later commits will come up with creative ways of dealing with all the other query types.
190 lines
4.7 KiB
Go
190 lines
4.7 KiB
Go
package main
|
|
|
|
import (
|
|
"github.com/gin-gonic/gin"
|
|
lm "github.com/hrfee/jfa-go/logmessages"
|
|
"github.com/timshannon/badgerhold/v4"
|
|
)
|
|
|
|
func activityTypeToString(v ActivityType) string {
|
|
switch v {
|
|
case ActivityCreation:
|
|
return "creation"
|
|
case ActivityDeletion:
|
|
return "deletion"
|
|
case ActivityDisabled:
|
|
return "disabled"
|
|
case ActivityEnabled:
|
|
return "enabled"
|
|
case ActivityContactLinked:
|
|
return "contactLinked"
|
|
case ActivityContactUnlinked:
|
|
return "contactUnlinked"
|
|
case ActivityChangePassword:
|
|
return "changePassword"
|
|
case ActivityResetPassword:
|
|
return "resetPassword"
|
|
case ActivityCreateInvite:
|
|
return "createInvite"
|
|
case ActivityDeleteInvite:
|
|
return "deleteInvite"
|
|
}
|
|
return "unknown"
|
|
}
|
|
|
|
func stringToActivityType(v string) ActivityType {
|
|
switch v {
|
|
case "creation":
|
|
return ActivityCreation
|
|
case "deletion":
|
|
return ActivityDeletion
|
|
case "disabled":
|
|
return ActivityDisabled
|
|
case "enabled":
|
|
return ActivityEnabled
|
|
case "contactLinked":
|
|
return ActivityContactLinked
|
|
case "contactUnlinked":
|
|
return ActivityContactUnlinked
|
|
case "changePassword":
|
|
return ActivityChangePassword
|
|
case "resetPassword":
|
|
return ActivityResetPassword
|
|
case "createInvite":
|
|
return ActivityCreateInvite
|
|
case "deleteInvite":
|
|
return ActivityDeleteInvite
|
|
}
|
|
return ActivityUnknown
|
|
}
|
|
|
|
func stringToActivitySource(v string) ActivitySource {
|
|
switch v {
|
|
case "user":
|
|
return ActivityUser
|
|
case "admin":
|
|
return ActivityAdmin
|
|
case "anon":
|
|
return ActivityAnon
|
|
case "daemon":
|
|
return ActivityDaemon
|
|
}
|
|
return ActivityAnon
|
|
}
|
|
|
|
func activitySourceToString(v ActivitySource) string {
|
|
switch v {
|
|
case ActivityUser:
|
|
return "user"
|
|
case ActivityAdmin:
|
|
return "admin"
|
|
case ActivityAnon:
|
|
return "anon"
|
|
case ActivityDaemon:
|
|
return "daemon"
|
|
}
|
|
return "anon"
|
|
}
|
|
|
|
// @Summary Get the requested set of activities, Paginated, filtered and sorted. Is a POST because of some issues I was having, ideally should be a GET.
|
|
// @Produce json
|
|
// @Param ServerSearchReqDTO body ServerSearchReqDTO true "search parameters"
|
|
// @Success 200 {object} GetActivitiesRespDTO
|
|
// @Router /activity [post]
|
|
// @Security Bearer
|
|
// @tags Activity
|
|
func (app *appContext) GetActivities(gc *gin.Context) {
|
|
req := ServerSearchReqDTO{}
|
|
gc.BindJSON(&req)
|
|
if req.SortByField == "" {
|
|
req.SortByField = USER_DEFAULT_SORT_FIELD
|
|
} else {
|
|
req.SortByField = activityDTONameToField(req.SortByField)
|
|
}
|
|
|
|
var query *badgerhold.Query
|
|
if len(req.SearchTerms) != 0 {
|
|
query = ActivityMatchesSearchAsDBBaseQuery(req.SearchTerms)
|
|
} else {
|
|
query = &badgerhold.Query{}
|
|
}
|
|
|
|
for _, q := range req.Queries {
|
|
query = q.AsDBQuery(query)
|
|
}
|
|
|
|
query = query.SortBy(req.SortByField)
|
|
if !req.Ascending {
|
|
query = query.Reverse()
|
|
}
|
|
|
|
query = query.Skip(req.Page * req.Limit).Limit(req.Limit)
|
|
|
|
var results []Activity
|
|
err := app.storage.db.Find(&results, query)
|
|
if err != nil {
|
|
app.err.Printf(lm.FailedDBReadActivities, err)
|
|
}
|
|
|
|
resp := GetActivitiesRespDTO{
|
|
Activities: make([]ActivityDTO, len(results)),
|
|
}
|
|
resp.LastPage = len(results) != req.Limit
|
|
for i, act := range results {
|
|
resp.Activities[i] = ActivityDTO{
|
|
ID: act.ID,
|
|
Type: activityTypeToString(act.Type),
|
|
UserID: act.UserID,
|
|
SourceType: activitySourceToString(act.SourceType),
|
|
Source: act.Source,
|
|
InviteCode: act.InviteCode,
|
|
Value: act.Value,
|
|
Time: act.Time.Unix(),
|
|
IP: act.IP,
|
|
}
|
|
if act.Type == ActivityDeletion || act.Type == ActivityCreation {
|
|
resp.Activities[i].Username = act.Value
|
|
resp.Activities[i].Value = ""
|
|
} else if user, err := app.jf.UserByID(act.UserID, false); err == nil {
|
|
resp.Activities[i].Username = user.Name
|
|
}
|
|
|
|
if (act.SourceType == ActivityUser || act.SourceType == ActivityAdmin) && act.Source != "" {
|
|
user, err := app.jf.UserByID(act.Source, false)
|
|
if err == nil {
|
|
resp.Activities[i].SourceUsername = user.Name
|
|
}
|
|
}
|
|
}
|
|
|
|
gc.JSON(200, resp)
|
|
}
|
|
|
|
// @Summary Delete the activity with the given ID. No-op if non-existent, always succeeds.
|
|
// @Produce json
|
|
// @Param id path string true "ID of activity to delete"
|
|
// @Success 200 {object} boolResponse
|
|
// @Router /activity/{id} [delete]
|
|
// @Security Bearer
|
|
// @tags Activity
|
|
func (app *appContext) DeleteActivity(gc *gin.Context) {
|
|
app.storage.DeleteActivityKey(gc.Param("id"))
|
|
respondBool(200, true, gc)
|
|
}
|
|
|
|
// @Summary Returns the total number of activities stored in the database.
|
|
// @Produce json
|
|
// @Success 200 {object} PageCountDTO
|
|
// @Router /activity/count [get]
|
|
// @Security Bearer
|
|
// @tags Activity
|
|
func (app *appContext) GetActivityCount(gc *gin.Context) {
|
|
resp := PageCountDTO{}
|
|
var err error
|
|
resp.Count, err = app.storage.db.Count(&Activity{}, &badgerhold.Query{})
|
|
if err != nil {
|
|
resp.Count = 0
|
|
}
|
|
gc.JSON(200, resp)
|
|
}
|