
io.joynr.accesscontrol.global.GlobalDomainAccessControllerProviderImpl Maven / Gradle / Ivy
package io.joynr.accesscontrol.global;
/*
* #%L
* %%
* Copyright (C) 2011 - 2014 BMW Car IT GmbH
* %%
* 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.
* #L%
*/
import io.joynr.accesscontrol.DomainAccessControlStore;
import io.joynr.provider.Promise;
import java.util.Arrays;
import joynr.infrastructure.GlobalDomainAccessControllerAbstractProvider;
import joynr.infrastructure.DacTypes.ChangeType;
import joynr.infrastructure.DacTypes.DomainRoleEntry;
import joynr.infrastructure.DacTypes.MasterAccessControlEntry;
import joynr.infrastructure.DacTypes.MasterRegistrationControlEntry;
import joynr.infrastructure.DacTypes.OwnerAccessControlEntry;
import joynr.infrastructure.DacTypes.OwnerRegistrationControlEntry;
import joynr.infrastructure.DacTypes.Role;
import com.google.inject.Inject;
import com.google.inject.Singleton;
/**
* Manages the Access Control Lists for all providers.
*/
@Singleton
public class GlobalDomainAccessControllerProviderImpl extends GlobalDomainAccessControllerAbstractProvider {
private static final String DUMMY_USERID = "dummyUserId";
private final DomainAccessControlStore domainAccessStore;
@Inject
public GlobalDomainAccessControllerProviderImpl(DomainAccessControlStore domainAccessStore) {
this.domainAccessStore = domainAccessStore;
}
@Override
public Promise getDomainRoles(String uid) {
GetDomainRolesDeferred deferred = new GetDomainRolesDeferred();
deferred.resolve(domainAccessStore.getDomainRoles(uid).toArray(new DomainRoleEntry[0]));
return new Promise(deferred);
}
@Override
public Promise updateDomainRole(DomainRoleEntry updatedEntry) {
UpdateDomainRoleDeferred deferred = new UpdateDomainRoleDeferred();
boolean updateSuccess = domainAccessStore.updateDomainRole(updatedEntry);
if (updateSuccess) {
fireDomainRoleEntryChanged(ChangeType.UPDATE, updatedEntry);
}
deferred.resolve(updateSuccess);
return new Promise(deferred);
}
@Override
public Promise removeDomainRole(String uid, Role role) {
RemoveDomainRoleDeferred deferred = new RemoveDomainRoleDeferred();
boolean removeSuccess = domainAccessStore.removeDomainRole(uid, role);
if (removeSuccess) {
// To notify DRE removal only primary keys (user ID and role) must
// be set. All other fields are undefined.
DomainRoleEntry removedEntry = new DomainRoleEntry(uid, null, role);
fireDomainRoleEntryChanged(ChangeType.REMOVE, removedEntry);
}
deferred.resolve(removeSuccess);
return new Promise(deferred);
}
@Override
public Promise getMasterAccessControlEntries(String uid) {
GetMasterAccessControlEntries1Deferred deferred = new GetMasterAccessControlEntries1Deferred();
deferred.resolve(domainAccessStore.getMasterAccessControlEntries(uid).toArray(new MasterAccessControlEntry[0]));
return new Promise(deferred);
}
@Override
public Promise getEditableMasterAccessControlEntries(String uid) {
GetEditableMasterAccessControlEntriesDeferred deferred = new GetEditableMasterAccessControlEntriesDeferred();
deferred.resolve(domainAccessStore.getEditableMasterAccessControlEntries(uid)
.toArray(new MasterAccessControlEntry[0]));
return new Promise(deferred);
}
@Override
public Promise getMasterAccessControlEntries(String domain,
String interfaceName) {
GetMasterAccessControlEntries1Deferred deferred = new GetMasterAccessControlEntries1Deferred();
deferred.resolve(domainAccessStore.getMasterAccessControlEntries(domain, interfaceName)
.toArray(new MasterAccessControlEntry[0]));
return new Promise(deferred);
}
@Override
public Promise updateMasterAccessControlEntry(MasterAccessControlEntry updatedMasterAccessControlEntry) {
UpdateMasterAccessControlEntryDeferred deferred = new UpdateMasterAccessControlEntryDeferred();
// Unless the userId has Role.MASTER, they may not change Master ACL
// TODO: we need the user ID of the user that is updating the ACE
if (!hasRoleMaster(DUMMY_USERID, updatedMasterAccessControlEntry.getDomain())) {
deferred.resolve(false);
} else {
boolean updateSuccess = domainAccessStore.updateMasterAccessControlEntry(updatedMasterAccessControlEntry);
if (updateSuccess) {
fireMasterAccessControlEntryChanged(ChangeType.UPDATE, updatedMasterAccessControlEntry);
}
deferred.resolve(updateSuccess);
}
return new Promise(deferred);
}
// Indicates if the given user has master role for the given domain
private boolean hasRoleMaster(String userId, String domain) {
DomainRoleEntry domainRole = domainAccessStore.getDomainRole(userId, Role.MASTER);
if (domainRole == null || !Arrays.asList(domainRole.getDomains()).contains(domain)) {
return false;
}
return true;
}
@Override
public Promise removeMasterAccessControlEntry(String uid,
String domain,
String interfaceName,
String operation) {
RemoveMasterAccessControlEntryDeferred deferred = new RemoveMasterAccessControlEntryDeferred();
boolean removeSuccess = domainAccessStore.removeMasterAccessControlEntry(uid, domain, interfaceName, operation);
if (removeSuccess) {
MasterAccessControlEntry removedEntry = new MasterAccessControlEntry(uid,
domain,
interfaceName,
null,
null,
null,
null,
operation,
null,
null);
fireMasterAccessControlEntryChanged(ChangeType.REMOVE, removedEntry);
}
deferred.resolve(removeSuccess);
return new Promise(deferred);
}
@Override
public Promise getMediatorAccessControlEntries(String uid) {
GetMediatorAccessControlEntries1Deferred deferred = new GetMediatorAccessControlEntries1Deferred();
deferred.resolve(domainAccessStore.getMediatorAccessControlEntries(uid)
.toArray(new MasterAccessControlEntry[0]));
return new Promise(deferred);
}
@Override
public Promise getEditableMediatorAccessControlEntries(String uid) {
GetEditableMediatorAccessControlEntriesDeferred deferred = new GetEditableMediatorAccessControlEntriesDeferred();
deferred.resolve(domainAccessStore.getEditableMediatorAccessControlEntries(uid)
.toArray(new MasterAccessControlEntry[0]));
return new Promise(deferred);
}
@Override
public Promise getMediatorAccessControlEntries(String domain,
String interfaceName) {
GetMediatorAccessControlEntries1Deferred deferred = new GetMediatorAccessControlEntries1Deferred();
deferred.resolve(domainAccessStore.getMediatorAccessControlEntries(domain, interfaceName)
.toArray(new MasterAccessControlEntry[0]));
return new Promise(deferred);
}
@Override
public Promise updateMediatorAccessControlEntry(MasterAccessControlEntry updatedMediatorAccessControlEntry) {
UpdateMediatorAccessControlEntryDeferred deferred = new UpdateMediatorAccessControlEntryDeferred();
// Unless the userId has Role.MASTER, they may not change Mediator ACL
// TODO: we need the user ID of the user that is updating the ACE
if (!hasRoleMaster(DUMMY_USERID, updatedMediatorAccessControlEntry.getDomain())) {
deferred.resolve(false);
} else {
boolean updateSuccess = domainAccessStore.updateMediatorAccessControlEntry(updatedMediatorAccessControlEntry);
if (updateSuccess) {
fireMediatorAccessControlEntryChanged(ChangeType.UPDATE, updatedMediatorAccessControlEntry);
}
deferred.resolve(updateSuccess);
}
return new Promise(deferred);
}
@Override
public Promise removeMediatorAccessControlEntry(String uid,
String domain,
String interfaceName,
String operation) {
RemoveMediatorAccessControlEntryDeferred deferred = new RemoveMediatorAccessControlEntryDeferred();
boolean removeSuccess = domainAccessStore.removeMediatorAccessControlEntry(uid,
domain,
interfaceName,
operation);
if (removeSuccess) {
MasterAccessControlEntry removedEntry = new MasterAccessControlEntry(uid,
domain,
interfaceName,
null,
null,
null,
null,
operation,
null,
null);
fireMediatorAccessControlEntryChanged(ChangeType.REMOVE, removedEntry);
}
deferred.resolve(removeSuccess);
return new Promise(deferred);
}
@Override
public Promise getOwnerAccessControlEntries(String uid) {
GetOwnerAccessControlEntries1Deferred deferred = new GetOwnerAccessControlEntries1Deferred();
deferred.resolve(domainAccessStore.getOwnerAccessControlEntries(uid).toArray(new OwnerAccessControlEntry[0]));
return new Promise(deferred);
}
@Override
public Promise getOwnerAccessControlEntries(String domain,
String interfaceName) {
GetOwnerAccessControlEntries1Deferred deferred = new GetOwnerAccessControlEntries1Deferred();
deferred.resolve(domainAccessStore.getOwnerAccessControlEntries(domain, interfaceName)
.toArray(new OwnerAccessControlEntry[0]));
return new Promise(deferred);
}
@Override
public Promise getEditableOwnerAccessControlEntries(String uid) {
GetEditableOwnerAccessControlEntriesDeferred deferred = new GetEditableOwnerAccessControlEntriesDeferred();
deferred.resolve(domainAccessStore.getEditableOwnerAccessControlEntries(uid)
.toArray(new OwnerAccessControlEntry[0]));
return new Promise(deferred);
}
@Override
public Promise updateOwnerAccessControlEntry(OwnerAccessControlEntry updatedOwnerAccessControlEntry) {
UpdateOwnerAccessControlEntryDeferred deferred = new UpdateOwnerAccessControlEntryDeferred();
// Unless the userId has Role.MASTER, they may not change Owner ACL
// TODO: we need the user ID of the user that is updating the ACE
if (!hasRoleMaster(DUMMY_USERID, updatedOwnerAccessControlEntry.getDomain())) {
deferred.resolve(false);
} else {
boolean updateSuccess = domainAccessStore.updateOwnerAccessControlEntry(updatedOwnerAccessControlEntry);
if (updateSuccess) {
fireOwnerAccessControlEntryChanged(ChangeType.UPDATE, updatedOwnerAccessControlEntry);
}
deferred.resolve(updateSuccess);
}
return new Promise(deferred);
}
@Override
public Promise removeOwnerAccessControlEntry(String uid,
String domain,
String interfaceName,
String operation) {
RemoveOwnerAccessControlEntryDeferred deferred = new RemoveOwnerAccessControlEntryDeferred();
boolean removeSuccess = domainAccessStore.removeOwnerAccessControlEntry(uid, domain, interfaceName, operation);
if (removeSuccess) {
OwnerAccessControlEntry removedEntry = new OwnerAccessControlEntry(uid,
domain,
interfaceName,
null,
null,
operation,
null);
fireOwnerAccessControlEntryChanged(ChangeType.REMOVE, removedEntry);
}
deferred.resolve(removeSuccess);
return new Promise(deferred);
}
@Override
public Promise getMasterRegistrationControlEntries(String uid) {
assert false : "method not implemented";
return null;
}
@Override
public Promise getEditableMasterRegistrationControlEntries(String uid) {
assert false : "method not implemented";
return null;
}
@Override
public Promise updateMasterRegistrationControlEntry(MasterRegistrationControlEntry updatedMasterRce) {
assert false : "method not implemented";
return null;
}
@Override
public Promise removeMasterRegistrationControlEntry(String uid,
String domain,
String interfaceName) {
assert false : "method not implemented";
return null;
}
@Override
public Promise getMediatorRegistrationControlEntries(String uid) {
assert false : "method not implemented";
return null;
}
@Override
public Promise getEditableMediatorRegistrationControlEntries(String uid) {
assert false : "method not implemented";
return null;
}
@Override
public Promise updateMediatorRegistrationControlEntry(MasterRegistrationControlEntry updatedMediatorRce) {
assert false : "method not implemented";
return null;
}
@Override
public Promise removeMediatorRegistrationControlEntry(String uid,
String domain,
String interfaceName) {
assert false : "method not implemented";
return null;
}
@Override
public Promise getOwnerRegistrationControlEntries(String uid) {
assert false : "method not implemented";
return null;
}
@Override
public Promise getEditableOwnerRegistrationControlEntries(String uid) {
assert false : "method not implemented";
return null;
}
@Override
public Promise updateOwnerRegistrationControlEntry(OwnerRegistrationControlEntry updatedOwnerRce) {
assert false : "method not implemented";
return null;
}
@Override
public Promise removeOwnerRegistrationControlEntry(String uid,
String domain,
String interfaceName) {
assert false : "method not implemented";
return null;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy