/**
* (C) Copyright 2013 Jabylon (http://www.jabylon.org) 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
*/
package org.jabylon.users.impl;
import java.util.Collection;
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.util.InternalEList;
import org.eclipse.emf.internal.cdo.CDOObjectImpl;
import org.jabylon.users.Permission;
import org.jabylon.users.Role;
import org.jabylon.users.User;
import org.jabylon.users.UserManagement;
import org.jabylon.users.UsersPackage;
/**
* <!-- begin-user-doc -->
* An implementation of the model object '<em><b>User Management</b></em>'.
* <!-- end-user-doc -->
* <p>
* The following features are implemented:
* <ul>
* <li>{@link org.jabylon.users.impl.UserManagementImpl#getUsers <em>Users</em>}</li>
* <li>{@link org.jabylon.users.impl.UserManagementImpl#getRoles <em>Roles</em>}</li>
* <li>{@link org.jabylon.users.impl.UserManagementImpl#getPermissions <em>Permissions</em>}</li>
* </ul>
* </p>
*
* @generated
*/
public class UserManagementImpl extends CDOObjectImpl implements UserManagement {
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected UserManagementImpl() {
super();
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
protected EClass eStaticClass() {
return UsersPackage.Literals.USER_MANAGEMENT;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
protected int eStaticFeatureCount() {
return 0;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@SuppressWarnings("unchecked")
public EList<User> getUsers() {
return (EList<User>)eDynamicGet(UsersPackage.USER_MANAGEMENT__USERS, UsersPackage.Literals.USER_MANAGEMENT__USERS, true, true);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@SuppressWarnings("unchecked")
public EList<Role> getRoles() {
return (EList<Role>)eDynamicGet(UsersPackage.USER_MANAGEMENT__ROLES, UsersPackage.Literals.USER_MANAGEMENT__ROLES, true, true);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@SuppressWarnings("unchecked")
public EList<Permission> getPermissions() {
return (EList<Permission>)eDynamicGet(UsersPackage.USER_MANAGEMENT__PERMISSIONS, UsersPackage.Literals.USER_MANAGEMENT__PERMISSIONS, true, true);
}
/**
* <!-- begin-user-doc -->
* May return null!
* <!-- end-user-doc -->
* @generated NOT
*/
public User findUserByName(String name) {
//TODO: user queries instead?
for (User user : getUsers()) {
if(user.getName().equals(name))
return user;
}
return null;
}
/**
* <!-- begin-user-doc -->
* May return null!
* <!-- end-user-doc -->
* @generated NOT
*/
public Permission findPermissionByName(String name) {
for (Permission perm : getPermissions()) {
if(perm.getName().equals(name))
return perm;
}
return null;
}
/**
* <!-- begin-user-doc -->
* May return null!
* <!-- end-user-doc -->
* @generated NOT
*/
public Role findRoleByName(String name) {
for (Role role : getRoles()) {
if(role.getName().equals(name))
return role;
}
return null;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated NOT
*/
public User findUserByToken(String token) {
if(token==null || token.isEmpty())
return null;
for (User user : getUsers()) {
if(token.equals(user.getToken()))
return user;
}
return null;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs) {
switch (featureID) {
case UsersPackage.USER_MANAGEMENT__USERS:
return ((InternalEList<?>)getUsers()).basicRemove(otherEnd, msgs);
case UsersPackage.USER_MANAGEMENT__ROLES:
return ((InternalEList<?>)getRoles()).basicRemove(otherEnd, msgs);
case UsersPackage.USER_MANAGEMENT__PERMISSIONS:
return ((InternalEList<?>)getPermissions()).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 UsersPackage.USER_MANAGEMENT__USERS:
return getUsers();
case UsersPackage.USER_MANAGEMENT__ROLES:
return getRoles();
case UsersPackage.USER_MANAGEMENT__PERMISSIONS:
return getPermissions();
}
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 UsersPackage.USER_MANAGEMENT__USERS:
getUsers().clear();
getUsers().addAll((Collection<? extends User>)newValue);
return;
case UsersPackage.USER_MANAGEMENT__ROLES:
getRoles().clear();
getRoles().addAll((Collection<? extends Role>)newValue);
return;
case UsersPackage.USER_MANAGEMENT__PERMISSIONS:
getPermissions().clear();
getPermissions().addAll((Collection<? extends Permission>)newValue);
return;
}
super.eSet(featureID, newValue);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void eUnset(int featureID) {
switch (featureID) {
case UsersPackage.USER_MANAGEMENT__USERS:
getUsers().clear();
return;
case UsersPackage.USER_MANAGEMENT__ROLES:
getRoles().clear();
return;
case UsersPackage.USER_MANAGEMENT__PERMISSIONS:
getPermissions().clear();
return;
}
super.eUnset(featureID);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public boolean eIsSet(int featureID) {
switch (featureID) {
case UsersPackage.USER_MANAGEMENT__USERS:
return !getUsers().isEmpty();
case UsersPackage.USER_MANAGEMENT__ROLES:
return !getRoles().isEmpty();
case UsersPackage.USER_MANAGEMENT__PERMISSIONS:
return !getPermissions().isEmpty();
}
return super.eIsSet(featureID);
}
} //UserManagementImpl