#!/usr/local/bin/perl # edit.cgi # Show a form for editing or creating a connection require './ipsec-lib.pl'; &ReadParse(); if ($in{'new'}) { &ui_print_header(undef, $text{'edit_title1'}, "", "edit"); } else { &ui_print_header(undef, $text{'edit_title2'}, "", "edit"); @conf = &get_config(); $conn = $conf[$in{'idx'}]; } print "
\n"; print "\n"; print "\n"; print "\n"; print "\n"; print "
$text{'edit_header'}
\n"; # Connection name print "\n"; if ($conn->{'value'} eq '%default' || $in{'new'} == 2) { print "\n"; } else { printf "\n", $conn->{'value'}; } # ipsec startup option $a = $conn->{'values'}->{'auto'}; print "\n"; print "\n"; # compression option $c = $conn->{'values'}->{'compress'}; print "\n"; # connection type option $t = $conn->{'values'}->{'type'}; print "\n"; print "\n"; # authentication type option $b = $conn->{'values'}->{'authby'}; print "\n"; print "\n"; # pfs option $c = $conn->{'values'}->{'pfs'}; print "\n"; # auth type option $a = $conn->{'values'}->{'auth'}; print "\n"; print "\n"; # keying tries option $k = $conn->{'values'}->{'keyingtries'}; print "\n"; print "\n"; # esp type option $e = $conn->{'values'}->{'esp'}; $eonly = ($e =~ s/\!//g ? "!" : ""); print "\n"; print "\n"; print "\n"; print "\n"; # key lifetime option $l = $conn->{'values'}->{'keylife'}; $lu = $l =~ s/([^0-9])$// ? $1 : "s"; print "\n"; print "\n"; # keying channel lifetime option $l = $conn->{'values'}->{'ikelifetime'}; $lu = $l =~ s/([^0-9])$// ? $1 : "s"; print "\n"; print "\n"; foreach $d ('left', 'right') { print "
$text{'edit_name'}$text{'edit_default'}$text{'edit_auto'}",&ui_select("auto", $a, [ [ "", $text{'edit_amode'} ], [ "ignore", $text{'edit_amodeignore'} ], [ "add", $text{'edit_amodeadd'} ], [ "start", $text{'edit_amodestart'} ] ]),"
$text{'edit_comp'} \n"; print &ui_radio("comp", $c, [ [ "", $text{'edit_cmode'} ], [ "yes", $text{'edit_cmodeyes'} ], [ "no", $text{'edit_cmodeno'} ] ]),"$text{'edit_type'}",&ui_select("type", $t, [ [ "", $text{'edit_tmode'} ], [ "tunnel", $text{'edit_tmodetunnel'} ], [ "transport", $text{'edit_tmodetransport'} ], [ "passthrough", $text{'edit_tmodepassthrough'} ] ]), "
$text{'edit_authby'}",&ui_select("authby", $b, [ [ "", $text{'edit_authbydef'} ], [ "rsasig", $text{'edit_rsasig'} ], [ "secret", $text{'edit_secret'} ], [ "rsasig|secret", $text{'edit_rsasigsecret'} ], [ "never", $text{'edit_never'} ] ], 0,0, 1),"$text{'edit_pfs'} \n"; print &ui_radio("pfs", $c, [ [ "yes", $text{'edit_pmodeyes'} ], [ "no", $text{'edit_pmodeno'} ], [ "", $text{'edit_pmode'} ] ]); print "
$text{'edit_auth'}",&ui_select("auth", $a, [ [ "", $text{'edit_authdef'} ], [ "esp", $text{'edit_authesp'} ], [ "ah", $text{'edit_authah'} ] ], 0, 0, 1), "$text{'edit_keying'}",&ui_opt_textbox("keying", $k, 10, $text{'default'}), "
$text{'edit_esp'}",&ui_select("esp", $e, [ [ "", $text{'edit_espdef'} ], [ "3des-md5", $text{'edit_espmd5'} ], [ "3des-sha", $text{'edit_espsha'} ], [ "aes-128-md5", $text{'edit_esp128'} ] ], 0, 0, 1), "$text{'edit_esponly'}",&ui_radio("esp_only", $eonly, [ [ "!", $text{'yes'} ], [ "", $text{'no'} ] ]),"
$text{'edit_keylife'}",&ui_opt_textbox("keylife", $l, 5, $text{'default'})," ", &ui_select("keylife_units", $lu, [ [ "s", $text{'edit_unit_s'} ], [ "m", $text{'edit_unit_m'} ], [ "h", $text{'edit_unit_h'} ], [ "d", $text{'edit_unit_d'} ] ]),"$text{'edit_ikelifetime'}",&ui_opt_textbox("ikelifetime", $l, 5, $text{'default'})," ", &ui_select("ikelifetime_units", $lu, [ [ "s", $text{'edit_unit_s'} ], [ "m", $text{'edit_unit_m'} ], [ "h", $text{'edit_unit_h'} ], [ "d", $text{'edit_unit_d'} ] ]),"

