Browse Source
Extract useful logic from StartupInfoLogger to a new ApplicationHome class. Fixes gh-1414pull/1433/head
2 changed files with 121 additions and 31 deletions
@ -0,0 +1,118 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2012-2014 the original author or authors. |
||||||
|
* |
||||||
|
* 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. |
||||||
|
*/ |
||||||
|
|
||||||
|
package org.springframework.boot; |
||||||
|
|
||||||
|
import java.io.File; |
||||||
|
import java.io.IOException; |
||||||
|
import java.net.JarURLConnection; |
||||||
|
import java.net.URL; |
||||||
|
import java.net.URLConnection; |
||||||
|
import java.security.CodeSource; |
||||||
|
import java.security.ProtectionDomain; |
||||||
|
|
||||||
|
import org.springframework.util.StringUtils; |
||||||
|
|
||||||
|
/** |
||||||
|
* Provides access to the application home directory. Attempts to pick a sensible home for |
||||||
|
* both Jar Files, Exploded Archives and directly running applications. |
||||||
|
* |
||||||
|
* @author Phillip Webb |
||||||
|
* @since 1.1.2 |
||||||
|
*/ |
||||||
|
public class ApplicationHome { |
||||||
|
|
||||||
|
private final File source; |
||||||
|
|
||||||
|
private final File dir; |
||||||
|
|
||||||
|
/** |
||||||
|
* Create a new {@link ApplicationHome} instance. |
||||||
|
*/ |
||||||
|
public ApplicationHome() { |
||||||
|
this(null); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* Create a new {@link ApplicationHome} instance for the specified source class. |
||||||
|
* @param sourceClass the source class or {@code null} |
||||||
|
*/ |
||||||
|
public ApplicationHome(Class<?> sourceClass) { |
||||||
|
this.source = findSource(sourceClass == null ? getClass() : sourceClass); |
||||||
|
this.dir = findHomeDir(this.source); |
||||||
|
} |
||||||
|
|
||||||
|
private File findSource(Class<?> sourceClass) { |
||||||
|
try { |
||||||
|
ProtectionDomain protectionDomain = sourceClass.getProtectionDomain(); |
||||||
|
CodeSource codeSource = protectionDomain.getCodeSource(); |
||||||
|
URL location = (codeSource == null ? null : codeSource.getLocation()); |
||||||
|
File source = (location == null ? null : findSource(location)); |
||||||
|
if (source != null && source.exists()) { |
||||||
|
return source.getAbsoluteFile(); |
||||||
|
} |
||||||
|
} |
||||||
|
catch (Exception ex) { |
||||||
|
} |
||||||
|
return null; |
||||||
|
} |
||||||
|
|
||||||
|
private File findSource(URL location) throws IOException { |
||||||
|
URLConnection connection = location.openConnection(); |
||||||
|
if (connection instanceof JarURLConnection) { |
||||||
|
return new File(((JarURLConnection) connection).getJarFile().getName()); |
||||||
|
} |
||||||
|
return new File(location.getPath()); |
||||||
|
} |
||||||
|
|
||||||
|
private File findHomeDir(File source) { |
||||||
|
File homeDir = source; |
||||||
|
homeDir = (homeDir == null ? findDefaultHomeDir() : homeDir); |
||||||
|
if (homeDir.isFile()) { |
||||||
|
homeDir = homeDir.getParentFile(); |
||||||
|
} |
||||||
|
homeDir = (homeDir.exists() ? homeDir : new File(".")); |
||||||
|
return homeDir.getAbsoluteFile(); |
||||||
|
} |
||||||
|
|
||||||
|
private File findDefaultHomeDir() { |
||||||
|
String userDir = System.getProperty("user.dir"); |
||||||
|
return new File(StringUtils.hasLength(userDir) ? userDir : "."); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* Returns the underlying source used to find the home folder. This is usually the jar |
||||||
|
* file or a directory. Can return {@code null} if the source cannot be determined. |
||||||
|
* @return the underlying source or {@code null} |
||||||
|
*/ |
||||||
|
public File getSource() { |
||||||
|
return this.source; |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* Returns the application home folder. |
||||||
|
* @return the home folder (never {@code null}) |
||||||
|
*/ |
||||||
|
public File getDir() { |
||||||
|
return this.dir; |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public String toString() { |
||||||
|
return getDir().toString(); |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
Loading…
Reference in new issue