org.apache.catalina.startup.RealmRuleSet Maven / Gradle / Ivy
/*
* 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.catalina.startup;
import org.apache.tomcat.util.digester.Digester;
import org.apache.tomcat.util.digester.RuleSetBase;
/**
* RuleSet for processing the contents of a Realm definition
* element. This RuleSet
supports Realms such as the
* CombinedRealm
that used nested Realms.
*
* @version $Id: RealmRuleSet.java 939305 2010-04-29 13:43:39Z kkolinko $
*/
public class RealmRuleSet extends RuleSetBase {
// ----------------------------------------------------- Instance Variables
/**
* The matching pattern prefix to use for recognizing our elements.
*/
protected String prefix = null;
// ------------------------------------------------------------ Constructor
/**
* Construct an instance of this RuleSet
with the default
* matching pattern prefix.
*/
public RealmRuleSet() {
this("");
}
/**
* Construct an instance of this RuleSet
with the specified
* matching pattern prefix.
*
* @param prefix Prefix for matching pattern rules (including the
* trailing slash character)
*/
public RealmRuleSet(String prefix) {
super();
this.namespaceURI = null;
this.prefix = prefix;
}
// --------------------------------------------------------- Public Methods
/**
* Add the set of Rule instances defined in this RuleSet to the
* specified Digester
instance, associating them with
* our namespace URI (if any). This method should only be called
* by a Digester instance.
*
* @param digester Digester instance to which the new Rule instances
* should be added.
*/
@Override
public void addRuleInstances(Digester digester) {
digester.addObjectCreate(prefix + "Realm",
null, // MUST be specified in the element,
"className");
digester.addSetProperties(prefix + "Realm");
digester.addSetNext(prefix + "Realm",
"setRealm",
"org.apache.catalina.Realm");
digester.addObjectCreate(prefix + "Realm/Realm",
null, // MUST be specified in the element
"className");
digester.addSetProperties(prefix + "Realm/Realm");
digester.addSetNext(prefix + "Realm/Realm",
"addRealm",
"org.apache.catalina.Realm");
}
}