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

com.disney.uriparcel.ContentStreamStore Maven / Gradle / Ivy

/*******************************************************************************
 * © 2018 Disney | ABC Television Group
 *
 * Licensed under the Apache License, Version 2.0 (the "Apache License")
 * with the following modification; you may not use this file except in
 * compliance with the Apache License and the following modification to it:
 * Section 6. Trademarks. is deleted and replaced with:
 *
 * 6. Trademarks. This License does not grant permission to use the trade
 *     names, trademarks, service marks, or product names of the Licensor
 *     and its affiliates, except as required to comply with Section 4(c) of
 *     the License and to reproduce the content of the NOTICE file.
 *
 * You may obtain a copy of the Apache License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the Apache License with the above modification is
 * distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied. See the Apache License for the specific
 * language governing permissions and limitations under the Apache License.
 *******************************************************************************/
package com.disney.uriparcel;

import java.io.IOException;
import java.util.Map;
/**
 * Core extension API for ContentStreamStores, which are components able to load and store binary streams and associated stream metadata for 
 * some URIs; stream stores are prioritized to ensure predictable fallback order, each store must respond false
 * when asked to load or store an unrecognized URI scheme to allow fallbacks to happen.
 *

* ContentStreamStores are discovered automatically using the Java ServiceLoader mechanism; in order to wire in a custom implementation * you should package it in a jar file with a manifest at "/META-INF/services/com.disney.uriparcel.ContentStreamStore" that lists the * fully qualified class name(s) of your implementation. * * @author Alex Vigdor */ public interface ContentStreamStore extends Comparable{ //given a ContentStream with only a URI, return true if content is considered loaded or valid, false if unable to process boolean load(ContentStream uriContent, Map config) throws IOException; //given a fully populated ContentStream, return true if content is considered stored at the designated URI, false if unable to process boolean store(ContentStream uriContent, Map config) throws IOException; //determines order of attempts; more specific loaders, e.g. specific protocols, //should take higher priority (e.g. 100), while more general-purpose loaders //like url should take lower priority (e.g. 1) int getPriority(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy