Search in sources :

Example 1 with Authenticate

use of com.runwaysdk.business.rbac.Authenticate in project geoprism-registry by terraframe.

the class GeoRegistryUtil method createHierarchyType.

@Authenticate
public static String createHierarchyType(String htJSON) {
    RegistryAdapter adapter = ServiceFactory.getAdapter();
    HierarchyType hierarchyType = HierarchyType.fromJSON(htJSON, adapter);
    ServiceFactory.getHierarchyPermissionService().enforceCanCreate(hierarchyType.getOrganizationCode());
    ServerHierarchyType sType = new ServerHierarchyTypeBuilder().createHierarchyType(hierarchyType);
    // The transaction did not error out, so it is safe to put into the cache.
    ServiceFactory.getMetadataCache().addHierarchyType(sType);
    return hierarchyType.getCode();
}
Also used : ServerHierarchyType(net.geoprism.registry.model.ServerHierarchyType) ServerHierarchyType(net.geoprism.registry.model.ServerHierarchyType) HierarchyType(org.commongeoregistry.adapter.metadata.HierarchyType) ServerHierarchyTypeBuilder(net.geoprism.registry.conversion.ServerHierarchyTypeBuilder) RegistryAdapter(org.commongeoregistry.adapter.RegistryAdapter) Authenticate(com.runwaysdk.business.rbac.Authenticate)

Example 2 with Authenticate

use of com.runwaysdk.business.rbac.Authenticate in project geoprism-registry by terraframe.

the class GeoRegistryUtil method applyClassificationType.

@Authenticate
public static String applyClassificationType(String json) {
    JsonObject object = JsonParser.parseString(json).getAsJsonObject();
    ClassificationType type = ClassificationType.apply(object);
    return type.toJSON().toString();
}
Also used : JsonObject(com.google.gson.JsonObject) ClassificationType(net.geoprism.registry.model.ClassificationType) Authenticate(com.runwaysdk.business.rbac.Authenticate)

Example 3 with Authenticate

use of com.runwaysdk.business.rbac.Authenticate in project geoprism-registry by terraframe.

the class RegistrySessionService method ologin.

/**
 * Serves as a "redirect url" for logging into DHIS2 via oauth.
 *
 * @param serverId
 * @param code
 * @param locales
 * @param redirectBase
 * @return
 */
@Authenticate
public static java.lang.String ologin(java.lang.String serverId, java.lang.String code, java.lang.String locales, java.lang.String redirectBase) {
    try {
        // We used to try to build this from the controller but it would include stuff (like the port :443) which then wouldn't match
        // with the redirect url the client specified in DHIS2. Therefore this has to be something that the user can set (or, at least,
        // in a properties file)
        redirectBase = GeoregistryProperties.getRemoteServerUrl();
        String redirect = redirectBase + "cgrsession/ologin";
        OauthServer server = OauthServer.get(serverId);
        /*
       * Get the access token
       */
        TokenRequestBuilder tokenBuilder = OAuthClientRequest.tokenLocation(server.getTokenLocation());
        tokenBuilder.setGrantType(GrantType.AUTHORIZATION_CODE);
        tokenBuilder.setRedirectURI(redirect);
        tokenBuilder.setCode(code);
        String auth = server.getClientId() + ":" + server.getSecretKey();
        OAuthClientRequest tokenRequest = tokenBuilder.buildBodyMessage();
        tokenRequest.setHeader("Accept", "application/json");
        tokenRequest.setHeader("Authorization", "Basic " + new String(Base64.getEncoder().encode(auth.getBytes())));
        URLConnectionClient connClient = new URLConnectionClient();
        OAuthClient oAuthClient = new OAuthClient(connClient);
        OAuthJSONAccessTokenResponse accessToken = oAuthClient.accessToken(tokenRequest, OAuth.HttpMethod.POST, OAuthJSONAccessTokenResponse.class);
        /*
       * Request the user information
       */
        OAuthBearerClientRequest requestBuilder = new OAuthBearerClientRequest(server.getProfileLocation());
        requestBuilder.setAccessToken(accessToken.getAccessToken());
        OAuthClientRequest bearerRequest = requestBuilder.buildQueryMessage();
        OAuthResourceResponse resourceResponse = oAuthClient.resource(bearerRequest, OAuth.HttpMethod.GET, OAuthResourceResponse.class);
        String body = resourceResponse.getBody();
        JSONObject object = new JSONObject(body);
        final String username = object.getJSONObject("userCredentials").getString("username");
        SingleActorDAOIF profile = RegistrySessionService.getActor(server, username);
        String sessionId = SessionFacade.logIn(profile, LocaleSerializer.deserialize(locales));
        JsonObject json = new JsonObject();
        json.addProperty("sessionId", sessionId);
        json.addProperty("username", username);
        return json.toString();
    } catch (JSONException | OAuthSystemException | OAuthProblemException e) {
        throw new InvalidLoginException(e);
    }
}
Also used : TokenRequestBuilder(org.apache.oltu.oauth2.client.request.OAuthClientRequest.TokenRequestBuilder) OAuthResourceResponse(org.apache.oltu.oauth2.client.response.OAuthResourceResponse) OAuthClient(org.apache.oltu.oauth2.client.OAuthClient) OAuthSystemException(org.apache.oltu.oauth2.common.exception.OAuthSystemException) JsonObject(com.google.gson.JsonObject) JSONException(org.json.JSONException) OAuthBearerClientRequest(org.apache.oltu.oauth2.client.request.OAuthBearerClientRequest) OAuthProblemException(org.apache.oltu.oauth2.common.exception.OAuthProblemException) URLConnectionClient(org.apache.oltu.oauth2.client.URLConnectionClient) JSONObject(org.json.JSONObject) InvalidLoginException(com.runwaysdk.session.InvalidLoginException) OAuthJSONAccessTokenResponse(org.apache.oltu.oauth2.client.response.OAuthJSONAccessTokenResponse) SingleActorDAOIF(com.runwaysdk.business.rbac.SingleActorDAOIF) OAuthClientRequest(org.apache.oltu.oauth2.client.request.OAuthClientRequest) OauthServer(net.geoprism.account.OauthServer) Authenticate(com.runwaysdk.business.rbac.Authenticate)

