X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.db.layer0%2Fsrc%2Forg%2Fsimantics%2Fdb%2Flayer0%2Frequest%2FSetActiveSessionRole.java;h=663e9b87843e1f62caacb652084fa649d70ea9be;hb=27cae6bcf184f7e27822886f5a7320f771913b71;hp=921e668590d06215d3842a30ec6aa22f7d711711;hpb=969bd23cab98a79ca9101af33334000879fb60c5;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.db.layer0/src/org/simantics/db/layer0/request/SetActiveSessionRole.java b/bundles/org.simantics.db.layer0/src/org/simantics/db/layer0/request/SetActiveSessionRole.java index 921e66859..663e9b878 100644 --- a/bundles/org.simantics.db.layer0/src/org/simantics/db/layer0/request/SetActiveSessionRole.java +++ b/bundles/org.simantics.db.layer0/src/org/simantics/db/layer0/request/SetActiveSessionRole.java @@ -1,52 +1,52 @@ -package org.simantics.db.layer0.request; - -import org.simantics.db.RequestProcessor; -import org.simantics.db.Resource; -import org.simantics.db.SessionModel; -import org.simantics.db.WriteGraph; -import org.simantics.db.common.request.WriteRequest; -import org.simantics.db.exception.DatabaseException; -import org.simantics.db.service.VirtualGraphSupport; -import org.simantics.layer0.Layer0; -import org.simantics.operation.Layer0X; -import org.simantics.user.UserResource; - -public class SetActiveSessionRole extends WriteRequest { - - final private Resource model; - final private Resource role; - - public SetActiveSessionRole(RequestProcessor processor, Resource model, Resource role) { - super(processor.getService(VirtualGraphSupport.class).getWorkspacePersistent("activations")); - this.model = model; - this.role = role; - } - - @Override - public void perform(WriteGraph graph) throws DatabaseException { - - Layer0 L0 = Layer0.getInstance(graph); - Layer0X L0X = Layer0X.getInstance(graph); - UserResource USER = UserResource.getInstance(graph); - Resource session = graph.getService(SessionModel.class).getResource(); - - if(session != null) { - for(Resource selection : graph.getObjects(session, L0X.Session_HasRoleSelection)) { - Resource selectionModel = graph.getPossibleObject(selection, USER.RoleSelection_HasModel); - if(selectionModel.equals(model)) { - graph.deny(selection, USER.RoleSelection_HasRole); - graph.claim(selection, USER.RoleSelection_HasRole, role); - return; - } - } - } - - Resource selection = graph.newResource(); - graph.claim(selection, L0.InstanceOf, null, USER.RoleSelection); - graph.claim(selection, USER.RoleSelection_HasModel, model); - graph.claim(selection, USER.RoleSelection_HasRole, role); - graph.claim(session, L0X.Session_HasRoleSelection, selection); - - } - -} +package org.simantics.db.layer0.request; + +import org.simantics.db.RequestProcessor; +import org.simantics.db.Resource; +import org.simantics.db.SessionModel; +import org.simantics.db.WriteGraph; +import org.simantics.db.common.request.WriteRequest; +import org.simantics.db.exception.DatabaseException; +import org.simantics.db.service.VirtualGraphSupport; +import org.simantics.layer0.Layer0; +import org.simantics.operation.Layer0X; +import org.simantics.user.UserResource; + +public class SetActiveSessionRole extends WriteRequest { + + final private Resource model; + final private Resource role; + + public SetActiveSessionRole(RequestProcessor processor, Resource model, Resource role) { + super(processor.getService(VirtualGraphSupport.class).getWorkspacePersistent("activations")); + this.model = model; + this.role = role; + } + + @Override + public void perform(WriteGraph graph) throws DatabaseException { + + Layer0 L0 = Layer0.getInstance(graph); + Layer0X L0X = Layer0X.getInstance(graph); + UserResource USER = UserResource.getInstance(graph); + Resource session = graph.getService(SessionModel.class).getResource(); + + if(session != null) { + for(Resource selection : graph.getObjects(session, L0X.Session_HasRoleSelection)) { + Resource selectionModel = graph.getPossibleObject(selection, USER.RoleSelection_HasModel); + if(selectionModel.equals(model)) { + graph.deny(selection, USER.RoleSelection_HasRole); + graph.claim(selection, USER.RoleSelection_HasRole, role); + return; + } + } + } + + Resource selection = graph.newResource(); + graph.claim(selection, L0.InstanceOf, null, USER.RoleSelection); + graph.claim(selection, USER.RoleSelection_HasModel, model); + graph.claim(selection, USER.RoleSelection_HasRole, role); + graph.claim(session, L0X.Session_HasRoleSelection, selection); + + } + +}