package service import ( "strings" "github.com/tinyauthapp/tinyauth/internal/model" "github.com/tinyauthapp/tinyauth/internal/utils/logger" "go.uber.org/dig" ) type LabelProvider interface { GetLabels(appDomain string) (*model.App, error) } type AccessControlsService struct { log *logger.Logger config *model.Config labelProvider LabelProvider } type AccessControlServiceInput struct { dig.In Log *logger.Logger Config *model.Config LabelProvider LabelProvider `optional:"true"` } func NewAccessControlsService(i AccessControlServiceInput) *AccessControlsService { return &AccessControlsService{ log: i.Log, config: i.Config, labelProvider: i.LabelProvider, } } func (service *AccessControlsService) lookupStaticACLs(domain string) *model.App { var nameMatch *model.App // First try to find a matching app by domain, then fallback to matching by app name (subdomain) for app, config := range service.config.Apps { if config.Config.Domain == domain { service.log.App.Debug().Str("name", app).Msg("Found matching container by domain") return &config } if strings.SplitN(domain, ".", 2)[0] == app { service.log.App.Debug().Str("name", app).Msg("Found matching container by app name") nameMatch = &config } } return nameMatch } func (service *AccessControlsService) GetAccessControls(domain string) (*model.App, error) { // First check in the static config app := service.lookupStaticACLs(domain) if app != nil { service.log.App.Debug().Msg("Using static ACLs for app") return app, nil } // If we have a label provider configured, try to get ACLs from it if service.labelProvider != nil { return service.labelProvider.GetLabels(domain) } // no labels return nil, nil }