Example 4 with Authenticate

use of com.runwaysdk.business.rbac.Authenticate in project geoprism-registry by terraframe.

the class GeoRegistryUtil method importTypes.

@Authenticate
public static void importTypes(String orgCode, InputStream istream) {
    Organization organization = Organization.getByCode(orgCode);
    XMLImporter xmlImporter = new XMLImporter();
    xmlImporter.importXMLDefinitions(organization, istream);
}
Also used : XMLImporter(net.geoprism.registry.xml.XMLImporter) Authenticate(com.runwaysdk.business.rbac.Authenticate)

Aggregations

Authenticate (com.runwaysdk.business.rbac.Authenticate)4 JsonObject (com.google.gson.JsonObject)2 SingleActorDAOIF (com.runwaysdk.business.rbac.SingleActorDAOIF)1 InvalidLoginException (com.runwaysdk.session.InvalidLoginException)1 OauthServer (net.geoprism.account.OauthServer)1 ServerHierarchyTypeBuilder (net.geoprism.registry.conversion.ServerHierarchyTypeBuilder)1 ClassificationType (net.geoprism.registry.model.ClassificationType)1 ServerHierarchyType (net.geoprism.registry.model.ServerHierarchyType)1 XMLImporter (net.geoprism.registry.xml.XMLImporter)1 OAuthClient (org.apache.oltu.oauth2.client.OAuthClient)1 URLConnectionClient (org.apache.oltu.oauth2.client.URLConnectionClient)1 OAuthBearerClientRequest (org.apache.oltu.oauth2.client.request.OAuthBearerClientRequest)1 OAuthClientRequest (org.apache.oltu.oauth2.client.request.OAuthClientRequest)1 TokenRequestBuilder (org.apache.oltu.oauth2.client.request.OAuthClientRequest.TokenRequestBuilder)1 OAuthJSONAccessTokenResponse (org.apache.oltu.oauth2.client.response.OAuthJSONAccessTokenResponse)1 OAuthResourceResponse (org.apache.oltu.oauth2.client.response.OAuthResourceResponse)1 OAuthProblemException (org.apache.oltu.oauth2.common.exception.OAuthProblemException)1 OAuthSystemException (org.apache.oltu.oauth2.common.exception.OAuthSystemException)1 RegistryAdapter (org.commongeoregistry.adapter.RegistryAdapter)1 HierarchyType (org.commongeoregistry.adapter.metadata.HierarchyType)1