001/**
002 * Licensed to the Apache Software Foundation (ASF) under one or more
003 * contributor license agreements.  See the NOTICE file distributed with
004 * this work for additional information regarding copyright ownership.
005 * The ASF licenses this file to You under the Apache License, Version 2.0
006 * (the "License"); you may not use this file except in compliance with
007 * the License.  You may obtain a copy of the License at
008 *
009 *      http://www.apache.org/licenses/LICENSE-2.0
010 *
011 * Unless required by applicable law or agreed to in writing, software
012 * distributed under the License is distributed on an "AS IS" BASIS,
013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
014 * See the License for the specific language governing permissions and
015 * limitations under the License.
016 */
017package org.apache.camel.model;
018
019import java.util.ArrayList;
020import java.util.List;
021
022import javax.xml.bind.annotation.XmlAccessType;
023import javax.xml.bind.annotation.XmlAccessorType;
024import javax.xml.bind.annotation.XmlElement;
025import javax.xml.bind.annotation.XmlRootElement;
026
027import org.apache.camel.spi.Metadata;
028
029/**
030 * Scans for Java {@link org.apache.camel.builder.RouteBuilder} classes in java packages
031 */
032@Metadata(label = "configuration")
033@XmlRootElement(name = "packageScan")
034@XmlAccessorType(XmlAccessType.FIELD)
035public class PackageScanDefinition {
036    @XmlElement(name = "package", required = true)
037    private List<String> packages = new ArrayList<>();
038    @XmlElement
039    private List<String> excludes = new ArrayList<>();
040    @XmlElement
041    private List<String> includes = new ArrayList<>();
042
043    public PackageScanDefinition() {
044    }
045
046    public List<String> getExcludes() {
047        return excludes;
048    }
049
050    public List<String> getIncludes() {
051        return includes;
052    }
053
054    public List<String> getPackages() {
055        return packages;
056    }
057
058    /**
059     * Sets the java package names to use for scanning for route builder classes
060     */
061    public void setPackages(List<String> packages) {
062        this.packages = packages;
063    }
064
065    /**
066     * Exclude finding route builder from these java package names.
067     */
068    public void setExcludes(List<String> excludes) {
069        this.excludes = excludes;
070    }
071
072    /**
073     * Include finding route builder from these java package names.
074     */
075    public void setIncludes(List<String> includes) {
076        this.includes = includes;
077    }
078
079    protected void clear() {
080        packages.clear();
081        excludes.clear();
082        includes.clear();
083    }
084}