|  | /* | 
|  | * 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.httpserver; | 
|  |  | 
|  | import java.io.UnsupportedEncodingException; | 
|  | import java.net.InetAddress; | 
|  | import java.net.MalformedURLException; | 
|  | import java.net.URL; | 
|  | import java.net.URLEncoder; | 
|  | import java.net.URLDecoder; | 
|  | import java.net.UnknownHostException; | 
|  | import java.util.StringTokenizer; | 
|  | import java.util.logging.Level; | 
|  | import java.util.logging.Logger; | 
|  | import org.openide.filesystems.URLMapper; | 
|  | import org.openide.filesystems.FileObject; | 
|  | import org.openide.util.Exceptions; | 
|  |  | 
|  | /** Implementation of a URLMapper which creates http URLs for fileobjects in the IDE. | 
|  | * Directs the requests for URLs to WrapperServlet. | 
|  | * | 
|  | * @author Petr Jiricka, David Konecny | 
|  | */ | 
|  | @org.openide.util.lookup.ServiceProvider(service=org.openide.filesystems.URLMapper.class) | 
|  | public class HttpServerURLMapper extends URLMapper { | 
|  |  | 
|  | /** Creates a new instance of HttpServerURLMapper */ | 
|  | public HttpServerURLMapper() { | 
|  | } | 
|  |  | 
|  | /** Get an array of FileObjects for this url | 
|  | * @param url to wanted FileObjects | 
|  | * @return a suitable array of FileObjects, or null | 
|  | */ | 
|  | public FileObject[] getFileObjects(URL url) { | 
|  | String path = url.getPath(); | 
|  |  | 
|  | // remove the wrapper servlet URI | 
|  | String wrapper = httpserverSettings().getWrapperBaseURL (); | 
|  | if (path == null || !path.startsWith(wrapper)) | 
|  | return null; | 
|  | path = path.substring(wrapper.length()); | 
|  |  | 
|  | // resource name | 
|  | if (path.startsWith ("/")) path = path.substring (1); // NOI18N | 
|  | if (path.length() == 0) { | 
|  | return new FileObject[0]; | 
|  | } | 
|  | // decode path to EXTERNAL/INTERNAL type of URL | 
|  | URL u = decodeURL(path); | 
|  | if (u == null) { | 
|  | return new FileObject[0]; | 
|  | } | 
|  | return URLMapper.findFileObjects(u); | 
|  | } | 
|  |  | 
|  | private URL decodeURL(String path) { | 
|  | StringTokenizer slashTok = new StringTokenizer(path, "/", true); // NOI18N | 
|  | StringBuffer newPath = new StringBuffer(); | 
|  | while (slashTok.hasMoreTokens()) { | 
|  | String tok = slashTok.nextToken(); | 
|  | if (tok.startsWith("/")) { // NOI18N | 
|  | newPath.append(tok); | 
|  | } else { | 
|  | try { | 
|  | newPath.append(URLDecoder.decode(tok, "UTF-8")); // NOI18N | 
|  | } catch (UnsupportedEncodingException e) { | 
|  | assert false : e; | 
|  | return null; | 
|  | } | 
|  | } | 
|  | } | 
|  |  | 
|  | try { | 
|  | return new URL(newPath.toString()); | 
|  | } catch (MalformedURLException ex) { | 
|  | Exceptions.attachMessage(ex, "using: " + newPath); | 
|  | Exceptions.printStackTrace(ex); | 
|  | return null; | 
|  | } | 
|  | } | 
|  |  | 
|  | /** Get a good URL for this file object which works according to type: | 
|  | * -inside this VM | 
|  | * - inside this machine | 
|  | * - from networked machines | 
|  | * @return a suitable URL, or null | 
|  | */ | 
|  | public URL getURL(FileObject fileObject, int type) { | 
|  |  | 
|  | // only do external and network URLs | 
|  | if (type != URLMapper.NETWORK) | 
|  | return null; | 
|  |  | 
|  | // fileObject must not be null | 
|  | if (fileObject == null) | 
|  | return null; | 
|  |  | 
|  | // It should be OK to call URLMapper here because we call | 
|  | // it with different then NETWORK type. | 
|  | URL u = URLMapper.findURL(fileObject, URLMapper.EXTERNAL); | 
|  | if (u == null) { | 
|  | // if EXTERNAL type is not available try the INTERNAL one | 
|  | u = URLMapper.findURL(fileObject, URLMapper.INTERNAL); | 
|  | if (u == null) { | 
|  | return null; | 
|  | } | 
|  | } | 
|  | String path = encodeURL(u); | 
|  | HttpServerSettings settings = httpserverSettings(); | 
|  | settings.setRunning(true); | 
|  | try { | 
|  | URL newURL = new URL("http",   // NOI18N | 
|  | getLocalHost(), | 
|  | settings.getPort(), | 
|  | settings.getWrapperBaseURL() + path); // NOI18N | 
|  | return newURL; | 
|  | } catch (MalformedURLException e) { | 
|  | Logger.getLogger("global").log(Level.WARNING, null, e); | 
|  | return null; | 
|  | } | 
|  | } | 
|  |  | 
|  | private String encodeURL(URL u) { | 
|  | String orig = u.toExternalForm(); | 
|  | StringTokenizer slashTok = new StringTokenizer(orig, "/", true); // NOI18N | 
|  | StringBuffer path = new StringBuffer(); | 
|  | while (slashTok.hasMoreTokens()) { | 
|  | String tok = slashTok.nextToken(); | 
|  | if (tok.startsWith("/")) { // NOI18N | 
|  | path.append(tok); | 
|  | } else { | 
|  | try { | 
|  | path.append(URLEncoder.encode(tok, "UTF-8")); // NOI18N | 
|  | } catch (UnsupportedEncodingException e) { | 
|  | assert false : e; | 
|  | return null; | 
|  | } | 
|  | } | 
|  | } | 
|  | return path.toString(); | 
|  | } | 
|  |  | 
|  | /** Returns string for localhost */ | 
|  | private static String getLocalHost() { | 
|  | try { | 
|  | return InetAddress.getLocalHost().getHostName(); | 
|  | } catch (UnknownHostException e) { | 
|  | return "127.0.0.1"; // NOI18N | 
|  | } | 
|  | } | 
|  |  | 
|  | /** | 
|  | * Obtains settings of this module | 
|  | */ | 
|  | static HttpServerSettings httpserverSettings () { | 
|  | return HttpServerSettings.getDefault(); | 
|  | } | 
|  |  | 
|  | } |