blob: 1b622ce9924e30b49ba5e1573024f6a5784e2a45 [file] [log] [blame]
/*
* 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.brooklyn.entity.network.bind;
import java.util.Map;
import org.apache.brooklyn.api.catalog.Catalog;
import org.apache.brooklyn.api.entity.Entity;
import org.apache.brooklyn.api.entity.ImplementedBy;
import org.apache.brooklyn.api.sensor.AttributeSensor;
import org.apache.brooklyn.config.ConfigKey;
import org.apache.brooklyn.core.annotation.Effector;
import org.apache.brooklyn.core.config.ConfigKeys;
import org.apache.brooklyn.core.location.PortRanges;
import org.apache.brooklyn.core.sensor.PortAttributeSensorAndConfigKey;
import org.apache.brooklyn.core.sensor.Sensors;
import org.apache.brooklyn.entity.group.DynamicGroup;
import org.apache.brooklyn.entity.software.base.SoftwareProcess;
import org.apache.brooklyn.util.core.flags.SetFromFlag;
import org.apache.brooklyn.util.net.Cidr;
import com.google.common.base.Predicate;
import com.google.common.base.Predicates;
import com.google.common.collect.Multimap;
import com.google.common.reflect.TypeToken;
/**
* This sets up a BIND DNS server.
*/
@Catalog(name="BIND", description="BIND is an Internet Domain Name Server.", iconUrl="classpath:///isc-logo.png")
@ImplementedBy(BindDnsServerImpl.class)
public interface BindDnsServer extends SoftwareProcess {
@SetFromFlag("filter")
ConfigKey<Predicate<? super Entity>> ENTITY_FILTER = ConfigKeys.newConfigKey(new TypeToken<Predicate<? super Entity>>() {},
"bind.entity.filter", "Filter for entities which will use the BIND DNS service for name resolution." +
"Default is all instances of SoftwareProcess in the application.",
Predicates.instanceOf(SoftwareProcess.class));
@SetFromFlag("domainName")
ConfigKey<String> DOMAIN_NAME = ConfigKeys.newStringConfigKey(
"bind.domain.name", "The DNS domain name to serve", "brooklyn.local");
@SetFromFlag("reverseLookupNetwork")
ConfigKey<String> REVERSE_LOOKUP_NETWORK = ConfigKeys.newStringConfigKey(
"bind.reverse-lookup.address", "Network address for reverse lookup zone");
@SetFromFlag("subnet")
ConfigKey<String> MANAGEMENT_CIDR = ConfigKeys.newStringConfigKey(
"bind.access.cidr", "Subnet CIDR or ACL allowed to access DNS", "0.0.0.0/0");
@SetFromFlag("hostnameSensor")
ConfigKey<AttributeSensor<String>> HOSTNAME_SENSOR = ConfigKeys.newConfigKey(new TypeToken<AttributeSensor<String>>() {},
"bind.sensor.hostname", "Sensor on managed entities that reports the basename for the hostname");
@SetFromFlag("addressSensor")
ConfigKey<AttributeSensor<String>> ADDRESS_SENSOR = ConfigKeys.newConfigKey(new TypeToken<AttributeSensor<String>>() {},
"bind.sensor.address", "Sensor on managed entities that reports the address to register;"
+ " host.address or host.subnet.address are common choices;"
+ " blank (deprecated default behaviour) will inspect machines attached to entities"
+ " but for legacy compatibility only; blueprints should set this");
// TODO in future might want to change default to Attributes.ADDRESS (and lose the "inspect machines" default behaviour)
PortAttributeSensorAndConfigKey DNS_PORT =
new PortAttributeSensorAndConfigKey("bind.port", "BIND DNS port for TCP and UDP", PortRanges.fromString("53"));
@SetFromFlag("zoneFileTemplate")
ConfigKey<String> DOMAIN_ZONE_FILE_TEMPLATE = ConfigKeys.newStringConfigKey(
"bind.template.domain-zone", "The BIND domain zone file to serve (as FreeMarker template)",
"classpath://org/apache/brooklyn/entity/network/bind/domain.zone");
@SetFromFlag("reverseZoneFileTemplate")
ConfigKey<String> REVERSE_ZONE_FILE_TEMPLATE = ConfigKeys.newStringConfigKey(
"bind.template.reverse-zone", "The BIND reverse lookup zone file to serve (as FreeMarker template)",
"classpath://org/apache/brooklyn/entity/network/bind/reverse.zone");
@SetFromFlag("namedConfTemplate")
ConfigKey<String> NAMED_CONF_TEMPLATE = ConfigKeys.newStringConfigKey(
"bind.template.named-conf", "The BIND named configuration file (as FreeMarker template)",
"classpath://org/apache/brooklyn/entity/network/bind/named.conf");
@SetFromFlag("updateRootZonesFile")
ConfigKey<Boolean> UPDATE_ROOT_ZONES_FILE = ConfigKeys.newBooleanConfigKey(
"bind.updateRootZones", "Instructs the entity to fetch the latest root zones file from ftp.rs.internic.net.",
Boolean.FALSE);
/* Reverse lookup attributes. */
AttributeSensor<Cidr> REVERSE_LOOKUP_CIDR = Sensors.newSensor(Cidr.class,
"bind.reverse-lookup.cidr", "The network CIDR that hosts must have for reverse lookup entries " +
"to be added (default uses server address /24)");
AttributeSensor<String> REVERSE_LOOKUP_DOMAIN = Sensors.newStringSensor(
"bind.reverse-lookup.domain", "The in-addr.arpa reverse lookup domain name");
/* Configuration applicable to clients of the BIND DNS service. */
@SetFromFlag("replaceResolvConf")
ConfigKey<Boolean> REPLACE_RESOLV_CONF = ConfigKeys.newBooleanConfigKey(
"bind.resolv-conf.replce", "Set to replace resolv.conf with the template (default is to use eth0 script)", Boolean.FALSE);
@SetFromFlag("interfaceConfigTemplate")
ConfigKey<String> INTERFACE_CONFIG_TEMPLATE = ConfigKeys.newStringConfigKey(
"bind.template.interface-cfg", "The network interface configuration file for clients (as FreeMarker template)",
"classpath://org/apache/brooklyn/entity/network/bind/ifcfg");
@SetFromFlag("interfaceConfigTemplate")
ConfigKey<String> RESOLV_CONF_TEMPLATE = ConfigKeys.newStringConfigKey(
"bind.template.resolv-conf", "The resolver configuration file for clients (as FreeMarker template)",
"classpath://org/apache/brooklyn/entity/network/bind/resolv.conf");
AttributeSensor<DynamicGroup> ENTITIES = Sensors.newSensor(DynamicGroup.class,
"bind.entities", "The entities being managed by this server");
AttributeSensor<Multimap<String, String>> ADDRESS_MAPPINGS = Sensors.newSensor(new TypeToken<Multimap<String, String>>() {},
"bind.mappings", "All address mappings maintained by the server, in form address -> [names]");
AttributeSensor<Map<String, String>> A_RECORDS = Sensors.newSensor(new TypeToken<Map<String, String>>() {},
"bind.records.a", "All A records for the server, in form name -> address");
AttributeSensor<Multimap<String, String>> CNAME_RECORDS = Sensors.newSensor(new TypeToken<Multimap<String, String>>() {},
"bind.records.cname", "All CNAME records for the server, in form name -> [names]");
AttributeSensor<Map<String, String>> PTR_RECORDS = Sensors.newSensor(new TypeToken<Map<String, String>>() {},
"bind.records.ptr", "All PTR records for the server, in form address -> name. Entries will be in REVERSE_LOOKUP_CIDR. " +
"Entries are guaranteed to have an inverse mapping in A_RECORDS.");
// NB must be less than 2^32, so just larger than Integer; we use current time mills / 1000
AttributeSensor<Long> SERIAL = Sensors.newLongSensor(
"bind.serial", "A serial number guaranteed to be valid for use in a modified domain.zone or reverse.zone file");
public Multimap<String, String> getAddressMappings();
/**
* @return the IP to hostname mappings stored in this DNS server's conf file
* @deprecated since 0.7.0 use {@link #PTR_RECORDS} instead.
*/
@Deprecated
@Effector(description="Gets the IP to hostname mappings stored in this DNS server's conf file")
public Map<String, String> getReverseMappings();
/**
* @return the predicate used to filter entities for the Bind server to manage.
*/
Predicate<? super Entity> getEntityFilter();
}