/** * <copyright> Copyright (c) 2008-2009 Jonas Helming, Maximilian Koegel. 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 </copyright> * * * */ package org.eclipse.emf.emfstore.server.model.accesscontrol.impl; import java.util.Collection; import org.eclipse.emf.common.notify.Notification; import org.eclipse.emf.common.notify.NotificationChain; import org.eclipse.emf.common.util.EList; import org.eclipse.emf.ecore.EClass; import org.eclipse.emf.ecore.InternalEObject; import org.eclipse.emf.ecore.impl.ENotificationImpl; import org.eclipse.emf.ecore.util.EObjectWithInverseResolvingEList; import org.eclipse.emf.ecore.util.InternalEList; import org.eclipse.emf.emfstore.common.model.impl.IdentifiableElementImpl; import org.eclipse.emf.emfstore.server.model.accesscontrol.AccesscontrolPackage; import org.eclipse.emf.emfstore.server.model.accesscontrol.PermissionType; import org.eclipse.emf.emfstore.server.model.accesscontrol.Role; import org.eclipse.emf.emfstore.server.model.accesscontrol.RoleAssignment; /** * <!-- begin-user-doc --> * An implementation of the model object '<em><b>Role</b></em>'. * <!-- end-user-doc --> * <p> * The following features are implemented: * <ul> * <li>{@link org.eclipse.emf.emfstore.server.model.accesscontrol.impl.RoleImpl#getPermissionTypes <em>Permission Types</em>}</li> * <li>{@link org.eclipse.emf.emfstore.server.model.accesscontrol.impl.RoleImpl#getDescription <em>Description</em>}</li> * <li>{@link org.eclipse.emf.emfstore.server.model.accesscontrol.impl.RoleImpl#getName <em>Name</em>}</li> * <li>{@link org.eclipse.emf.emfstore.server.model.accesscontrol.impl.RoleImpl#isSystemRole <em>System Role</em>}</li> * </ul> * </p> * * @generated */ public class RoleImpl extends IdentifiableElementImpl implements Role { /** * The cached value of the '{@link #getPermissionTypes() <em>Permission Types</em>}' reference list. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getPermissionTypes() * @generated * @ordered */ protected EList<PermissionType> permissionTypes; /** * The default value of the '{@link #getDescription() <em>Description</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getDescription() * @generated * @ordered */ protected static final String DESCRIPTION_EDEFAULT = null; /** * The cached value of the '{@link #getDescription() <em>Description</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getDescription() * @generated * @ordered */ protected String description = DESCRIPTION_EDEFAULT; /** * The default value of the '{@link #getName() <em>Name</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getName() * @generated * @ordered */ protected static final String NAME_EDEFAULT = null; /** * The cached value of the '{@link #getName() <em>Name</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #getName() * @generated * @ordered */ protected String name = NAME_EDEFAULT; /** * The default value of the '{@link #isSystemRole() <em>System Role</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #isSystemRole() * @generated * @ordered */ protected static final boolean SYSTEM_ROLE_EDEFAULT = false; /** * The cached value of the '{@link #isSystemRole() <em>System Role</em>}' attribute. * <!-- begin-user-doc --> * <!-- end-user-doc --> * @see #isSystemRole() * @generated * @ordered */ protected boolean systemRole = SYSTEM_ROLE_EDEFAULT; /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ protected RoleImpl() { super(); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override protected EClass eStaticClass() { return AccesscontrolPackage.Literals.ROLE; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public EList<PermissionType> getPermissionTypes() { if (permissionTypes == null) { permissionTypes = new EObjectWithInverseResolvingEList.ManyInverse<PermissionType>(PermissionType.class, this, AccesscontrolPackage.ROLE__PERMISSION_TYPES, AccesscontrolPackage.PERMISSION_TYPE__REFERING_ROLES); } return permissionTypes; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public String getDescription() { return description; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setDescription(String newDescription) { String oldDescription = description; description = newDescription; if (eNotificationRequired()) eNotify(new ENotificationImpl(this, Notification.SET, AccesscontrolPackage.ROLE__DESCRIPTION, oldDescription, description)); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public String getName() { return name; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setName(String newName) { String oldName = name; name = newName; if (eNotificationRequired()) eNotify(new ENotificationImpl(this, Notification.SET, AccesscontrolPackage.ROLE__NAME, oldName, name)); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public boolean isSystemRole() { return systemRole; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ public void setSystemRole(boolean newSystemRole) { boolean oldSystemRole = systemRole; systemRole = newSystemRole; if (eNotificationRequired()) eNotify(new ENotificationImpl(this, Notification.SET, AccesscontrolPackage.ROLE__SYSTEM_ROLE, oldSystemRole, systemRole)); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @SuppressWarnings("unchecked") @Override public NotificationChain eInverseAdd(InternalEObject otherEnd, int featureID, NotificationChain msgs) { switch (featureID) { case AccesscontrolPackage.ROLE__PERMISSION_TYPES: return ((InternalEList<InternalEObject>)(InternalEList<?>)getPermissionTypes()).basicAdd(otherEnd, msgs); } return super.eInverseAdd(otherEnd, featureID, msgs); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs) { switch (featureID) { case AccesscontrolPackage.ROLE__PERMISSION_TYPES: return ((InternalEList<?>)getPermissionTypes()).basicRemove(otherEnd, msgs); } return super.eInverseRemove(otherEnd, featureID, msgs); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public Object eGet(int featureID, boolean resolve, boolean coreType) { switch (featureID) { case AccesscontrolPackage.ROLE__PERMISSION_TYPES: return getPermissionTypes(); case AccesscontrolPackage.ROLE__DESCRIPTION: return getDescription(); case AccesscontrolPackage.ROLE__NAME: return getName(); case AccesscontrolPackage.ROLE__SYSTEM_ROLE: return isSystemRole(); } return super.eGet(featureID, resolve, coreType); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @SuppressWarnings("unchecked") @Override public void eSet(int featureID, Object newValue) { switch (featureID) { case AccesscontrolPackage.ROLE__PERMISSION_TYPES: getPermissionTypes().clear(); getPermissionTypes().addAll((Collection<? extends PermissionType>)newValue); return; case AccesscontrolPackage.ROLE__DESCRIPTION: setDescription((String)newValue); return; case AccesscontrolPackage.ROLE__NAME: setName((String)newValue); return; case AccesscontrolPackage.ROLE__SYSTEM_ROLE: setSystemRole((Boolean)newValue); return; } super.eSet(featureID, newValue); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public void eUnset(int featureID) { switch (featureID) { case AccesscontrolPackage.ROLE__PERMISSION_TYPES: getPermissionTypes().clear(); return; case AccesscontrolPackage.ROLE__DESCRIPTION: setDescription(DESCRIPTION_EDEFAULT); return; case AccesscontrolPackage.ROLE__NAME: setName(NAME_EDEFAULT); return; case AccesscontrolPackage.ROLE__SYSTEM_ROLE: setSystemRole(SYSTEM_ROLE_EDEFAULT); return; } super.eUnset(featureID); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public boolean eIsSet(int featureID) { switch (featureID) { case AccesscontrolPackage.ROLE__PERMISSION_TYPES: return permissionTypes != null && !permissionTypes.isEmpty(); case AccesscontrolPackage.ROLE__DESCRIPTION: return DESCRIPTION_EDEFAULT == null ? description != null : !DESCRIPTION_EDEFAULT.equals(description); case AccesscontrolPackage.ROLE__NAME: return NAME_EDEFAULT == null ? name != null : !NAME_EDEFAULT.equals(name); case AccesscontrolPackage.ROLE__SYSTEM_ROLE: return systemRole != SYSTEM_ROLE_EDEFAULT; } return super.eIsSet(featureID); } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * @generated */ @Override public String toString() { if (eIsProxy()) return super.toString(); StringBuffer result = new StringBuffer(super.toString()); result.append(" (description: "); result.append(description); result.append(", name: "); result.append(name); result.append(", systemRole: "); result.append(systemRole); result.append(')'); return result.toString(); } } // RoleImpl