mirror of
https://github.com/zitadel/zitadel.git
synced 2025-03-01 11:37:23 +00:00
36 lines
1.3 KiB
Go
36 lines
1.3 KiB
Go
![]() |
package query
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"fmt"
|
||
|
|
||
|
sq "github.com/Masterminds/squirrel"
|
||
|
"github.com/zitadel/logging"
|
||
|
|
||
|
"github.com/zitadel/zitadel/internal/api/authz"
|
||
|
)
|
||
|
|
||
|
const (
|
||
|
// eventstore.permitted_orgs(instanceid text, userid text, perm text)
|
||
|
wherePermittedOrgsClause = "%s = ANY(eventstore.permitted_orgs(?, ?, ?))"
|
||
|
)
|
||
|
|
||
|
// wherePermittedOrgs sets a `WHERE` clause to the query that filters the orgs
|
||
|
// for which the authenticated user has the requested permission for.
|
||
|
// The user ID is taken from the context.
|
||
|
//
|
||
|
// The `orgIDColumn` specifies the table column to which this filter must be applied,
|
||
|
// and is typically the `resource_owner` column in ZITADEL.
|
||
|
// We use full identifiers in the query builder so this function should be
|
||
|
// called with something like `UserResourceOwnerCol.identifier()` for example.
|
||
|
func wherePermittedOrgs(ctx context.Context, query sq.SelectBuilder, orgIDColumn, permission string) sq.SelectBuilder {
|
||
|
userID := authz.GetCtxData(ctx).UserID
|
||
|
logging.WithFields("permission_check_v2_flag", authz.GetFeatures(ctx).PermissionCheckV2, "org_id_column", orgIDColumn, "permission", permission, "user_id", userID).Debug("permitted orgs check used")
|
||
|
return query.Where(
|
||
|
fmt.Sprintf(wherePermittedOrgsClause, orgIDColumn),
|
||
|
authz.GetInstance(ctx).InstanceID(),
|
||
|
userID,
|
||
|
permission,
|
||
|
)
|
||
|
}
|