diff --git a/document/design/assets/Modeling.svg b/document/design/assets/Modeling.svg index 925a530a..f38be3b3 100644 --- a/document/design/assets/Modeling.svg +++ b/document/design/assets/Modeling.svg @@ -11,62 +11,65 @@ - limitations under the License. --> -https://github.com/Ahoo-Wang/CoSecCoSec Modeling Class Diagramtenantpolicyroleprincipalpolicyroleprincipaljava.securitycontextauthorizationauthenticationauthenticationTenantval tenantId: Stringval isPlatform: BooleanTenantCapableval tenant: TenantIs it a root platform tenant?PolicyTypeSYSTEMCUSTOMGLOBALPolicyval id: Stringval name: Stringval type: PolicyTypeval description: Stringval tenantId:Stringval statements: Set<Statement>EffectALLOWDENYRequestMatchermatch(Request,SecurityContext): BooleanActionMatcherConditionMatcherVerifyResultALLOWEXPLICIT_DENYIMPLICIT_DENYStatementval effect: Effectval actions: Set<ActionMatcher>val conditions: Set<ConditionMatcher>PermissionVerifierverify(Request,SecurityContext): VerifyResultPolicyEvaluatorevaluate(Policy)PolicyCapableval policies: Set<String>Used to evaluate the effectiveness of the PolicyRoleval id: Stringval name: Stringval description: Stringval tenantId:StringRoleCapableval roles: Set<String>CoSecPrincipalval id: Stringval attrs: Map<String, String>anonymous(): Booleanauthenticated(): BooleanTenantPrincipalA set of rolesSecurityContextval principal: CoSecPrincipalsetAttribute(String, Object): SecurityContextgetAttribute(String): T?getRequiredAttribute(String): TRequestval path: Stringval method: Stringval remoteIp: Stringval origin: Stringval referer: StringgetHeader(key: String): StringAuthorizeResultval authorized: Booleanval reason: StringAuthorizationauthorize(Request,SecurityContext): Mono<AuthorizeResult>CredentialsAuthenticationC:Credentials,P:CoSecPrincipalsupportCredentials: Class<C>authenticate(C): Mono<P>AuthenticationProviderget(Class<Credentials>): A?getRequired(Class<Credentials>): Aregister(A): Unitregister(Class<C>, A): Unitregister(A): UnitgetRequired(Class<Credentials>): ANamedname: StringPolicyTypeSYSTEMCUSTOMGLOBALPolicyval id: Stringval name: Stringval type: PolicyTypeval description: Stringval tenantId:Stringval statements: Set<Statement>EffectALLOWDENYRequestMatchermatch(Request,SecurityContext): BooleanActionMatcherConditionMatcherVerifyResultALLOWEXPLICIT_DENYIMPLICIT_DENYStatementval effect: Effectval actions: Set<ActionMatcher>val conditions: Set<ConditionMatcher>PermissionVerifierverify(Request,SecurityContext): VerifyResultPolicyEvaluatorevaluate(Policy)PolicyCapableval policies: Set<String>Used to evaluate the effectiveness of the PolicyRoleval id: Stringval name: Stringval description: Stringval tenantId:StringRoleCapableval roles: Set<String>CoSecPrincipalval id: Stringval attributes: Map<String, String>anonymous(): Booleanauthenticated(): BooleanTenantPrincipalA set of rolesPrincipalgetName():StringSecurityContextval principal: CoSecPrincipalsetAttribute(String, Object): SecurityContextgetAttribute(String): T?getRequiredAttribute(String): TRequestval path: Stringval method: Stringval remoteIp: Stringval origin: Stringval referer: StringgetHeader(key: String): StringAuthorizeResultval authorized: Booleanval reason: StringAuthorizationauthorize(Request,SecurityContext): Mono<AuthorizeResult>CredentialsAuthenticationC:Credentials,P:CoSecPrincipalsupportCredentials: Class<C>authenticate(C): Mono<P>AuthenticationProviderget(Class<Credentials>): A?getRequired(Class<Credentials>): Aregister(A): Unitregister(Class<C>, A): Unitregister(A): UnitgetRequired(Class<Credentials>): ANamedname: Stringhttps://github.com/Ahoo-Wang/CoSechttps://github.com/Ahoo-Wang/CoSec