2022-12-22 19:51:29 +01:00
|
|
|
package controller
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/go-openapi/runtime/middleware"
|
2023-01-13 21:01:34 +01:00
|
|
|
"github.com/openziti/zrok/rest_model_zrok"
|
|
|
|
"github.com/openziti/zrok/rest_server_zrok/operations/metadata"
|
2022-12-22 19:51:29 +01:00
|
|
|
"github.com/sirupsen/logrus"
|
|
|
|
)
|
|
|
|
|
|
|
|
type environmentDetailHandler struct{}
|
|
|
|
|
|
|
|
func newEnvironmentDetailHandler() *environmentDetailHandler {
|
|
|
|
return &environmentDetailHandler{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *environmentDetailHandler) Handle(params metadata.GetEnvironmentDetailParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
tx, err := str.Begin()
|
|
|
|
if err != nil {
|
|
|
|
logrus.Errorf("error starting transaction: %v", err)
|
|
|
|
return metadata.NewGetEnvironmentDetailInternalServerError()
|
|
|
|
}
|
|
|
|
defer func() { _ = tx.Rollback() }()
|
2022-12-22 20:56:19 +01:00
|
|
|
senv, err := str.FindEnvironmentForAccount(params.EnvZID, int(principal.ID), tx)
|
2022-12-22 19:51:29 +01:00
|
|
|
if err != nil {
|
2022-12-22 20:56:19 +01:00
|
|
|
logrus.Errorf("environment '%v' not found for account '%v': %v", params.EnvZID, principal.Email, err)
|
2022-12-22 19:51:29 +01:00
|
|
|
return metadata.NewGetEnvironmentDetailNotFound()
|
|
|
|
}
|
2023-01-04 19:43:37 +01:00
|
|
|
es := &rest_model_zrok.EnvironmentShares{
|
2022-12-22 19:51:29 +01:00
|
|
|
Environment: &rest_model_zrok.Environment{
|
|
|
|
Address: senv.Address,
|
|
|
|
CreatedAt: senv.CreatedAt.UnixMilli(),
|
|
|
|
Description: senv.Description,
|
|
|
|
Host: senv.Host,
|
|
|
|
UpdatedAt: senv.UpdatedAt.UnixMilli(),
|
|
|
|
ZID: senv.ZId,
|
|
|
|
},
|
|
|
|
}
|
2023-01-04 19:13:50 +01:00
|
|
|
shrs, err := str.FindSharesForEnvironment(senv.Id, tx)
|
2022-12-22 19:51:29 +01:00
|
|
|
if err != nil {
|
2023-01-04 20:21:23 +01:00
|
|
|
logrus.Errorf("error finding shares for environment '%v': %v", senv.ZId, err)
|
2022-12-22 19:51:29 +01:00
|
|
|
return metadata.NewGetEnvironmentDetailInternalServerError()
|
|
|
|
}
|
|
|
|
var sparkData map[string][]int64
|
|
|
|
if cfg.Influx != nil {
|
2023-01-04 20:21:23 +01:00
|
|
|
sparkData, err = sparkDataForShares(shrs)
|
2022-12-22 19:51:29 +01:00
|
|
|
if err != nil {
|
2023-01-04 20:21:23 +01:00
|
|
|
logrus.Errorf("error querying spark data for shares: %v", err)
|
2022-12-22 19:51:29 +01:00
|
|
|
}
|
|
|
|
}
|
2023-01-04 19:13:50 +01:00
|
|
|
for _, shr := range shrs {
|
2022-12-22 19:51:29 +01:00
|
|
|
feEndpoint := ""
|
2023-01-04 19:13:50 +01:00
|
|
|
if shr.FrontendEndpoint != nil {
|
|
|
|
feEndpoint = *shr.FrontendEndpoint
|
2022-12-22 19:51:29 +01:00
|
|
|
}
|
|
|
|
feSelection := ""
|
2023-01-04 19:13:50 +01:00
|
|
|
if shr.FrontendSelection != nil {
|
|
|
|
feSelection = *shr.FrontendSelection
|
2022-12-22 19:51:29 +01:00
|
|
|
}
|
|
|
|
beProxyEndpoint := ""
|
2023-01-04 19:13:50 +01:00
|
|
|
if shr.BackendProxyEndpoint != nil {
|
|
|
|
beProxyEndpoint = *shr.BackendProxyEndpoint
|
2022-12-22 19:51:29 +01:00
|
|
|
}
|
2023-01-04 19:43:37 +01:00
|
|
|
es.Shares = append(es.Shares, &rest_model_zrok.Share{
|
2023-01-04 19:13:50 +01:00
|
|
|
Token: shr.Token,
|
|
|
|
ZID: shr.ZId,
|
|
|
|
ShareMode: shr.ShareMode,
|
|
|
|
BackendMode: shr.BackendMode,
|
2022-12-22 19:51:29 +01:00
|
|
|
FrontendSelection: feSelection,
|
|
|
|
FrontendEndpoint: feEndpoint,
|
|
|
|
BackendProxyEndpoint: beProxyEndpoint,
|
2023-01-04 19:13:50 +01:00
|
|
|
Reserved: shr.Reserved,
|
|
|
|
Metrics: sparkData[shr.Token],
|
|
|
|
CreatedAt: shr.CreatedAt.UnixMilli(),
|
|
|
|
UpdatedAt: shr.UpdatedAt.UnixMilli(),
|
2022-12-22 19:51:29 +01:00
|
|
|
})
|
|
|
|
}
|
|
|
|
return metadata.NewGetEnvironmentDetailOK().WithPayload(es)
|
|
|
|
}
|