/* * 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.apache.pdfbox.filter; import java.io.IOException; import java.util.Collection; import java.util.HashMap; import java.util.Map; import org.apache.pdfbox.cos.COSName; /** * This will contain manage all the different types of filters that are available. * * @author <a href="mailto:ben@benlitchfield.com">Ben Litchfield</a> * @version $Revision: 1.13 $ */ public class FilterManager { private Map<COSName, Filter> filters = new HashMap<COSName, Filter>(); /** * Constructor. */ public FilterManager() { Filter flateFilter = new FlateFilter(); Filter dctFilter = new DCTFilter(); Filter ccittFaxFilter = new CCITTFaxDecodeFilter(); Filter lzwFilter = new LZWFilter(); Filter asciiHexFilter = new ASCIIHexFilter(); Filter ascii85Filter = new ASCII85Filter(); Filter runLengthFilter = new RunLengthDecodeFilter(); Filter cryptFilter = new CryptFilter(); Filter jpxFilter = new JPXFilter(); Filter jbig2Filter = new JBIG2Filter(); addFilter( COSName.FLATE_DECODE, flateFilter ); addFilter( COSName.FLATE_DECODE_ABBREVIATION, flateFilter ); addFilter( COSName.DCT_DECODE, dctFilter ); addFilter( COSName.DCT_DECODE_ABBREVIATION, dctFilter ); addFilter( COSName.CCITTFAX_DECODE, ccittFaxFilter ); addFilter( COSName.CCITTFAX_DECODE_ABBREVIATION, ccittFaxFilter ); addFilter( COSName.LZW_DECODE, lzwFilter ); addFilter( COSName.LZW_DECODE_ABBREVIATION, lzwFilter ); addFilter( COSName.ASCII_HEX_DECODE, asciiHexFilter ); addFilter( COSName.ASCII_HEX_DECODE_ABBREVIATION, asciiHexFilter ); addFilter( COSName.ASCII85_DECODE, ascii85Filter ); addFilter( COSName.ASCII85_DECODE_ABBREVIATION, ascii85Filter ); addFilter( COSName.RUN_LENGTH_DECODE, runLengthFilter ); addFilter( COSName.RUN_LENGTH_DECODE_ABBREVIATION, runLengthFilter ); addFilter( COSName.CRYPT, cryptFilter ); addFilter( COSName.JPX_DECODE, jpxFilter ); addFilter( COSName.JBIG2_DECODE, jbig2Filter ); } /** * This will get all of the filters that are available in the system. * * @return All available filters in the system. */ public Collection<Filter> getFilters() { return filters.values(); } /** * This will add an available filter. * * @param filterName The name of the filter. * @param filter The filter to use. */ public void addFilter( COSName filterName, Filter filter ) { filters.put( filterName, filter ); } /** * This will get a filter by name. * * @param filterName The name of the filter to retrieve. * * @return The filter that matches the name. * * @throws IOException If the filter could not be found. */ public Filter getFilter( COSName filterName ) throws IOException { Filter filter = (Filter)filters.get( filterName ); if( filter == null ) { throw new IOException( "Unknown stream filter:" + filterName ); } return filter; } /** * This will get a filter by name. * * @param filterName The name of the filter to retrieve. * * @return The filter that matches the name. * * @throws IOException If the filter could not be found. */ public Filter getFilter( String filterName ) throws IOException { return getFilter( COSName.getPDFName( filterName ) ); } }