Use classes from policy/common 53/127153/2
authorRam Krishna Verma <ram_krishna.verma@bell.ca>
Wed, 16 Feb 2022 17:12:20 +0000 (12:12 -0500)
committerAjith Sreekumar <ajith.sreekumar@bell.ca>
Thu, 17 Feb 2022 16:20:38 +0000 (16:20 +0000)
Use YamlHttpMessageConverter from policy/common.
Use CustomImplicitNamingStrategy from policy/common.
Fix few sonar issues.

Issue-ID: POLICY-3931
Change-Id: I4720761cbf8da464ec57541f9b19f8d124503e17
Signed-off-by: Ram Krishna Verma <ram_krishna.verma@bell.ca>
main/pom.xml
main/src/main/java/org/onap/policy/pap/main/CustomImplicitNamingStrategy.java [deleted file]
main/src/main/java/org/onap/policy/pap/main/config/WebConfig.java
main/src/main/java/org/onap/policy/pap/main/config/converter/YamlHttpMessageConverter.java [deleted file]
main/src/main/resources/application.yaml
main/src/test/resources/config/application.yaml
packages/policy-pap-tarball/src/main/resources/etc/papParameters.yaml

index 621fb45..06c0334 100644 (file)
             <artifactId>policy-models-pdp</artifactId>
             <version>${policy.models.version}</version>
         </dependency>
+        <dependency>
+            <groupId>org.onap.policy.common</groupId>
+            <artifactId>spring-utils</artifactId>
+            <version>${policy.common.version}</version>
+        </dependency>
         <dependency>
             <groupId>org.onap.policy.common</groupId>
             <artifactId>utils-test</artifactId>
diff --git a/main/src/main/java/org/onap/policy/pap/main/CustomImplicitNamingStrategy.java b/main/src/main/java/org/onap/policy/pap/main/CustomImplicitNamingStrategy.java
deleted file mode 100644 (file)
index 7505039..0000000
+++ /dev/null
@@ -1,36 +0,0 @@
-/*-
- * ============LICENSE_START=======================================================
- *  Copyright (C) 2022 Bell Canada. All rights reserved.
- * ================================================================================
- * 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.
- *
- * SPDX-License-Identifier: Apache-2.0
- * ============LICENSE_END=========================================================
- */
-
-package org.onap.policy.pap.main;
-
-import org.hibernate.boot.model.naming.Identifier;
-import org.hibernate.boot.model.naming.ImplicitJoinColumnNameSource;
-import org.hibernate.boot.model.naming.ImplicitNamingStrategyJpaCompliantImpl;
-
-public class CustomImplicitNamingStrategy extends ImplicitNamingStrategyJpaCompliantImpl {
-
-    private static final long serialVersionUID = 8666774028328486896L;
-
-    @Override
-    public Identifier determineJoinColumnName(ImplicitJoinColumnNameSource source) {
-        String name = source.getReferencedColumnName().getText();
-        return toIdentifier(name, source.getBuildingContext());
-    }
-}
index 751ca61..d8aee3a 100644 (file)
@@ -22,7 +22,7 @@ package org.onap.policy.pap.main.config;
 
 import java.util.Arrays;
 import java.util.List;
-import org.onap.policy.pap.main.config.converter.YamlHttpMessageConverter;
+import org.onap.policy.common.spring.utils.YamlHttpMessageConverter;
 import org.springframework.context.annotation.Configuration;
 import org.springframework.http.MediaType;
 import org.springframework.http.converter.HttpMessageConverter;
