/* * JBoss, Home of Professional Open Source. * Copyright 2010, Red Hat, Inc., and individual contributors * as indicated by the @author tags. See the copyright.txt file in the * distribution for a full listing of individual contributors. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.jboss.as.controller.services.path; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.PATH; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.RELATIVE_TO; import java.io.File; import java.util.List; import org.jboss.as.controller.logging.ControllerLogger; import org.jboss.dmr.ModelNode; import org.jboss.msc.service.ServiceBuilder; import org.jboss.msc.service.ServiceController; import org.jboss.msc.service.ServiceListener; import org.jboss.msc.service.ServiceName; import org.jboss.msc.service.ServiceTarget; import org.jboss.msc.value.InjectedValue; import org.wildfly.common.Assert; /** * {@link AbstractPathService} implementation for paths that are relative * to other paths. * * @author Brian Stansberry */ public class RelativePathService extends AbstractPathService { private final String relativePath; private final InjectedValue<String> injectedPath = new InjectedValue<String>(); public static ServiceController<String> addService(final String name, final String relativePath, final String relativeTo, final ServiceTarget serviceTarget) { return addService(pathNameOf(name), relativePath, false, relativeTo, serviceTarget, null); } public static ServiceController<String> addService(final String name, final String relativePath, final String relativeTo, final ServiceTarget serviceTarget, final List<ServiceController<?>> newControllers, final ServiceListener... listeners) { return addService(pathNameOf(name), relativePath, false, relativeTo, serviceTarget, newControllers, listeners); } public static ServiceController<String> addService(final ServiceName name, final String relativePath, final String relativeTo, final ServiceTarget serviceTarget) { return addService(name, relativePath, false, relativeTo, serviceTarget, null); } /** * Installs a path service. * * @param name the name to use for the service * @param path the relative portion of the path * @param possiblyAbsolute {@code true} if {@code path} may be an {@link #isAbsoluteUnixOrWindowsPath(String) absolute path} * and should be {@link AbsolutePathService installed as such} if it is, with any * {@code relativeTo} parameter ignored * @param relativeTo the name of the path that {@code path} may be relative to * @param serviceTarget the {@link ServiceTarget} to use to install the service * @param newControllers list of service controllers that are being installed as part of the operation that has * led to this invocation. May be {@code null}. If not {@code null} the returned * ServiceController will be added to this list * @param listeners listeners to add to the service. May be {@code null} * @return the ServiceController for the path service */ public static ServiceController<String> addService(final ServiceName name, final String path, boolean possiblyAbsolute, final String relativeTo, final ServiceTarget serviceTarget, final List<ServiceController<?>> newControllers, final ServiceListener... listeners) { if (possiblyAbsolute && isAbsoluteUnixOrWindowsPath(path)) { return AbsolutePathService.addService(name, path, serviceTarget, newControllers, listeners); } RelativePathService service = new RelativePathService(path); ServiceBuilder<String> builder = serviceTarget.addService(name, service) .addDependency(pathNameOf(relativeTo), String.class, service.injectedPath); if (listeners != null) { for (ServiceListener listener : listeners) { builder.addListener(listener); } } ServiceController<String> svc = builder.install(); if (newControllers != null) { newControllers.add(svc); } return svc; } public static void addService(final ServiceName name, final ModelNode element, final ServiceTarget serviceTarget) { final String relativePath = element.require(PATH).asString(); final String relativeTo = element.require(RELATIVE_TO).asString(); addService(name, relativePath, false, relativeTo, serviceTarget, null); } static String convertPath(String relativePath) { Assert.checkNotNullParam("relativePath", relativePath); Assert.checkNotEmptyParam("relativePath", relativePath); if (relativePath.charAt(0) == '/') { if (relativePath.length() == 1) { throw ControllerLogger.ROOT_LOGGER.invalidRelativePathValue(relativePath); } return relativePath.substring(1); } else if (relativePath.indexOf(":\\") == 1) { throw ControllerLogger.ROOT_LOGGER.pathIsAWindowsAbsolutePath(relativePath); } else { if(isWindows()) { return relativePath.replace("/", File.separator); } else { return relativePath.replace("\\", File.separator); } } } static String doResolve(String base, String relativePath) { base = base.endsWith(File.separator) ? base.substring(0, base.length() -1) : base; return base + File.separatorChar + relativePath; } public RelativePathService(final String relativePath) { this.relativePath = convertPath(relativePath); } @Override protected String resolvePath() { return doResolve(injectedPath.getValue(), relativePath); } private static boolean isWindows(){ return File.separatorChar == '\\'; } }