/** * 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.camel.model.dataformat; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlAttribute; import javax.xml.bind.annotation.XmlRootElement; import org.apache.camel.CamelContext; import org.apache.camel.model.DataFormatDefinition; import org.apache.camel.spi.DataFormat; import org.apache.camel.spi.Metadata; /** * Zip-file data format */ @Metadata(firstVersion = "2.11.0", label = "dataformat,transformation,file", title = "Zip File") // TODO: use zipfile as name in Camel 3.0 @XmlRootElement(name = "zipFile") @XmlAccessorType(XmlAccessType.FIELD) public class ZipFileDataFormat extends DataFormatDefinition { @XmlAttribute private Boolean usingIterator; @XmlAttribute private Boolean allowEmptyDirectory; public ZipFileDataFormat() { super("zipfile"); } @Override protected void configureDataFormat(DataFormat dataFormat, CamelContext camelContext) { if (usingIterator != null) { setProperty(camelContext, dataFormat, "usingIterator", usingIterator); } if (allowEmptyDirectory != null) { setProperty(camelContext, dataFormat, "allowEmptyDirectory", allowEmptyDirectory); } } public Boolean getUsingIterator() { return usingIterator; } public Boolean getAllowEmptyDirectory() { return allowEmptyDirectory; } /** * If the zip file has more then one entry, the setting this option to true, allows to work with the splitter EIP, * to split the data using an iterator in a streaming mode. */ public void setUsingIterator(Boolean usingIterator) { this.usingIterator = usingIterator; } /** * If the zip file has more then one entry, setting this option to true, allows to get the iterator * even if the directory is empty */ public void setAllowEmptyDirectory(Boolean allowEmptyDirectory) { this.allowEmptyDirectory = allowEmptyDirectory; } }