\n"; print "\n"; print "\n"; print "
",$text{'edit_'.$d},"
\n"; # left/right $a = $conn->{'values'}->{$d}; $amode = $a eq '%defaultroute' ? 0 : $a eq '%any' ? 1 : $a eq '%opportunistic' ? 2 : 3; if ($a eq '' && $conn->{'value'} eq '%default' || $in{'new'} == 2) { $amode = -1; } print "\n", $amode == 3 ? $a : undef; # leftid/rightid $i = $conn->{'values'}->{$d."id"}; $imode = $i =~ /^\@/ ? 2 : $i eq '' ? 0 : 1; print "\n"; # leftrsasigkey/rightrsasigkey $k = $conn->{'values'}->{$d.'rsasigkey'}; if ($in{'new'} == 1 && $d eq 'left') { $k = &get_public_key(); } $kmode = $k eq '%dns' ? 1 : $k ? 2 : 0; print " ", "\n"; # leftnexthop/rightnexthop $h = $conn->{'values'}->{$d.'nexthop'}; $hmode = $h eq '%direct' ? 1 : $h eq '%defaultroute' ? 3 : $h ? 2 : 0; print "\n", $hmode == 2 ? $h : undef; # leftcert/rightcert $s = $conn->{'values'}->{$d.'cert'}; print "\n"; } print "
$text{'edit_addr'} \n"; foreach $m ($amode == -1 ? (-1 .. 3) : (0 .. 3)) { printf "%s\n", $m, $m == $amode ? "checked" : "", $text{'edit_addr'.$m}; } printf "
$text{'edit_id'} \n"; printf " %s\n", $imode == 0 ? "checked" : "", $text{'default'}; printf " %s\n", $imode == 1 ? "checked" : "", $text{'edit_id1'}; printf " %s\n", $imode == 2 ? "checked" : "", $text{'edit_id2'}; printf "\n", $imode == 2 ? substr($i, 1) : $i; # leftsubnet/rightsubnet $s = $conn->{'values'}->{$d.'subnet'}; print "
$text{'edit_subnet'} \n"; printf " %s\n", $s ? "" : "checked", $text{'edit_none'}; printf " %s\n", $s ? "checked" : ""; print "
$text{'edit_key'}\n"; foreach $m (0 .. 2) { printf " %s\n", $m, $kmode == $m ? "checked" : "", $text{'edit_key'.$m}; } print "
$text{'edit_hop'} \n"; printf " %s\n", $hmode == 0 ? "checked" : "", $text{'default'}; printf " %s\n", $hmode == 1 ? "checked" : "", $text{'edit_hopdir'}; printf " %s\n", $hmode == 3 ? "checked" : "", $text{'edit_hoproute'}; printf " %s\n", $hmode == 2 ? "checked" : "", $text{'edit_hopip'}; printf "
$text{'edit_cert'} \n"; printf " %s\n", $s ? "" : "checked", $text{'edit_none'}; printf " %s\n", $s ? "checked" : ""; print "
\n"; print "\n"; if ($in{'new'}) { print "\n"; } else { print "\n"; if ($conn->{'value'} ne '%default') { print "\n"; } print "\n"; } print "
\n"; &ui_print_footer("", $text{'index_return'});