All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.milton.davproxy.adapter.RootFolder Maven / Gradle / Ivy

/*
 * 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 io.milton.davproxy.adapter;

import io.milton.http.Request.Method;
import io.milton.http.*;
import io.milton.http.exceptions.BadRequestException;
import io.milton.http.exceptions.NotAuthorizedException;
import io.milton.http.exceptions.NotFoundException;
import io.milton.http.http11.auth.DigestResponse;
import io.milton.davproxy.content.FolderHtmlContentGenerator;
import io.milton.httpclient.Host;
import io.milton.resource.*;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;

/**
 *
 * @author brad
 */
public class RootFolder implements CollectionResource, GetableResource, DigestResource, PropFindableResource {
    // This is the host name which this resource was resolved on. It is NOT the name
    // of any remote webdav host
    // This is the host name which this resource was resolved on. It is NOT the name
    // of any remote webdav host
    private final String hostName;
    /**
     * These are the root folders we will present to end users, which are the
     * remote webdav hosts being accessed.
     */
    /**
     * These are the root folders we will present to end users, which are the
     * remote webdav hosts being accessed.
     */
    private final Map roots;
    private final RemoteDavResourceFactory davResourceFactory;
    private final FolderHtmlContentGenerator contentGenerator;
    private final io.milton.http.SecurityManager securityManager;
    private final RemoteManager remoteManager;

    public RootFolder(String host, Map roots, final RemoteDavResourceFactory davResourceFactory, FolderHtmlContentGenerator contentGenerator, io.milton.http.SecurityManager securityManager, RemoteManager remoteManager) {
        this.davResourceFactory = davResourceFactory;
        this.contentGenerator = contentGenerator;
        this.securityManager = securityManager;
        this.remoteManager = remoteManager;
        this.hostName = host;
        this.roots = roots;
    }

    @Override
    public Resource child(String childName) {
        Host h = roots.get(childName);
        if (h == null) {
            return null;
        } else {
            return new MappedHostResourceAdapter(childName, h, securityManager, hostName, contentGenerator, remoteManager);
        }
    }

    @Override
    public List getChildren() {
        List list = new ArrayList<>();
        for (Entry root : roots.entrySet()) {
            MappedHostResourceAdapter mappedHost = new MappedHostResourceAdapter(root.getKey(), root.getValue(), securityManager, hostName, contentGenerator, remoteManager);
            list.add(mappedHost);
        }
        return list;
    }

    @Override
    public String getUniqueId() {
        return null;
    }

    @Override
    public String getName() {
        return "";
    }

    @Override
    public Object authenticate(String user, String password) {
        return securityManager.authenticate(user, password);
    }

    @Override
    public boolean authorise(Request request, Method method, Auth auth) {
        return securityManager.authorise(request, method, auth, this);
    }

    @Override
    public String getRealm() {
        return securityManager.getRealm(hostName);
    }

    @Override
    public Date getModifiedDate() {
        return null;
    }

    @Override
    public String checkRedirect(Request request) {
        return null;
    }

    @Override
    public void sendContent(OutputStream out, Range range, Map params, String contentType) throws IOException, NotAuthorizedException, BadRequestException, NotFoundException {
        String uri = HttpManager.request().getAbsolutePath();
        contentGenerator.generateContent(this, out, uri);
    }

    @Override
    public Long getMaxAgeSeconds(Auth auth) {
        return null;
    }

    @Override
    public String getContentType(String accepts) {
        return "text/html";
    }

    @Override
    public Long getContentLength() {
        return null;
    }

    @Override
    public Object authenticate(DigestResponse digestRequest) {
        return securityManager.authenticate(digestRequest);
    }

    @Override
    public boolean isDigestAllowed() {
        return true;
    }

    @Override
    public Date getCreateDate() {
        return null;
    }
    
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy