From ac1930192133c1e49d5a98f957da9fb926316346 Mon Sep 17 00:00:00 2001 From: Klaas Dellschaft Date: Tue, 13 Sep 2022 13:49:31 +0200 Subject: [PATCH] Enable loading the UserSchemaExtension from a classpath resource, e.g. a file packaged into the application's jar file The change is fully backwards compatible, i.e. the previous method signature `buildUserSchemaExtension(String configFilePath)` is still available, and it behaves the same as before. Only a new method `buildUserSchemaExtension(InputStream inputStream)` has been made available. --- .../SCIMUserSchemaExtensionBuilder.java | 33 ++++++++++++------- 1 file changed, 21 insertions(+), 12 deletions(-) diff --git a/modules/charon-core/src/main/java/org/wso2/charon3/core/config/SCIMUserSchemaExtensionBuilder.java b/modules/charon-core/src/main/java/org/wso2/charon3/core/config/SCIMUserSchemaExtensionBuilder.java index af56b7cdd..26ef1afc2 100644 --- a/modules/charon-core/src/main/java/org/wso2/charon3/core/config/SCIMUserSchemaExtensionBuilder.java +++ b/modules/charon-core/src/main/java/org/wso2/charon3/core/config/SCIMUserSchemaExtensionBuilder.java @@ -56,13 +56,30 @@ public AttributeSchema getExtensionSchema() { return extensionSchema; } + public void buildUserSchemaExtension(String configFilePath) throws CharonException, InternalErrorException { + + File provisioningConfig = new File(configFilePath); + + try (InputStream inputStream = new FileInputStream(provisioningConfig)) { + + buildUserSchemaExtension(inputStream); + + } catch (FileNotFoundException e) { + throw new CharonException(SCIMConfigConstants.SCIM_SCHEMA_EXTENSION_CONFIG + " file not found!", + e); + } catch (IOException e) { + throw new CharonException("Error while closing " + + SCIMConfigConstants.SCIM_SCHEMA_EXTENSION_CONFIG + " file!", e); + } + } + /* * Logic goes here * @throws CharonException */ - public void buildUserSchemaExtension(String configFilePath) throws CharonException, InternalErrorException { + public void buildUserSchemaExtension(InputStream inputStream) throws CharonException, InternalErrorException { - readConfiguration(configFilePath); + readConfiguration(inputStream); for (Map.Entry attributeSchemaConfig : extensionConfig.entrySet()) { // if there are no children its a simple attribute, build it @@ -88,11 +105,9 @@ public void buildUserSchemaExtension(String configFilePath) throws CharonExcepti * @param configFilePath * @throws CharonException */ - private void readConfiguration(String configFilePath) throws CharonException { + private void readConfiguration(InputStream inputStream) throws CharonException { - File provisioningConfig = new File(configFilePath); - try (InputStream inputStream = new FileInputStream(provisioningConfig)) { - //Scanner scanner = new Scanner(new FileInputStream(provisioningConfig)); + try { Scanner scanner = new Scanner(inputStream, "utf-8").useDelimiter("\\A"); String jsonString = scanner.hasNext() ? scanner.next() : ""; @@ -112,15 +127,9 @@ private void readConfiguration(String configFilePath) throws CharonException { extensionRootAttributeName = schemaAttributeConfig.getName(); } } - } catch (FileNotFoundException e) { - throw new CharonException(SCIMConfigConstants.SCIM_SCHEMA_EXTENSION_CONFIG + " file not found!", - e); } catch (JSONException e) { throw new CharonException("Error while parsing " + SCIMConfigConstants.SCIM_SCHEMA_EXTENSION_CONFIG + " file!", e); - } catch (IOException e) { - throw new CharonException("Error while closing " + - SCIMConfigConstants.SCIM_SCHEMA_EXTENSION_CONFIG + " file!", e); } }