/* * Copyright 2016 Red Hat, Inc. and/or its affiliates * and other contributors as indicated by the @author tags. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.keycloak.services.resources.admin; import org.keycloak.models.ClientModel; import org.keycloak.models.RealmModel; import org.keycloak.models.RoleModel; import org.keycloak.models.UserModel; import org.keycloak.representations.AccessToken; /** * @author <a href="mailto:sthorger@redhat.com">Stian Thorgersen</a> */ public class AdminAuth { private final RealmModel realm; private final AccessToken token; private final UserModel user; private final ClientModel client; public AdminAuth(RealmModel realm, AccessToken token, UserModel user, ClientModel client) { this.token = token; this.realm = realm; this.user = user; this.client = client; } public RealmModel getRealm() { return realm; } public UserModel getUser() { return user; } public ClientModel getClient() { return client; } public AccessToken getToken() { return token; } public boolean hasRealmRole(String role) { if (client instanceof ClientModel) { RoleModel roleModel = realm.getRole(role); if (roleModel == null) return false; return user.hasRole(roleModel) && client.hasScope(roleModel); } else { AccessToken.Access access = token.getRealmAccess(); return access != null && access.isUserInRole(role); } } public boolean hasOneOfRealmRole(String... roles) { for (String r : roles) { if (hasRealmRole(r)) { return true; } } return false; } public boolean hasAppRole(ClientModel app, String role) { if (client instanceof ClientModel) { RoleModel roleModel = app.getRole(role); if (roleModel == null) return false; return user.hasRole(roleModel) && client.hasScope(roleModel); } else { AccessToken.Access access = token.getResourceAccess(app.getClientId()); return access != null && access.isUserInRole(role); } } public boolean hasOneOfAppRole(ClientModel app, String... roles) { for (String r : roles) { if (hasAppRole(app, r)) { return true; } } return false; } }