/usr/share/perl5/EBox/Network/Model/DNSResolver.pm is in zentyal-network 2.3.13+quantal1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 | # Copyright (C) 2008-2012 eBox Technologies S.L.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License, version 2, as
# published by the Free Software Foundation.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
# Class: EBox::Network::Model::DNSResolver
#
# This model configures the DNS resolvers for the host. It allows to
# set as many name servers as you want. The single field available is
# the following one:
#
# - nameserver
#
package EBox::Network::Model::DNSResolver;
use base 'EBox::Model::DataTable';
use strict;
use warnings;
use EBox::Gettext;
use EBox::Global;
use EBox::Types::HostIP;
# Dependencies
# Group: Public methods
# Constructor: new
#
# Create the new DNS resolver table
#
# Overrides:
#
# <EBox::Model::DataTable::new>
#
# Returns:
#
# <EBox::Network::Model::DNSResolver> - the newly created object
# instance
#
sub new
{
my ($class, %opts) = @_;
my $self = $class->SUPER::new(%opts);
bless ( $self, $class);
return $self;
}
# Group: Protected methods
# Method: _table
#
# Overrides:
#
# <EBox::Model::DataTable::_table>
#
sub _table
{
my ($self) = @_;
my $helpHostIP = __('IP address of the DNS server that Zentyal'.
' will use to resolve names.');
my @tableDesc =
(
new EBox::Types::HostIP(
fieldName => 'nameserver',
printableName => __('Domain Name Server'),
editable => 1,
unique => 1,
help => $helpHostIP
),
);
my $dataTable = {
tableName => 'DNSResolver',
printableTableName => __('Domain Name Server Resolver List'),
modelDomain => 'Network',
defaultActions => [ 'add', 'del', 'move', 'editField', 'changeView' ],
tableDescription => \@tableDesc,
class => 'dataTable',
help => _help(),
printableRowName => __('name server'),
order => 1,
insertPosition => 'back',
};
return $dataTable;
}
sub _help
{
return (__('<p>Here you can add the name server resolvers that Zentyal will ' .
'use.</p>' .
'<p>Note that these settings may be overriden if you have any ' .
'network interface configured via DHCP</p>'));
}
sub replace
{
my ($self, $pos, $newIP) = @_;
my @ids = @{ $self->ids() };
print "IDS @ids";
if ($pos >= scalar @ids) {
throw EBox::Exceptions::Internal("Inexistent DNS resolver position $pos");
}
my $id = $ids[$pos];
my $row = $self->row($id);
$row->elementByName('namserver')->setValue($newIP);
$row->store();
}
1;
|