| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you 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. |
| */ |
| package org.netbeans.modules.payara.tooling.server; |
| |
| import java.util.concurrent.atomic.AtomicReferenceArray; |
| import org.netbeans.modules.payara.tooling.data.PayaraVersion; |
| |
| /** |
| * Payara server JPA support matrix. |
| * <p/> |
| * @author Tomas Kraus |
| */ |
| public class JpaSupport { |
| |
| //////////////////////////////////////////////////////////////////////////// |
| // Inner classes // |
| //////////////////////////////////////////////////////////////////////////// |
| |
| /** |
| * Individual JPA specifications support. |
| */ |
| public static class ApiVersion { |
| |
| //////////////////////////////////////////////////////////////////////// |
| // Class attributes // |
| //////////////////////////////////////////////////////////////////////// |
| |
| /** JPA 1.0 supported. */ |
| final boolean _1_0; |
| |
| /** JPA 2.0 supported. */ |
| final boolean _2_0; |
| |
| /** JPA 2.1 supported. */ |
| final boolean _2_1; |
| |
| /** JPA provider class. */ |
| final String provider; |
| |
| //////////////////////////////////////////////////////////////////////// |
| // Constructors // |
| //////////////////////////////////////////////////////////////////////// |
| |
| /** |
| * Creates an instance of individual JPA specifications support class. |
| * <p/> |
| * @param jpa_1_0 JPA 1.0 supported. |
| * @param jpa_2_0 JPA 2.0 supported. |
| * @param jpa_2_1 JPA 2.1 supported. |
| * @param provider JPA provider class. |
| */ |
| ApiVersion(boolean jpa_1_0, boolean jpa_2_0, |
| boolean jpa_2_1, String provider) { |
| this._1_0 = jpa_1_0; |
| this._2_0 = jpa_2_0; |
| this._2_1 = jpa_2_1; |
| this.provider = provider; |
| } |
| |
| //////////////////////////////////////////////////////////////////////// |
| // Getters and setters // |
| //////////////////////////////////////////////////////////////////////// |
| |
| /** |
| * Is JPA 1.0 supported. |
| * <p/> |
| * @return Value of <code>true</code> when JPA 1.0 supported |
| * or <code>false</code> otherwise. |
| */ |
| public boolean is10() { |
| return _1_0; |
| } |
| |
| /** |
| * Is JPA 2.0 supported. |
| * <p/> |
| * @return Value of <code>true</code> when JPA 2.0 supported |
| * or <code>false</code> otherwise. |
| */ |
| public boolean is20() { |
| return _2_0; |
| } |
| |
| /** |
| * Is JPA 2.1 supported. |
| * <p/> |
| * @return Value of <code>true</code> when JPA 2.1 supported |
| * or <code>false</code> otherwise. |
| */ |
| public boolean is21() { |
| return _2_1; |
| } |
| |
| /** |
| * Get JPA provider class. |
| * <p/> |
| * @return JPA provider class name. |
| */ |
| public String getProvider() { |
| return provider; |
| } |
| |
| } |
| |
| //////////////////////////////////////////////////////////////////////////// |
| // Class attributes // |
| //////////////////////////////////////////////////////////////////////////// |
| |
| /** Payara server JPA provider class since V1. */ |
| private static final String JPA_PROVIDER_SINCE_V1 |
| = "oracle.toplink.essentials.PersistenceProvider"; |
| |
| /** Payara server JPA provider class since V3. */ |
| private static final String JPA_PROVIDER_SINCE_V3 |
| = "org.eclipse.persistence.jpa.PersistenceProvider"; |
| |
| /** |
| * Payara JPA support matrix:<p/><table> |
| * <tr><th>Payara</th><th>JPA 1.0</th><th>JPA 2.0</th><th>JPA 2.1</th></tr> |
| * <tr><th>V1</th><td>YES</td><td>NO</td><td>NO</td></tr> |
| * <tr><th>V2</th><td>YES</td><td>NO</td><td>NO</td></tr> |
| * <tr><th>V3</th><td>YES</td><td>YES</td><td>NO</td></tr> |
| * <tr><th>V4</th><td>YES</td><td>YES</td><td>YES</td></tr> |
| * </table><p/> |
| * Array is stored as <code>Object[] array</code> internally which |
| * is initialized with all values set to <code>null</code>. |
| */ |
| private static final AtomicReferenceArray<ApiVersion> jpaSupport |
| = new AtomicReferenceArray<>(PayaraVersion.length); |
| |
| //////////////////////////////////////////////////////////////////////////// |
| // Static methods // |
| //////////////////////////////////////////////////////////////////////////// |
| |
| /** |
| * Get Payara JPA support information for given Payara version. |
| * <p/> |
| * @param version Payara version to get JPA support information for. |
| * @return Payara JPA support information for given Payara version. |
| */ |
| public static ApiVersion getApiVersion(PayaraVersion version) { |
| ApiVersion apiVersion = jpaSupport.get(version.ordinal()); |
| if (apiVersion != null) { |
| return apiVersion; |
| } |
| synchronized(jpaSupport) { |
| apiVersion = jpaSupport.get(version.ordinal()); |
| if (apiVersion == null) { |
| jpaSupport.set(version.ordinal(), new ApiVersion(true,false, |
| version.ordinal() >= PayaraVersion.PF_4_1_144.ordinal(), |
| version.ordinal() < PayaraVersion.PF_4_1_144.ordinal() |
| ? JPA_PROVIDER_SINCE_V1 : JPA_PROVIDER_SINCE_V3)); |
| } |
| } |
| return jpaSupport.get(version.ordinal()); |
| } |
| |
| } |