001/* 002 * #%L 003 * HAPI FHIR - Core Library 004 * %% 005 * Copyright (C) 2014 - 2025 Smile CDR, Inc. 006 * %% 007 * Licensed under the Apache License, Version 2.0 (the "License"); 008 * you may not use this file except in compliance with the License. 009 * You may obtain a copy of the License at 010 * 011 * http://www.apache.org/licenses/LICENSE-2.0 012 * 013 * Unless required by applicable law or agreed to in writing, software 014 * distributed under the License is distributed on an "AS IS" BASIS, 015 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 016 * See the License for the specific language governing permissions and 017 * limitations under the License. 018 * #L% 019 */ 020package ca.uhn.fhir.util; 021 022import ca.uhn.fhir.system.HapiSystemProperties; 023import org.apache.commons.lang3.StringUtils; 024 025import java.io.InputStream; 026import java.util.Properties; 027 028import static org.apache.commons.lang3.StringUtils.defaultIfBlank; 029 030/** 031 * Used internally by HAPI to log the version of the HAPI FHIR framework 032 * once, when the framework is first loaded by the classloader. 033 */ 034public class VersionUtil { 035 036 private static final org.slf4j.Logger ourLog = org.slf4j.LoggerFactory.getLogger(VersionUtil.class); 037 private static String ourVersion; 038 private static String ourBuildNumber; 039 private static String ourBuildTime; 040 private static boolean ourSnapshot; 041 042 static { 043 initialize(); 044 } 045 046 public static boolean isSnapshot() { 047 return ourSnapshot; 048 } 049 050 public static String getBuildNumber() { 051 return ourBuildNumber; 052 } 053 054 public static String getBuildTime() { 055 return ourBuildTime; 056 } 057 058 public static String getVersion() { 059 return ourVersion; 060 } 061 062 private static void initialize() { 063 try (InputStream is = VersionUtil.class.getResourceAsStream("/ca/uhn/fhir/hapi-fhir-base-build.properties")) { 064 065 Properties p = new Properties(); 066 if (is != null) { 067 p.load(is); 068 } 069 070 ourVersion = p.getProperty("hapifhir.version"); 071 ourVersion = defaultIfBlank(ourVersion, "(unknown)"); 072 073 ourSnapshot = ourVersion.contains("SNAPSHOT"); 074 075 ourBuildNumber = StringUtils.left(p.getProperty("hapifhir.buildnumber"), 10); 076 ourBuildTime = p.getProperty("hapifhir.timestamp"); 077 078 if (!HapiSystemProperties.isSuppressHapiFhirVersionLogEnabled()) { 079 String buildNumber = ourBuildNumber; 080 if (isSnapshot()) { 081 buildNumber = buildNumber + "/" + getBuildDate(); 082 } 083 084 ourLog.info("HAPI FHIR version {} - Rev {}", ourVersion, buildNumber); 085 } 086 087 } catch (Exception e) { 088 ourLog.warn("Unable to determine HAPI version information", e); 089 } 090 } 091 092 public static String getBuildDate() { 093 return ourBuildTime.substring(0, 10); 094 } 095}