(ctx context.Context, filter interface{})
| 96 | } |
| 97 | |
| 98 | func (e *Enforcer) loadFilteredPolicyCtx(ctx context.Context, filter interface{}) error { |
| 99 | e.invalidateMatcherMap() |
| 100 | |
| 101 | var filteredAdapter persist.ContextFilteredAdapter |
| 102 | |
| 103 | // Attempt to cast the Adapter as a FilteredAdapter |
| 104 | switch adapter := e.adapter.(type) { |
| 105 | case persist.ContextFilteredAdapter: |
| 106 | filteredAdapter = adapter |
| 107 | default: |
| 108 | return errors.New("filtered policies are not supported by this adapter") |
| 109 | } |
| 110 | if err := filteredAdapter.LoadFilteredPolicyCtx(ctx, e.model, filter); err != nil && err.Error() != "invalid file path, file path cannot be empty" { |
| 111 | return err |
| 112 | } |
| 113 | |
| 114 | if err := e.model.SortPoliciesBySubjectHierarchy(); err != nil { |
| 115 | return err |
| 116 | } |
| 117 | |
| 118 | if err := e.model.SortPoliciesByPriority(); err != nil { |
| 119 | return err |
| 120 | } |
| 121 | |
| 122 | e.initRmMap() |
| 123 | e.model.PrintPolicy() |
| 124 | if e.autoBuildRoleLinks { |
| 125 | err := e.BuildRoleLinks() |
| 126 | if err != nil { |
| 127 | return err |
| 128 | } |
| 129 | } |
| 130 | return nil |
| 131 | } |
| 132 | |
| 133 | // IsFilteredCtx returns true if the loaded policy has been filtered with context. |
| 134 | func (e *ContextEnforcer) IsFilteredCtx(ctx context.Context) bool { |
no test coverage detected