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.XmlAttribute;
025import javax.xml.bind.annotation.XmlElement;
026import javax.xml.bind.annotation.XmlRootElement;
027
028import org.apache.camel.spi.Metadata;
029
030/**
031 * Scans for Java {@link org.apache.camel.builder.RouteBuilder} instances in the
032 * context {@link org.apache.camel.spi.Registry}.
033 */
034@Metadata(label = "configuration")
035@XmlRootElement(name = "contextScan")
036@XmlAccessorType(XmlAccessType.FIELD)
037public class ContextScanDefinition {
038    @XmlAttribute
039    @Metadata(javaType = "java.lang.Boolean")
040    private String includeNonSingletons;
041    @XmlElement(name = "excludes")
042    private List<String> excludes = new ArrayList<>();
043    @XmlElement(name = "includes")
044    private List<String> includes = new ArrayList<>();
045
046    public ContextScanDefinition() {
047    }
048
049    public String getIncludeNonSingletons() {
050        return includeNonSingletons;
051    }
052
053    /**
054     * Whether to include non-singleton beans (prototypes)
055     * <p/>
056     * By default only singleton beans is included in the context scan
057     */
058    public void setIncludeNonSingletons(String includeNonSingletons) {
059        this.includeNonSingletons = includeNonSingletons;
060    }
061
062    public List<String> getExcludes() {
063        return excludes;
064    }
065
066    /**
067     * Exclude finding route builder from these java package names.
068     */
069    public void setExcludes(List<String> excludes) {
070        this.excludes = excludes;
071    }
072
073    public List<String> getIncludes() {
074        return includes;
075    }
076
077    /**
078     * Include finding route builder from these java package names.
079     */
080    public void setIncludes(List<String> includes) {
081        this.includes = includes;
082    }
083
084    protected void clear() {
085        excludes.clear();
086        includes.clear();
087    }
088}