\n"; if (&can_install_dkim()) { print &ui_form_start("install_dkim.cgi"); print &text('dkim_installdesc'),"
\n"; print &ui_form_end([ [ undef, $text{'dkim_install'} ] ]); } &ui_print_footer("", $text{'index_return'}); return; } # Show form to enable print &ui_form_start("enable_dkim.cgi"); print &ui_table_start($text{'dkim_header'}, "width=100%", 2); # Enabled? $dkim = &get_dkim_config(); print &ui_table_row($text{'dkim_enabled'}, &ui_yesno_radio("enabled", $dkim && $dkim->{'enabled'})); # Selector for record if ($dkim && $dkim->{'enabled'}) { # Selector is fixed print &ui_table_row($text{'dkim_selector'}, "$dkim->{'selector'}"); print &ui_hidden("selector", $dkim->{'selector'}); } else { # New selector input $defsel = &get_default_dkim_selector(); print &ui_table_row($text{'dkim_selector'}, &ui_textbox("selector", $dkim && $dkim->{'selector'} || $defsel, 20)); } # Verify incoming email? print &ui_table_row($text{'dkim_verify'}, &ui_yesno_radio("verify", $dkim->{'verify'})); # Force new private key if ($dkim && $dkim->{'keyfile'} && -r $dkim->{'keyfile'}) { print &ui_table_row($text{'dkim_makenewkey'}, &ui_yesno_radio("newkey", 0)); } # New key size print &ui_table_row($text{'dkim_size'}, &ui_textbox("size", $dkim->{'size'} || 2048, 5). " ".$text{'dkim_bits'}); # Sign for all domains, or just those with email? print &ui_table_row($text{'dkim_alldns'}, &ui_radio("alldns", $dkim->{'alldns'}, [ [ 0, $text{'dkim_alldns0'}."" ], [ 1, $text{'dkim_alldns1'}."" ], [ 3, $text{'dkim_alldns3'}."" ], [ 2, $text{'dkim_alldns2'} ] ])); # Additional domains to sign for, defaulting to local hostname @extra = @{$dkim->{'extra'}}; if (!@extra && (!$dkim || !$dkim->{'enabled'})) { @extra = &unique(&get_system_hostname(), &get_system_hostname(1)); @extra = grep { $_ =~ /\./ } @extra; } print &ui_table_row($text{'dkim_extra'}, &ui_textarea("extra", join("\n", @extra), 5, 80)); print &ui_table_end(); # Get domains for which signing is currently active if ($dkim && $dkim->{'enabled'}) { my @dnames = &get_dkim_domains($dkim); print &ui_hidden_table_start($text{'dkim_header3'}, "width=100%", 2, 'domains'); my @grid; foreach my $dname (@dnames) { my $d = &get_domain_by("dom", $dname); push(@grid, $d ? &ui_link("summary_domain.cgi?dom=$d->{'id'}", &show_domain_name($d)) : $dname); } print &ui_table_row(undef, &ui_grid_table(\@grid, 4, 100), 2); print &ui_hidden_table_end('domains'); } # Public key and DNS record, for offsite DNS domains if ($dkim && $dkim->{'enabled'}) { print &ui_hidden_table_start($text{'dkim_header2'}, "width=100%", 2, 'keys'); $privkey = &get_dkim_privkey($dkim); print &ui_table_row($text{'dkim_privkeypem'}, &ui_textarea("privkey", $privkey, 8, 80, "hard", undef, "readonly=true")); $pubkey = &get_dkim_pubkey($dkim); print &ui_table_row($text{'dkim_pubkeypem'}, &ui_textarea("pubkey", $pubkey, 8, 80, "hard", undef, "readonly=true")); $dnskey = &get_dkim_dns_pubkey($dkim); $records = $dkim->{'selector'}."._domainkey IN TXT ". &split_long_txt_record("\"v=DKIM1; k=rsa; t=s; p=$dnskey\""); print &ui_table_row($text{'dkim_records'}, &ui_textarea("records", $records, 8, 80, "off", undef, "readonly=true")); print &ui_hidden_table_end('keys'); } print &ui_form_end([ [ undef, $text{'save'} ] ]); &ui_print_footer("", $text{'index_return'});