zrok/controller/overview.go

89 lines
2.8 KiB
Go
Raw Normal View History

2022-08-03 20:58:11 +02:00
package controller
import (
"github.com/go-openapi/runtime/middleware"
"github.com/openziti/zrok/controller/store"
"github.com/openziti/zrok/rest_model_zrok"
"github.com/openziti/zrok/rest_server_zrok/operations/metadata"
2022-08-03 21:05:28 +02:00
"github.com/sirupsen/logrus"
2022-08-03 20:58:11 +02:00
)
func overviewHandler(_ metadata.OverviewParams, principal *rest_model_zrok.Principal) middleware.Responder {
2022-08-03 21:05:28 +02:00
tx, err := str.Begin()
if err != nil {
logrus.Errorf("error starting transaction: %v", err)
2022-09-26 22:35:06 +02:00
return metadata.NewOverviewInternalServerError()
2022-08-03 21:05:28 +02:00
}
defer func() { _ = tx.Rollback() }()
envs, err := str.FindEnvironmentsForAccount(int(principal.ID), tx)
if err != nil {
2022-09-09 16:20:05 +02:00
logrus.Errorf("error finding environments for '%v': %v", principal.Email, err)
2022-09-26 22:35:06 +02:00
return metadata.NewOverviewInternalServerError()
2022-08-03 21:05:28 +02:00
}
var out rest_model_zrok.EnvironmentSharesList
2022-08-03 21:05:28 +02:00
for _, env := range envs {
shrs, err := str.FindSharesForEnvironment(env.Id, tx)
2022-08-03 21:05:28 +02:00
if err != nil {
2023-01-04 20:21:23 +01:00
logrus.Errorf("error finding shares for environment '%v': %v", env.ZId, err)
2022-09-26 22:35:06 +02:00
return metadata.NewOverviewInternalServerError()
2022-08-03 21:05:28 +02:00
}
es := &rest_model_zrok.EnvironmentShares{
Environment: &rest_model_zrok.Environment{
Address: env.Address,
CreatedAt: env.CreatedAt.UnixMilli(),
Description: env.Description,
Host: env.Host,
UpdatedAt: env.UpdatedAt.UnixMilli(),
ZID: env.ZId,
},
}
var shrIds []int
for i := range shrs {
shrIds = append(shrIds, shrs[i].Id)
}
shrsLimited, err := str.FindSelectedLatestShareLimitjournal(shrIds, tx)
if err != nil {
logrus.Errorf("error finding limited shares for environment '%v': %v", env.ZId, err)
return metadata.NewOverviewInternalServerError()
}
shrsLimitedMap := make(map[int]store.LimitJournalAction)
for i := range shrsLimited {
shrsLimitedMap[shrsLimited[i].ShareId] = shrsLimited[i].Action
}
for _, shr := range shrs {
feEndpoint := ""
if shr.FrontendEndpoint != nil {
feEndpoint = *shr.FrontendEndpoint
}
feSelection := ""
if shr.FrontendSelection != nil {
feSelection = *shr.FrontendSelection
}
beProxyEndpoint := ""
if shr.BackendProxyEndpoint != nil {
beProxyEndpoint = *shr.BackendProxyEndpoint
}
oshr := &rest_model_zrok.Share{
Token: shr.Token,
ZID: shr.ZId,
ShareMode: shr.ShareMode,
BackendMode: shr.BackendMode,
FrontendSelection: feSelection,
FrontendEndpoint: feEndpoint,
BackendProxyEndpoint: beProxyEndpoint,
Reserved: shr.Reserved,
CreatedAt: shr.CreatedAt.UnixMilli(),
UpdatedAt: shr.UpdatedAt.UnixMilli(),
}
if action, found := shrsLimitedMap[shr.Id]; found {
if action == store.LimitAction {
oshr.Limited = true
}
}
es.Shares = append(es.Shares, oshr)
}
out = append(out, es)
}
return metadata.NewOverviewOK().WithPayload(out)
}