#!/usr/local/bin/perl
# Show a form for setting up DNSSEC verification and trusted keys
require './bind8-lib.pl';
&ReadParse();
$access{'defaults'} || &error($text{'trusted_ecannot'});
&supports_dnssec_client() || &error($text{'trusted_esupport'});
&ui_print_header(undef, $text{'trusted_title'}, "",
undef, undef, undef, undef, &restart_links());
$conf = &get_config();
$options = &find("options", $conf);
$mems = $options->{'members'};
@dlv = &find("dnssec-lookaside", $mems);
$tkeys = &find("trusted-keys", $conf);
$tkeys ||= { 'members' => [ ] };
# Check if not setup at all
if (!@dlv && !@{$tkeys->{'members'}}) {
print "
\n";
print &ui_form_start("setup_trusted.cgi", "post");
print &text('trusted_setup', "$dnssec_dlv_zone"),"\n";
print &ui_form_end([ [ undef, $text{'trusted_ok'} ] ]);
print "
\n";
print "
\n";
}
print &ui_form_start("save_trusted.cgi", "post");
print &ui_table_start($text{'trusted_header'}, undef, 4);
# DNSSEC enabled?
print &choice_input($text{'trusted_dnssec'}, 'dnssec-enable', $mems,
$text{'yes'}, 'yes', $text{'no'}, 'no',
$text{'default'}, undef);
if (&supports_dnssec_client() == 2) {
print &choice_input($text{'trusted_validation'},
'dnssec-validation', $mems,
$text{'yes'}, 'yes', $text{'no'}, 'no',
$text{'default'}, undef);
}
print &ui_table_hr();
# Trusted DLVs
@dtable = ( );
$i = 0;
foreach $d (@dlv, { 'values' => [ '.' ] }) {
$dlv = $d->{'values'}->[0];
$dlv = "" if ($dlv eq ".");
push(@dtable, [ &ui_opt_textbox("anchor_$i", $d->{'values'}->[2],
30, $text{'trusted_none'}),
&ui_opt_textbox("dlv_$i", $dlv, 20,
$text{'trusted_root'}) ]);
$i++;
}
print &ui_table_row($text{'trusted_dlvs'},
&ui_columns_table([ $text{'trusted_anchor'}, $text{'trusted_dlv'} ],
undef,
\@dtable), 3);
# Trusted keys
@ktable = ( );
$i = 0;
foreach $k (@{$tkeys->{'members'}}, { }) {
@v = @{$k->{'values'}};
@wrapped = ( );
while(length($v[3]) > 30) {
push(@wrapped, substr($v[3], 0, 30));
$v[3] = substr($v[3], 30);
}
push(@wrapped, $v[3]);
push(@ktable, [ &ui_opt_textbox("zone_$i", $k->{'name'}, 20,
$text{'trusted_none'}),
&ui_textbox("flags_$i", $v[0], 6),
&ui_textbox("proto_$i", $v[1], 6),
&ui_textbox("alg_$i", $v[2], 6),
&ui_textarea("key_$i", join("\n", @wrapped), 4, 32) ]);
$i++;
}
print &ui_table_row($text{'trusted_keys'},
&ui_columns_table([ $text{'trusted_zone'}, $text{'trusted_flags'},
$text{'trusted_proto'}, $text{'trusted_alg'},
$text{'trusted_key'} ],
undef,
\@ktable), 3);
print &ui_table_end();
print &ui_form_end([ [ undef, $text{'save'} ] ]);
&ui_print_footer("", $text{'index_return'});