happyDomain/internal/api/route/user.go
Pierre-Olivier Mercier f28cdefa8b Add user data export (GDPR/DSAR)
Refactors the admin backup usecase to share per-user collection logic
via backupOneUser(), then adds BackupUser() which filters system-wide
collections (checker configs, plans, evaluations, executions, discovery)
down to the requesting user by UserId.

Wires the backup usecase into the public API dependency graph and adds
a download button in the /me settings page near the delete-account
section.
2026-05-25 12:25:43 +08:00

51 lines
1.9 KiB
Go

// This file is part of the happyDomain (R) project.
// Copyright (c) 2020-2024 happyDomain
// Authors: Pierre-Olivier Mercier, et al.
//
// This program is offered under a commercial and under the AGPL license.
// For commercial licensing, contact us at <contact@happydomain.org>.
//
// For AGPL licensing:
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.
package route
import (
"github.com/gin-gonic/gin"
"git.happydns.org/happyDomain/internal/api/controller"
"git.happydns.org/happyDomain/internal/api/middleware"
"git.happydns.org/happyDomain/model"
)
func DeclareUsersRoutes(router *gin.RouterGroup, userUC happydns.UserUsecase, backupUC happydns.BackupUsecase, lc *controller.LoginController) *controller.UserController {
uc := controller.NewUserController(userUC, backupUC, lc)
apiUserRoutes := router.Group("/users/:uid")
apiUserRoutes.Use(middleware.UserHandler(userUC))
apiUserRoutes.GET("", uc.GetUser)
apiUserRoutes.GET("/avatar.png", uc.GetUserAvatar)
apiSameUserRoutes := router.Group("/users/:uid")
apiSameUserRoutes.Use(middleware.UserHandler(userUC))
apiSameUserRoutes.Use(middleware.SameUserHandler)
apiSameUserRoutes.DELETE("", uc.DeleteMyUser)
apiSameUserRoutes.GET("/export.json", uc.ExportUserData)
apiSameUserRoutes.GET("/settings", uc.GetUserSettings)
apiSameUserRoutes.POST("/settings", uc.ChangeUserSettings)
return uc
}