mirror of
https://github.com/openziti/zrok.git
synced 2025-01-24 14:59:08 +01:00
add trx to action interfaces; implement limit and relax for share (#276)
This commit is contained in:
parent
44cbb8491c
commit
558606fad3
@ -1,6 +1,7 @@
|
|||||||
package limits
|
package limits
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/jmoiron/sqlx"
|
||||||
"github.com/openziti/edge/rest_management_api_client"
|
"github.com/openziti/edge/rest_management_api_client"
|
||||||
"github.com/openziti/zrok/controller/store"
|
"github.com/openziti/zrok/controller/store"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
@ -15,7 +16,7 @@ func newAccountLimitAction(str *store.Store, edge *rest_management_api_client.Zi
|
|||||||
return &accountLimitAction{str, edge}
|
return &accountLimitAction{str, edge}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *accountLimitAction) HandleAccount(acct *store.Account, rxBytes, txBytes int64, limit *BandwidthPerPeriod) error {
|
func (a *accountLimitAction) HandleAccount(acct *store.Account, rxBytes, txBytes int64, limit *BandwidthPerPeriod, trx *sqlx.Tx) error {
|
||||||
logrus.Infof("limiting '%v'", acct.Email)
|
logrus.Infof("limiting '%v'", acct.Email)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package limits
|
package limits
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/jmoiron/sqlx"
|
||||||
"github.com/openziti/edge/rest_management_api_client"
|
"github.com/openziti/edge/rest_management_api_client"
|
||||||
"github.com/openziti/zrok/controller/store"
|
"github.com/openziti/zrok/controller/store"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
@ -15,7 +16,7 @@ func newAccountRelaxAction(str *store.Store, edge *rest_management_api_client.Zi
|
|||||||
return &accountRelaxAction{str, edge}
|
return &accountRelaxAction{str, edge}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *accountRelaxAction) HandleAccount(acct *store.Account, rxBytes, txBytes int64, limit *BandwidthPerPeriod) error {
|
func (a *accountRelaxAction) HandleAccount(acct *store.Account, rxBytes, txBytes int64, limit *BandwidthPerPeriod, trx *sqlx.Tx) error {
|
||||||
logrus.Infof("relaxing '%v'", acct.Email)
|
logrus.Infof("relaxing '%v'", acct.Email)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package limits
|
package limits
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/jmoiron/sqlx"
|
||||||
"github.com/openziti/edge/rest_management_api_client"
|
"github.com/openziti/edge/rest_management_api_client"
|
||||||
"github.com/openziti/zrok/controller/store"
|
"github.com/openziti/zrok/controller/store"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
@ -15,7 +16,7 @@ func newAccountWarningAction(str *store.Store, edge *rest_management_api_client.
|
|||||||
return &accountWarningAction{str, edge}
|
return &accountWarningAction{str, edge}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *accountWarningAction) HandleAccount(acct *store.Account, rxBytes, txBytes int64, limit *BandwidthPerPeriod) error {
|
func (a *accountWarningAction) HandleAccount(acct *store.Account, rxBytes, txBytes int64, limit *BandwidthPerPeriod, trx *sqlx.Tx) error {
|
||||||
logrus.Infof("warning '%v'", acct.Email)
|
logrus.Infof("warning '%v'", acct.Email)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -165,7 +165,7 @@ func (a *Agent) enforce(u *metrics.Usage) error {
|
|||||||
}
|
}
|
||||||
// run account limit actions
|
// run account limit actions
|
||||||
for _, action := range a.acctLimitActions {
|
for _, action := range a.acctLimitActions {
|
||||||
if err := action.HandleAccount(acct, rxBytes, txBytes, a.cfg.Bandwidth.PerAccount); err != nil {
|
if err := action.HandleAccount(acct, rxBytes, txBytes, a.cfg.Bandwidth.PerAccount, trx); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -202,7 +202,7 @@ func (a *Agent) enforce(u *metrics.Usage) error {
|
|||||||
}
|
}
|
||||||
// run account warning actions
|
// run account warning actions
|
||||||
for _, action := range a.acctWarningActions {
|
for _, action := range a.acctWarningActions {
|
||||||
if err := action.HandleAccount(acct, rxBytes, txBytes, a.cfg.Bandwidth.PerAccount); err != nil {
|
if err := action.HandleAccount(acct, rxBytes, txBytes, a.cfg.Bandwidth.PerAccount, trx); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -241,7 +241,7 @@ func (a *Agent) enforce(u *metrics.Usage) error {
|
|||||||
}
|
}
|
||||||
// run environment limit actions
|
// run environment limit actions
|
||||||
for _, action := range a.envLimitActions {
|
for _, action := range a.envLimitActions {
|
||||||
if err := action.HandleEnvironment(env, rxBytes, txBytes, a.cfg.Bandwidth.PerEnvironment); err != nil {
|
if err := action.HandleEnvironment(env, rxBytes, txBytes, a.cfg.Bandwidth.PerEnvironment, trx); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -278,7 +278,7 @@ func (a *Agent) enforce(u *metrics.Usage) error {
|
|||||||
}
|
}
|
||||||
// run environment warning actions
|
// run environment warning actions
|
||||||
for _, action := range a.envWarningActions {
|
for _, action := range a.envWarningActions {
|
||||||
if err := action.HandleEnvironment(env, rxBytes, txBytes, a.cfg.Bandwidth.PerEnvironment); err != nil {
|
if err := action.HandleEnvironment(env, rxBytes, txBytes, a.cfg.Bandwidth.PerEnvironment, trx); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -318,7 +318,7 @@ func (a *Agent) enforce(u *metrics.Usage) error {
|
|||||||
}
|
}
|
||||||
// run share limit actions
|
// run share limit actions
|
||||||
for _, action := range a.shrLimitActions {
|
for _, action := range a.shrLimitActions {
|
||||||
if err := action.HandleShare(shr, rxBytes, txBytes, a.cfg.Bandwidth.PerShare); err != nil {
|
if err := action.HandleShare(shr, rxBytes, txBytes, a.cfg.Bandwidth.PerShare, trx); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -356,7 +356,7 @@ func (a *Agent) enforce(u *metrics.Usage) error {
|
|||||||
}
|
}
|
||||||
// run share warning actions
|
// run share warning actions
|
||||||
for _, action := range a.shrWarningActions {
|
for _, action := range a.shrWarningActions {
|
||||||
if err := action.HandleShare(shr, rxBytes, txBytes, a.cfg.Bandwidth.PerShare); err != nil {
|
if err := action.HandleShare(shr, rxBytes, txBytes, a.cfg.Bandwidth.PerShare, trx); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -401,7 +401,7 @@ func (a *Agent) relax() error {
|
|||||||
if !enforce && !warning {
|
if !enforce && !warning {
|
||||||
// run relax actions for share
|
// run relax actions for share
|
||||||
for _, action := range a.shrRelaxActions {
|
for _, action := range a.shrRelaxActions {
|
||||||
if err := action.HandleShare(shr, rxBytes, txBytes, a.cfg.Bandwidth.PerShare); err != nil {
|
if err := action.HandleShare(shr, rxBytes, txBytes, a.cfg.Bandwidth.PerShare, trx); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -433,7 +433,7 @@ func (a *Agent) relax() error {
|
|||||||
if !enforce && !warning {
|
if !enforce && !warning {
|
||||||
// run relax actions for environment
|
// run relax actions for environment
|
||||||
for _, action := range a.envRelaxActions {
|
for _, action := range a.envRelaxActions {
|
||||||
if err := action.HandleEnvironment(env, rxBytes, txBytes, a.cfg.Bandwidth.PerEnvironment); err != nil {
|
if err := action.HandleEnvironment(env, rxBytes, txBytes, a.cfg.Bandwidth.PerEnvironment, trx); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -465,7 +465,7 @@ func (a *Agent) relax() error {
|
|||||||
if !enforce && !warning {
|
if !enforce && !warning {
|
||||||
// run relax actions for account
|
// run relax actions for account
|
||||||
for _, action := range a.acctRelaxActions {
|
for _, action := range a.acctRelaxActions {
|
||||||
if err := action.HandleAccount(acct, rxBytes, txBytes, a.cfg.Bandwidth.PerAccount); err != nil {
|
if err := action.HandleAccount(acct, rxBytes, txBytes, a.cfg.Bandwidth.PerAccount, trx); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package limits
|
package limits
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/jmoiron/sqlx"
|
||||||
"github.com/openziti/edge/rest_management_api_client"
|
"github.com/openziti/edge/rest_management_api_client"
|
||||||
"github.com/openziti/zrok/controller/store"
|
"github.com/openziti/zrok/controller/store"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
@ -15,7 +16,7 @@ func newEnvironmentLimitAction(str *store.Store, edge *rest_management_api_clien
|
|||||||
return &environmentLimitAction{str, edge}
|
return &environmentLimitAction{str, edge}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *environmentLimitAction) HandleEnvironment(e *store.Environment, rxBytes, txBytes int64, limit *BandwidthPerPeriod) error {
|
func (a *environmentLimitAction) HandleEnvironment(e *store.Environment, rxBytes, txBytes int64, limit *BandwidthPerPeriod, trx *sqlx.Tx) error {
|
||||||
logrus.Infof("limiting '%v'", e.ZId)
|
logrus.Infof("limiting '%v'", e.ZId)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package limits
|
package limits
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/jmoiron/sqlx"
|
||||||
"github.com/openziti/edge/rest_management_api_client"
|
"github.com/openziti/edge/rest_management_api_client"
|
||||||
"github.com/openziti/zrok/controller/store"
|
"github.com/openziti/zrok/controller/store"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
@ -15,7 +16,7 @@ func newEnvironmentRelaxAction(str *store.Store, edge *rest_management_api_clien
|
|||||||
return &environmentRelaxAction{str, edge}
|
return &environmentRelaxAction{str, edge}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *environmentRelaxAction) HandleEnvironment(e *store.Environment, rxBytes, txBytes int64, limit *BandwidthPerPeriod) error {
|
func (a *environmentRelaxAction) HandleEnvironment(e *store.Environment, rxBytes, txBytes int64, limit *BandwidthPerPeriod, trx *sqlx.Tx) error {
|
||||||
logrus.Infof("relaxing '%v'", e.ZId)
|
logrus.Infof("relaxing '%v'", e.ZId)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package limits
|
package limits
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/jmoiron/sqlx"
|
||||||
"github.com/openziti/edge/rest_management_api_client"
|
"github.com/openziti/edge/rest_management_api_client"
|
||||||
"github.com/openziti/zrok/controller/store"
|
"github.com/openziti/zrok/controller/store"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
@ -15,7 +16,7 @@ func newEnvironmentWarningAction(str *store.Store, edge *rest_management_api_cli
|
|||||||
return &environmentWarningAction{str, edge}
|
return &environmentWarningAction{str, edge}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *environmentWarningAction) HandleEnvironment(e *store.Environment, rxBytes, txBytes int64, limit *BandwidthPerPeriod) error {
|
func (a *environmentWarningAction) HandleEnvironment(e *store.Environment, rxBytes, txBytes int64, limit *BandwidthPerPeriod, trx *sqlx.Tx) error {
|
||||||
logrus.Infof("warning '%v'", e.ZId)
|
logrus.Infof("warning '%v'", e.ZId)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -1,15 +1,18 @@
|
|||||||
package limits
|
package limits
|
||||||
|
|
||||||
import "github.com/openziti/zrok/controller/store"
|
import (
|
||||||
|
"github.com/jmoiron/sqlx"
|
||||||
|
"github.com/openziti/zrok/controller/store"
|
||||||
|
)
|
||||||
|
|
||||||
type AccountAction interface {
|
type AccountAction interface {
|
||||||
HandleAccount(a *store.Account, rxBytes, txBytes int64, limit *BandwidthPerPeriod) error
|
HandleAccount(a *store.Account, rxBytes, txBytes int64, limit *BandwidthPerPeriod, trx *sqlx.Tx) error
|
||||||
}
|
}
|
||||||
|
|
||||||
type EnvironmentAction interface {
|
type EnvironmentAction interface {
|
||||||
HandleEnvironment(e *store.Environment, rxBytes, txBytes int64, limit *BandwidthPerPeriod) error
|
HandleEnvironment(e *store.Environment, rxBytes, txBytes int64, limit *BandwidthPerPeriod, trx *sqlx.Tx) error
|
||||||
}
|
}
|
||||||
|
|
||||||
type ShareAction interface {
|
type ShareAction interface {
|
||||||
HandleShare(s *store.Share, rxBytes, txBytes int64, limit *BandwidthPerPeriod) error
|
HandleShare(s *store.Share, rxBytes, txBytes int64, limit *BandwidthPerPeriod, trx *sqlx.Tx) error
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,10 @@
|
|||||||
package limits
|
package limits
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/jmoiron/sqlx"
|
||||||
"github.com/openziti/edge/rest_management_api_client"
|
"github.com/openziti/edge/rest_management_api_client"
|
||||||
"github.com/openziti/zrok/controller/store"
|
"github.com/openziti/zrok/controller/store"
|
||||||
|
"github.com/openziti/zrok/controller/zrokEdgeSdk"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -15,7 +17,18 @@ func newShareLimitAction(str *store.Store, edge *rest_management_api_client.Ziti
|
|||||||
return &shareLimitAction{str, edge}
|
return &shareLimitAction{str, edge}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *shareLimitAction) HandleShare(s *store.Share, rxBytes, txBytes int64, limit *BandwidthPerPeriod) error {
|
func (a *shareLimitAction) HandleShare(s *store.Share, _, _ int64, _ *BandwidthPerPeriod, trx *sqlx.Tx) error {
|
||||||
logrus.Infof("limiting '%v'", s.Token)
|
logrus.Infof("limiting '%v'", s.Token)
|
||||||
|
|
||||||
|
env, err := a.str.GetEnvironment(s.EnvironmentId, trx)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := zrokEdgeSdk.DeleteServicePolicyDial(env.ZId, s.Token, a.edge); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
logrus.Infof("removed service dial policy for '%v'", s.Token)
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,11 @@
|
|||||||
package limits
|
package limits
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/jmoiron/sqlx"
|
||||||
"github.com/openziti/edge/rest_management_api_client"
|
"github.com/openziti/edge/rest_management_api_client"
|
||||||
"github.com/openziti/zrok/controller/store"
|
"github.com/openziti/zrok/controller/store"
|
||||||
|
"github.com/openziti/zrok/controller/zrokEdgeSdk"
|
||||||
|
"github.com/pkg/errors"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -15,7 +18,28 @@ func newShareRelaxAction(str *store.Store, edge *rest_management_api_client.Ziti
|
|||||||
return &shareRelaxAction{str, edge}
|
return &shareRelaxAction{str, edge}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *shareRelaxAction) HandleShare(s *store.Share, rxBytes, txBytes int64, limit *BandwidthPerPeriod) error {
|
func (a *shareRelaxAction) HandleShare(s *store.Share, rxBytes, txBytes int64, limit *BandwidthPerPeriod, trx *sqlx.Tx) error {
|
||||||
logrus.Infof("relaxing '%v'", s.Token)
|
logrus.Infof("relaxing '%v'", s.Token)
|
||||||
|
|
||||||
|
if s.ShareMode == "public" {
|
||||||
|
env, err := a.str.GetEnvironment(s.EnvironmentId, trx)
|
||||||
|
if err != nil {
|
||||||
|
return errors.Wrap(err, "error finding environment")
|
||||||
|
}
|
||||||
|
|
||||||
|
fe, err := a.str.FindFrontendPubliclyNamed(*s.FrontendSelection, trx)
|
||||||
|
if err != nil {
|
||||||
|
return errors.Wrapf(err, "error finding frontend name '%v' for '%v'", *s.FrontendSelection, s.Token)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := zrokEdgeSdk.CreateServicePolicyDial(env.ZId+"-"+s.ZId+"-dial", s.ZId, []string{fe.ZId}, zrokEdgeSdk.ZrokShareTags(s.Token).SubTags, a.edge); err != nil {
|
||||||
|
return errors.Wrapf(err, "error creating dial service policy for '%v'", s.Token)
|
||||||
|
}
|
||||||
|
logrus.Infof("added dial service policy for '%v'", s.Token)
|
||||||
|
|
||||||
|
} else if s.ShareMode == "private" {
|
||||||
|
return errors.New("share relax for private share not implemented")
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package limits
|
package limits
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/jmoiron/sqlx"
|
||||||
"github.com/openziti/edge/rest_management_api_client"
|
"github.com/openziti/edge/rest_management_api_client"
|
||||||
"github.com/openziti/zrok/controller/store"
|
"github.com/openziti/zrok/controller/store"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
@ -15,7 +16,7 @@ func newShareWarningAction(str *store.Store, edge *rest_management_api_client.Zi
|
|||||||
return &shareWarningAction{str, edge}
|
return &shareWarningAction{str, edge}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *shareWarningAction) HandleShare(s *store.Share, rxBytes, txBytes int64, limit *BandwidthPerPeriod) error {
|
func (a *shareWarningAction) HandleShare(s *store.Share, rxBytes, txBytes int64, limit *BandwidthPerPeriod, trx *sqlx.Tx) error {
|
||||||
logrus.Infof("warning '%v'", s.Token)
|
logrus.Infof("warning '%v'", s.Token)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -115,6 +115,9 @@ func (h *shareHandler) Handle(params share.ShareParams, principal *rest_model_zr
|
|||||||
BackendProxyEndpoint: ¶ms.Body.BackendProxyEndpoint,
|
BackendProxyEndpoint: ¶ms.Body.BackendProxyEndpoint,
|
||||||
Reserved: reserved,
|
Reserved: reserved,
|
||||||
}
|
}
|
||||||
|
if len(params.Body.FrontendSelection) > 0 {
|
||||||
|
sshr.FrontendSelection = ¶ms.Body.FrontendSelection[0]
|
||||||
|
}
|
||||||
if len(frontendEndpoints) > 0 {
|
if len(frontendEndpoints) > 0 {
|
||||||
sshr.FrontendEndpoint = &frontendEndpoints[0]
|
sshr.FrontendEndpoint = &frontendEndpoints[0]
|
||||||
} else if sshr.ShareMode == "private" {
|
} else if sshr.ShareMode == "private" {
|
||||||
|
Loading…
Reference in New Issue
Block a user