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

org.duracloud.sync.endpoint.SyncEndpoint Maven / Gradle / Ivy

/*
 * The contents of this file are subject to the license and copyright
 * detailed in the LICENSE and NOTICE files at the root of the source
 * tree and available online at
 *
 *     http://duracloud.org/license/
 */
package org.duracloud.sync.endpoint;

import java.io.File;
import java.util.Iterator;

import org.duracloud.error.ContentStoreException;

/**
 * Endpoint to which files are synchronized.
 *
 * @author: Bill Branan
 * Date: Mar 17, 2010
 */
public interface SyncEndpoint {

    /**
     * Ensures that the endpoint includes a file equivalent to the provided
     * local file:
     * - If the local file exists but no file with the same path exists at
     * the endpoint, the local file will be copied to the endpoint
     * - If the local file exists and is different from a file with the same
     * path at the endpoint, the local file will replace the file at the
     * endpoint.
     * - If the local file does not exist (it has been deleted), a file with
     * the same path will be removed at the endpoint (if it exists)
     *
     * @param file     local file to sync with the endpoint
     * @param watchDir the directory under watch in which this file resides
     * @return true if file was successfully synced, false otherwise
     */
    public boolean syncFile(MonitoredFile file, File watchDir);

    /**
     * Retrieves a listing of all files available at the endpoint. This list
     * is to be used for comparison with the local system.
     *
     * @return Iterator allowing access to complete file listing
     */
    public Iterator getFilesList();

    /**
     * Registers a listener
     *
     * @param listener
     */
    public void addEndPointListener(EndPointListener listener);

    /**
     * Unregisters a listener
     *
     * @param listener
     */
    public void removeEndPointListener(EndPointListener listener);

    /**
     * An alternate form of the syncFile method that returns a more nuanced result.
     *
     * @param monitoredFile
     * @param watchDir
     * @return
     */
    public SyncResultType syncFileAndReturnDetailedResult(MonitoredFile monitoredFile,
                                                          File watchDir);

    /**
     * Removes content from the endpoint.
     *
     * @param spaceId
     * @param contentId
     */
    public void deleteContent(String spaceId, String contentId) throws ContentStoreException;

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy