Skip to content

Commit

Permalink
Merge pull request #281 from savage-engineer/master
Browse files Browse the repository at this point in the history
Better version detection of Payara Server
  • Loading branch information
rhuss committed Oct 4, 2016
2 parents a3b57c9 + b600795 commit 12ab616
Showing 1 changed file with 30 additions and 4 deletions.
Expand Up @@ -38,8 +38,18 @@
*/
public class GlassfishDetector extends AbstractServerDetector {

private static final Pattern GLASSFISH_VERSION = Pattern.compile("^.*(?:Glassfish|Payara).*\\sv?(.*?)$",Pattern.CASE_INSENSITIVE);
private static final Pattern GLASSFISH_FULL_VERSION = Pattern.compile("^.*(?:Glassfish|Payara).*?\\sv?([.\\d]+).*$",Pattern.CASE_INSENSITIVE);
private static final Pattern GLASSFISH_VERSION = Pattern.compile("^.*Glassfish.*\\sv?(.*?)$",Pattern.CASE_INSENSITIVE);
private static final Pattern GLASSFISH_FULL_VERSION = Pattern.compile("^.*Glassfish.*?\\sv?([.\\d]+).*$",Pattern.CASE_INSENSITIVE);
private static final Pattern PAYARA_VERSION = Pattern.compile("^.*Payara.*\\sv?(.*?)$",Pattern.CASE_INSENSITIVE);
private static final Pattern PAYARA_FULL_VERSION = Pattern.compile("^.*Payara.*?\\sv?([.\\d]+).*$",Pattern.CASE_INSENSITIVE);

private static final String GLASSFISH_NAME = "glassfish";
private static final String GLASSFISH_VENDOR_NAME = "Oracle";
private static final String PAYARA_NAME = "Payara Server";
private static final String PAYARA_VENDOR_NAME = "Payara Foundation";

private String serverName;
private String vendorName;

/** {@inheritDoc}
* @param pMBeanServerExecutor*/
Expand Down Expand Up @@ -70,11 +80,20 @@ private String detectVersion(MBeanServerExecutor pMBeanServerExecutor) {
return version;
}

// Tries to match Glassfish first, then Payara Server, updating server and vendor name
private String extractVersionFromFullVersion(String pFullVersion) {
if (pFullVersion != null) {
Matcher matcher = GLASSFISH_VERSION.matcher(pFullVersion);
if (matcher.matches()) {
return matcher.group(1);
serverName = GLASSFISH_NAME;
vendorName = GLASSFISH_VENDOR_NAME;
return matcher.group(1);
}
matcher = PAYARA_VERSION.matcher(pFullVersion);
if (matcher.matches()) {
serverName = PAYARA_NAME;
vendorName = PAYARA_VENDOR_NAME;
return matcher.group(1);
}
}
return null;
Expand Down Expand Up @@ -123,8 +142,15 @@ private String getVersionFromFullVersion(String pOriginalVersion,String pFullVer
return pOriginalVersion;
}
Matcher v3Matcher = GLASSFISH_FULL_VERSION.matcher(pFullVersion);
Matcher payaraMatcher = PAYARA_FULL_VERSION.matcher(pFullVersion);
if (v3Matcher.matches()) {
serverName = GLASSFISH_NAME;
vendorName = GLASSFISH_VENDOR_NAME;
return v3Matcher.group(1);
} else if (payaraMatcher.matches()) {
serverName = PAYARA_NAME;
vendorName = PAYARA_VENDOR_NAME;
return payaraMatcher.group(1);
} else {
return pOriginalVersion;
}
Expand All @@ -141,7 +167,7 @@ private class GlassfishServerHandle extends ServerHandle {
* @param extraInfo extra infos
*/
public GlassfishServerHandle(String version, Map<String, String> extraInfo) {
super("Oracle", "glassfish", version, extraInfo);
super(vendorName, serverName, version, extraInfo);
}

@Override
Expand Down

0 comments on commit 12ab616

Please sign in to comment.