@@ -36,7 +36,7 @@ public class WebConfig implements WebMvcConfigurer {
 
     @Override
     public void extendMessageConverters(List<HttpMessageConverter<?>> converters) {
-        YamlHttpMessageConverter yamlConverter = new YamlHttpMessageConverter();
+        var yamlConverter = new YamlHttpMessageConverter();
         yamlConverter.setSupportedMediaTypes(Arrays.asList(MediaType.parseMediaType("application/yaml")));
         converters.add(yamlConverter);
     }
diff --git a/main/src/main/java/org/onap/policy/pap/main/config/converter/YamlHttpMessageConverter.java b/main/src/main/java/org/onap/policy/pap/main/config/converter/YamlHttpMessageConverter.java
deleted file mode 100644 (file)
index 5678b83..0000000
+++ /dev/null
@@ -1,109 +0,0 @@
-/*-
- * ============LICENSE_START=======================================================
- *  Copyright (C) 2022 Bell Canada. All rights reserved.
- * ================================================================================
- * 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.
- *
- * SPDX-License-Identifier: Apache-2.0
- * ============LICENSE_END=========================================================
- */
-
-package org.onap.policy.pap.main.config.converter;
-
-import java.io.IOException;
-import java.io.InputStreamReader;
-import java.io.OutputStreamWriter;
-import java.io.Reader;
-import java.io.Writer;
-import java.lang.reflect.Type;
-import java.nio.charset.Charset;
-import java.nio.charset.StandardCharsets;
-import org.onap.policy.common.utils.coder.YamlJsonTranslator;
-import org.springframework.core.GenericTypeResolver;
-import org.springframework.http.HttpHeaders;
-import org.springframework.http.HttpInputMessage;
-import org.springframework.http.HttpOutputMessage;
-import org.springframework.http.MediaType;
-import org.springframework.http.converter.AbstractGenericHttpMessageConverter;
-import org.springframework.http.converter.HttpMessageNotReadableException;
-import org.springframework.http.converter.HttpMessageNotWritableException;
-import org.springframework.lang.Nullable;
-
-/**
- * Custom converter to marshal/unmarshall data structured with YAML media type.
- */
-public class YamlHttpMessageConverter extends AbstractGenericHttpMessageConverter<Object> {
-
-    public static final Charset DEFAULT_CHARSET = StandardCharsets.UTF_8;
-
-    private static final YamlJsonTranslator TRANSLATOR = new YamlJsonTranslator();
-
-    public YamlHttpMessageConverter() {
-        super(new MediaType("application", "yaml"));
-        setDefaultCharset(DEFAULT_CHARSET);
-    }
-
-    @Override
-    public final Object read(Type type, @Nullable Class<?> contextClass, HttpInputMessage inputMessage)
-        throws IOException {
-        return readResolved(GenericTypeResolver.resolveType(type, contextClass), inputMessage);
-    }
-
-    @Override
-    protected final Object readInternal(Class<?> clazz, HttpInputMessage inputMessage) throws IOException {
-        return readResolved(clazz, inputMessage);
-    }
-
-    private Object readInternal(Type resolvedType, Reader reader) {
-        Class<?> clazz = (Class<?>) resolvedType;
-        return TRANSLATOR.fromYaml(reader, clazz);
-    }
-
-    @Override
-    protected final void writeInternal(Object object, @Nullable Type type, HttpOutputMessage outputMessage)
-        throws IOException {
-        var writer = getWriter(outputMessage);
-        try {
-            writeInternal(object, type, writer);
-        } catch (Exception ex) {
-            throw new HttpMessageNotWritableException("Could not write YAML: " + ex.getMessage(), ex);
-        }
-        writer.flush();
-    }
-
-    private void writeInternal(Object object, @Nullable Type type, Writer writer) {
-        TRANSLATOR.toYaml(writer, object);
-    }
-
-    private Object readResolved(Type resolvedType, HttpInputMessage inputMessage) throws IOException {
-        var reader = getReader(inputMessage);
-        try {
-            return readInternal(resolvedType, reader);
-        } catch (Exception ex) {
-            throw new HttpMessageNotReadableException("Could not read YAML: " + ex.getMessage(), ex, inputMessage);
-        }
-    }
-
-    private static Reader getReader(HttpInputMessage inputMessage) throws IOException {
-        return new InputStreamReader(inputMessage.getBody(), getCharset(inputMessage.getHeaders()));
-    }
-
-    private static Writer getWriter(HttpOutputMessage outputMessage) throws IOException {
-        return new OutputStreamWriter(outputMessage.getBody(), getCharset(outputMessage.getHeaders()));
-    }
-
-    private static Charset getCharset(HttpHeaders headers) {
-        Charset charset = (headers.getContentType() == null ? null : headers.getContentType().getCharset());
-        return (charset != null ? charset : DEFAULT_CHARSET);
-    }
-}
\ No newline at end of file
index d6111aa..2b6d8fc 100644 (file)
@@ -19,7 +19,7 @@ spring:
       ddl-auto: none
       naming:
         physical-strategy: org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl
-        implicit-strategy: org.onap.policy.pap.main.CustomImplicitNamingStrategy
+        implicit-strategy: org.onap.policy.common.spring.utils.CustomImplicitNamingStrategy
 
 server:
   port: 6969
index b9579db..b6a497a 100644 (file)
@@ -17,7 +17,7 @@ spring:
       ddl-auto: update
       naming:
         physical-strategy: org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl
-        implicit-strategy: org.onap.policy.pap.main.CustomImplicitNamingStrategy
+        implicit-strategy: org.onap.policy.common.spring.utils.CustomImplicitNamingStrategy
 
 server:
   port: 6969
index 9bfb5c0..0c37b46 100644 (file)
@@ -19,7 +19,7 @@ spring:
       ddl-auto: none
       naming:
         physical-strategy: org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl
-        implicit-strategy: org.onap.policy.pap.main.CustomImplicitNamingStrategy
+        implicit-strategy: org.onap.policy.common.spring.utils.CustomImplicitNamingStrategy
 
 server:
   port: 6969