/* * Copyright (c) 2012, 2013, 2016 Eike Stepper (Berlin, Germany) and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * Eike Stepper - initial API and implementation */ package org.eclipse.emf.cdo.security.impl; import org.eclipse.emf.cdo.security.Access; import org.eclipse.emf.cdo.security.Directory; import org.eclipse.emf.cdo.security.Group; import org.eclipse.emf.cdo.security.Permission; import org.eclipse.emf.cdo.security.Realm; import org.eclipse.emf.cdo.security.RealmUtil; import org.eclipse.emf.cdo.security.Role; import org.eclipse.emf.cdo.security.SecurityFactory; import org.eclipse.emf.cdo.security.SecurityItem; import org.eclipse.emf.cdo.security.SecurityPackage; import org.eclipse.emf.cdo.security.User; import org.eclipse.emf.cdo.security.UserPassword; import org.eclipse.net4j.util.security.IPasswordCredentials; import org.eclipse.emf.common.util.EList; import org.eclipse.emf.ecore.EClass; import org.eclipse.emf.ecore.EStructuralFeature; import org.eclipse.emf.ecore.InternalEObject; /** * <!-- begin-user-doc --> * An implementation of the model object '<em><b>Realm</b></em>'. * <!-- end-user-doc --> * <p> * The following features are implemented: * </p> * <ul> * <li>{@link org.eclipse.emf.cdo.security.impl.RealmImpl#getItems <em>Items</em>}</li> * <li>{@link org.eclipse.emf.cdo.security.impl.RealmImpl#getAllUsers <em>All Users</em>}</li> * <li>{@link org.eclipse.emf.cdo.security.impl.RealmImpl#getAllGroups <em>All Groups</em>}</li> * <li>{@link org.eclipse.emf.cdo.security.impl.RealmImpl#getAllRoles <em>All Roles</em>}</li> * <li>{@link org.eclipse.emf.cdo.security.impl.RealmImpl#getAllPermissions <em>All Permissions</em>}</li> * <li>{@link org.eclipse.emf.cdo.security.impl.RealmImpl#getName <em>Name</em>}</li> * <li>{@link org.eclipse.emf.cdo.security.impl.RealmImpl#getDefaultAccess <em>Default Access</em>}</li> * <li>{@link org.eclipse.emf.cdo.security.impl.RealmImpl#getDefaultUserDirectory <em>Default User Directory</em>}</li> * <li>{@link org.eclipse.emf.cdo.security.impl.RealmImpl#getDefaultGroupDirectory <em>Default Group Directory</em>}</li> * <li>{@link org.eclipse.emf.cdo.security.impl.RealmImpl#getDefaultRoleDirectory <em>Default Role Directory</em>}</li> * </ul> * * @generated */ public class RealmImpl extends SecurityElementImpl implements Realm { private EList<User> allUsers = new DerivedList<User>() { @Override protected InternalEObject getOwner() { return RealmImpl.this; } @Override protected EStructuralFeature getFeature() { return SecurityPackage.Literals.REALM__ALL_USERS; } @Override protected Object[] getData() { EList<SecurityItem> items = getItems(); return RealmUtil.allUsers(items).toArray(); } }; private EList<Group> allGroups = new DerivedList<Group>() { @Override protected InternalEObject getOwner() { return RealmImpl.this; } @Override protected EStructuralFeature getFeature() { return SecurityPackage.Literals.REALM__ALL_GROUPS; } @Override protected Object[] getData() { EList<SecurityItem> items = getItems(); return RealmUtil.allGroups(items).toArray(); } }; private EList<Role> allRoles = new DerivedList<Role>() { @Override protected InternalEObject getOwner() { return RealmImpl.this; } @Override protected EStructuralFeature getFeature() { return SecurityPackage.Literals.REALM__ALL_ROLES; } @Override protected Object[] getData() { EList<SecurityItem> items = getItems(); return RealmUtil.allRoles(items).toArray(); } }; private EList<Permission> allPermissions = new DerivedList<Permission>() { @Override protected InternalEObject getOwner() { return RealmImpl.this; } @Override protected EStructuralFeature getFeature() { return SecurityPackage.Literals.REALM__ALL_PERMISSIONS; } @Override protected Object[] getData() { EList<SecurityItem> items = getItems(); return RealmUtil.allPermissions(items).toArray(); } }; /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ protected RealmImpl() { super(); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override protected EClass eStaticClass() { return SecurityPackage.Literals.REALM; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @SuppressWarnings("unchecked") public EList<SecurityItem> getItems() { return (EList<SecurityItem>)eGet(SecurityPackage.Literals.REALM__ITEMS, true); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated NOT */ public EList<User> getAllUsers() { return allUsers; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated NOT */ public EList<Group> getAllGroups() { return allGroups; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated NOT */ public EList<Role> getAllRoles() { return allRoles; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated NOT */ public EList<Permission> getAllPermissions() { return allPermissions; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public String getName() { return (String)eGet(SecurityPackage.Literals.REALM__NAME, true); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setName(String newName) { eSet(SecurityPackage.Literals.REALM__NAME, newName); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public Access getDefaultAccess() { return (Access)eGet(SecurityPackage.Literals.REALM__DEFAULT_ACCESS, true); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setDefaultAccess(Access newDefaultAccess) { eSet(SecurityPackage.Literals.REALM__DEFAULT_ACCESS, newDefaultAccess); } /** * <!-- begin-user-doc --> * @since 4.2 * <!-- end-user-doc --> * @generated */ public Directory getDefaultUserDirectory() { return (Directory)eGet(SecurityPackage.Literals.REALM__DEFAULT_USER_DIRECTORY, true); } /** * <!-- begin-user-doc --> * @since 4.2 * <!-- end-user-doc --> * @generated */ public void setDefaultUserDirectory(Directory newDefaultUserDirectory) { eSet(SecurityPackage.Literals.REALM__DEFAULT_USER_DIRECTORY, newDefaultUserDirectory); } /** * <!-- begin-user-doc --> * @since 4.2 * <!-- end-user-doc --> * @generated */ public Directory getDefaultGroupDirectory() { return (Directory)eGet(SecurityPackage.Literals.REALM__DEFAULT_GROUP_DIRECTORY, true); } /** * <!-- begin-user-doc --> * @since 4.2 * <!-- end-user-doc --> * @generated */ public void setDefaultGroupDirectory(Directory newDefaultGroupDirectory) { eSet(SecurityPackage.Literals.REALM__DEFAULT_GROUP_DIRECTORY, newDefaultGroupDirectory); } /** * <!-- begin-user-doc --> * @since 4.2 * <!-- end-user-doc --> * @generated */ public Directory getDefaultRoleDirectory() { return (Directory)eGet(SecurityPackage.Literals.REALM__DEFAULT_ROLE_DIRECTORY, true); } /** * <!-- begin-user-doc --> * @since 4.2 * <!-- end-user-doc --> * @generated */ public void setDefaultRoleDirectory(Directory newDefaultRoleDirectory) { eSet(SecurityPackage.Literals.REALM__DEFAULT_ROLE_DIRECTORY, newDefaultRoleDirectory); } /** * @since 4.2 */ public Role getRole(String id) { return RealmUtil.findRole(getItems(), id); } /** * @since 4.2 */ public Group getGroup(String id) { return RealmUtil.findGroup(getItems(), id); } /** * @since 4.2 */ public User getUser(String id) { return RealmUtil.findUser(getItems(), id); } /** * @since 4.2 */ protected EList<SecurityItem> getRoleItems() { Directory directory = getDefaultRoleDirectory(); return directory != null ? directory.getItems() : getItems(); } /** * @since 4.2 */ protected EList<SecurityItem> getGroupItems() { Directory directory = getDefaultGroupDirectory(); return directory != null ? directory.getItems() : getItems(); } /** * @since 4.2 */ protected EList<SecurityItem> getUserItems() { Directory directory = getDefaultUserDirectory(); return directory != null ? directory.getItems() : getItems(); } /** * @since 4.2 */ public Role addRole(String id) { Role role = SecurityFactory.eINSTANCE.createRole(id); EList<SecurityItem> items = getRoleItems(); items.add(role); return role; } /** * @since 4.2 */ public Group addGroup(String id) { Group group = SecurityFactory.eINSTANCE.createGroup(id); EList<SecurityItem> items = getGroupItems(); items.add(group); return group; } /** * @since 4.2 */ public User addUser(String id) { User user = SecurityFactory.eINSTANCE.createUser(id); return addUser(user); } /** * @since 4.2 */ public User addUser(String id, String password) { User user = SecurityFactory.eINSTANCE.createUser(id, password); return addUser(user); } /** * @since 4.3 */ public User addUser(IPasswordCredentials credentials) { return addUser(credentials.getUserID(), new String(credentials.getPassword())); } /** * @since 4.2 */ protected User addUser(User user) { EList<SecurityItem> items = getUserItems(); items.add(user); return user; } /** * @since 4.3 */ public User setPassword(String id, String password) { UserPassword userPassword = null; if (password != null && password.length() != 0) { userPassword = SecurityFactory.eINSTANCE.createUserPassword(); userPassword.setEncrypted(password); } User user = getUser(id); user.setPassword(userPassword); return user; } /** * @since 4.2 */ public Role removeRole(String id) { EList<SecurityItem> items = getRoleItems(); Role role = RealmUtil.removeRole(items, id); if (role == null) { EList<SecurityItem> realmItems = getItems(); if (items != realmItems) { role = RealmUtil.removeRole(realmItems, id); } } return role; } /** * @since 4.2 */ public Group removeGroup(String id) { EList<SecurityItem> items = getGroupItems(); Group group = RealmUtil.removeGroup(items, id); if (group == null) { EList<SecurityItem> realmItems = getItems(); if (items != realmItems) { group = RealmUtil.removeGroup(realmItems, id); } } return group; } /** * @since 4.2 */ public User removeUser(String id) { EList<SecurityItem> items = getUserItems(); User user = RealmUtil.removeUser(items, id); if (user == null) { EList<SecurityItem> realmItems = getItems(); if (items != realmItems) { user = RealmUtil.removeUser(realmItems, id); } } return user; } @Override public Realm getRealm() { return this; } } // SecurityRealmImpl