]> git.ipfire.org Git - people/teissler/ipfire-2.x.git/commitdiff
Merge remote-tracking branch 'ummeegge/openvpn' into next
authorMichael Tremer <michael.tremer@ipfire.org>
Sun, 11 May 2014 16:47:11 +0000 (18:47 +0200)
committerMichael Tremer <michael.tremer@ipfire.org>
Sun, 11 May 2014 16:47:11 +0000 (18:47 +0200)
Conflicts:
html/cgi-bin/ovpnmain.cgi
langs/de/cgi-bin/de.pl
langs/en/cgi-bin/en.pl

12 files changed:
1  2 
doc/language_issues.de
doc/language_issues.en
doc/language_issues.es
doc/language_issues.fr
doc/language_issues.nl
doc/language_issues.pl
doc/language_issues.ru
doc/language_issues.tr
doc/language_missings
html/cgi-bin/ovpnmain.cgi
langs/de/cgi-bin/de.pl
langs/en/cgi-bin/en.pl

diff --combined doc/language_issues.de
index 650d41552ef16a38f9f899f26253e13d76283474,25612b5b74e6f1c2656da3869da7e7632e66f96b..a00e97a051756d4ff5d8572e128e38ee59b102b9
@@@ -1,3 -1,4 +1,3 @@@
 -WARNING: translation string unused: Client status and controlc
  WARNING: translation string unused: ConnSched scheduler
  WARNING: translation string unused: ConnSched select profile
  WARNING: translation string unused: HDD temperature
@@@ -363,7 -364,6 +363,7 @@@ WARNING: translation string unused: net
  WARNING: translation string unused: network traffic graphs
  WARNING: translation string unused: network updated
  WARNING: translation string unused: networks settings
 +WARNING: translation string unused: never
  WARNING: translation string unused: new optionsfw must boot
  WARNING: translation string unused: no alcatelusb firmware
  WARNING: translation string unused: no cfg upload
@@@ -386,6 -386,7 +386,6 @@@ WARNING: translation string unused: opt
  WARNING: translation string unused: optionsfw warning
  WARNING: translation string unused: or
  WARNING: translation string unused: original
 -WARNING: translation string unused: other countries
  WARNING: translation string unused: our donors
  WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall
@@@ -408,11 -409,10 +408,10 @@@ WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall view group
  WARNING: translation string unused: outgoing firewall warning
  WARNING: translation string unused: override mtu
 -WARNING: translation string unused: ovpn
  WARNING: translation string unused: ovpn config
  WARNING: translation string unused: ovpn dl
- WARNING: translation string unused: ovpn engines
  WARNING: translation string unused: ovpn log
 +WARNING: translation string unused: ovpn reneg sec
  WARNING: translation string unused: ovpn_fastio
  WARNING: translation string unused: ovpn_fragment
  WARNING: translation string unused: ovpn_mssfix
@@@ -459,12 -459,16 +458,12 @@@ WARNING: translation string unused: rel
  WARNING: translation string unused: removable device advice
  WARNING: translation string unused: reportfile
  WARNING: translation string unused: requested data
 -WARNING: translation string unused: reserved dst port
 -WARNING: translation string unused: reserved src port
  WARNING: translation string unused: restore hardware settings
  WARNING: translation string unused: root
  WARNING: translation string unused: root path
  WARNING: translation string unused: root user password
  WARNING: translation string unused: route subnet is invalid
  WARNING: translation string unused: router ip
 -WARNING: translation string unused: rsvd dst port overlap
 -WARNING: translation string unused: rsvd src port overlap
  WARNING: translation string unused: rules already up to date
  WARNING: translation string unused: safe removal of umounted device
  WARNING: translation string unused: save error
@@@ -615,16 -619,10 +614,16 @@@ WARNING: untranslated string: addon
  WARNING: untranslated string: bytes
  WARNING: untranslated string: community rules
  WARNING: untranslated string: dead peer detection
 +WARNING: untranslated string: dns servers
 +WARNING: untranslated string: downlink
  WARNING: untranslated string: emerging rules
 +WARNING: untranslated string: first
  WARNING: untranslated string: fwhost err hostip
 +WARNING: untranslated string: last
 +WARNING: untranslated string: monitor interface
  WARNING: untranslated string: qos add subclass
  WARNING: untranslated string: route config changed
  WARNING: untranslated string: routing config added
  WARNING: untranslated string: routing config changed
  WARNING: untranslated string: routing table
 +WARNING: untranslated string: uplink
diff --combined doc/language_issues.en
index c32d0579b825b100e462347722c22604fa6d8825,e6af830a5d47d90f302ff5094fa3d37a3016700e..ba7f0307df6b0b49a6ef5fefef0239eec67e59d5
@@@ -1,3 -1,4 +1,3 @@@
 -WARNING: translation string unused: Client status and controlc
  WARNING: translation string unused: ConnSched scheduler
  WARNING: translation string unused: ConnSched select profile
  WARNING: translation string unused: HDD temperature
@@@ -145,6 -146,6 +145,7 @@@ WARNING: translation string unused: des
  WARNING: translation string unused: destination ip or net
  WARNING: translation string unused: destination net
  WARNING: translation string unused: destination port overlaps
++WARNING: translation string unused: dh name is invalid
  WARNING: translation string unused: dhcp base ip fixed lease
  WARNING: translation string unused: dhcp create fixed leases
  WARNING: translation string unused: dhcp fixed lease err1
@@@ -388,7 -389,6 +389,7 @@@ WARNING: translation string unused: net
  WARNING: translation string unused: network traffic graphs
  WARNING: translation string unused: network updated
  WARNING: translation string unused: networks settings
 +WARNING: translation string unused: never
  WARNING: translation string unused: new optionsfw must boot
  WARNING: translation string unused: no alcatelusb firmware
  WARNING: translation string unused: no cfg upload
@@@ -412,6 -412,7 +413,6 @@@ WARNING: translation string unused: opt
  WARNING: translation string unused: optionsfw warning
  WARNING: translation string unused: or
  WARNING: translation string unused: original
 -WARNING: translation string unused: other countries
  WARNING: translation string unused: our donors
  WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall
@@@ -434,13 -435,12 +435,11 @@@ WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall view group
  WARNING: translation string unused: outgoing firewall warning
  WARNING: translation string unused: override mtu
 -WARNING: translation string unused: ovpn
  WARNING: translation string unused: ovpn config
  WARNING: translation string unused: ovpn dl
- WARNING: translation string unused: ovpn engines
  WARNING: translation string unused: ovpn log
 +WARNING: translation string unused: ovpn reneg sec
  WARNING: translation string unused: ovpn_fastio
--WARNING: translation string unused: ovpn_fragment
  WARNING: translation string unused: ovpn_mssfix
  WARNING: translation string unused: ovpn_mtudisc
  WARNING: translation string unused: ovpn_processprio
@@@ -486,12 -486,16 +485,12 @@@ WARNING: translation string unused: rel
  WARNING: translation string unused: removable device advice
  WARNING: translation string unused: reportfile
  WARNING: translation string unused: requested data
 -WARNING: translation string unused: reserved dst port
 -WARNING: translation string unused: reserved src port
  WARNING: translation string unused: restore hardware settings
  WARNING: translation string unused: root
  WARNING: translation string unused: root path
  WARNING: translation string unused: root user password
  WARNING: translation string unused: route subnet is invalid
  WARNING: translation string unused: router ip
 -WARNING: translation string unused: rsvd dst port overlap
 -WARNING: translation string unused: rsvd src port overlap
  WARNING: translation string unused: rules already up to date
  WARNING: translation string unused: safe removal of umounted device
  WARNING: translation string unused: save error
@@@ -546,6 -550,6 +545,7 @@@ WARNING: translation string unused: suc
  WARNING: translation string unused: system graphs
  WARNING: translation string unused: system log viewer
  WARNING: translation string unused: system status information
++WARNING: translation string unused: teovpn_fragment
  WARNING: translation string unused: test
  WARNING: translation string unused: test email could not be sent
  WARNING: translation string unused: test email was sent
@@@ -646,14 -650,8 +646,14 @@@ WARNING: translation string unused: yea
  WARNING: translation string unused: yearly firewallhits
  WARNING: untranslated string: Scan for Songs
  WARNING: untranslated string: bytes
 +WARNING: untranslated string: dns servers
 +WARNING: untranslated string: downlink
 +WARNING: untranslated string: first
  WARNING: untranslated string: fwhost err hostip
 +WARNING: untranslated string: last
 +WARNING: untranslated string: monitor interface
  WARNING: untranslated string: route config changed
  WARNING: untranslated string: routing config added
  WARNING: untranslated string: routing config changed
  WARNING: untranslated string: routing table
 +WARNING: untranslated string: uplink
diff --combined doc/language_issues.es
index b274590afc93dee683038be557af5fe9f6171b02,b854a2b7a661cd648cc7d7e9ca4df61b2ea563c9..54cb32e982402487f14ad1a6fd28c85dfc729981
@@@ -360,6 -360,7 +360,6 @@@ WARNING: translation string unused: opt
  WARNING: translation string unused: optionsfw warning
  WARNING: translation string unused: or
  WARNING: translation string unused: original
 -WARNING: translation string unused: other countries
  WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall
  WARNING: translation string unused: outgoing firewall mode0
@@@ -370,6 -371,7 +370,6 @@@ WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall reset
  WARNING: translation string unused: outgoing firewall warning
  WARNING: translation string unused: override mtu
 -WARNING: translation string unused: ovpn
  WARNING: translation string unused: ovpn config
  WARNING: translation string unused: ovpn dl
  WARNING: translation string unused: ovpn log
@@@ -420,12 -422,16 +420,12 @@@ WARNING: translation string unused: rel
  WARNING: translation string unused: removable device advice
  WARNING: translation string unused: reportfile
  WARNING: translation string unused: requested data
 -WARNING: translation string unused: reserved dst port
 -WARNING: translation string unused: reserved src port
  WARNING: translation string unused: restore hardware settings
  WARNING: translation string unused: root
  WARNING: translation string unused: root path
  WARNING: translation string unused: root user password
  WARNING: translation string unused: route subnet is invalid
  WARNING: translation string unused: router ip
 -WARNING: translation string unused: rsvd dst port overlap
 -WARNING: translation string unused: rsvd src port overlap
  WARNING: translation string unused: rules already up to date
  WARNING: translation string unused: safe removal of umounted device
  WARNING: translation string unused: save error
@@@ -552,7 -558,6 +552,7 @@@ WARNING: translation string unused: us
  WARNING: translation string unused: use ibod
  WARNING: translation string unused: view log
  WARNING: translation string unused: vpn aggrmode
 +WARNING: translation string unused: vpn configuration main
  WARNING: translation string unused: vpn incompatible use of defaultroute
  WARNING: translation string unused: vpn mtu invalid
  WARNING: translation string unused: vpn on blue
@@@ -575,7 -580,6 +575,7 @@@ WARNING: untranslated string: ConnSche
  WARNING: untranslated string: ConnSched shutdown
  WARNING: untranslated string: MB read
  WARNING: untranslated string: MB written
 +WARNING: untranslated string: Number of Countries for the pie chart
  WARNING: untranslated string: Scan for Songs
  WARNING: untranslated string: Set time on boot
  WARNING: untranslated string: addons
@@@ -588,7 -592,6 +588,7 @@@ WARNING: untranslated string: atm devic
  WARNING: untranslated string: attention
  WARNING: untranslated string: bit
  WARNING: untranslated string: bytes
 +WARNING: untranslated string: capabilities
  WARNING: untranslated string: ccd add
  WARNING: untranslated string: ccd choose net
  WARNING: untranslated string: ccd client options
@@@ -633,9 -636,6 +633,10 @@@ WARNING: untranslated string: countryco
  WARNING: untranslated string: dead peer detection
  WARNING: untranslated string: deprecated fs warn
  WARNING: untranslated string: details
- WARNING: untranslated string: dh name is invalid
 +WARNING: untranslated string: dh
++WARNING: untranslated string: dh key move failed
 +WARNING: untranslated string: dh key warn
++WARNING: untranslated string: dh key warn1
  WARNING: untranslated string: dnat address
  WARNING: untranslated string: dns servers
  WARNING: untranslated string: dnsforward
@@@ -674,7 -674,6 +675,7 @@@ WARNING: untranslated string: fireinfo 
  WARNING: untranslated string: fireinfo why enable
  WARNING: untranslated string: fireinfo why read more
  WARNING: untranslated string: fireinfo your profile id
 +WARNING: untranslated string: firewall logs country
  WARNING: untranslated string: firewall rules
  WARNING: untranslated string: first
  WARNING: untranslated string: flag
@@@ -821,12 -820,8 +822,12 @@@ WARNING: untranslated string: fwhost st
  WARNING: untranslated string: fwhost type
  WARNING: untranslated string: fwhost used
  WARNING: untranslated string: fwhost welcome
 +WARNING: untranslated string: gen dh
 +WARNING: untranslated string: generate dh key
  WARNING: untranslated string: grouptype
  WARNING: untranslated string: hardware support
 +WARNING: untranslated string: imei
 +WARNING: untranslated string: imsi
  WARNING: untranslated string: incoming firewall access
  WARNING: untranslated string: integrity
  WARNING: untranslated string: invalid input for dpd delay
@@@ -840,23 -835,8 +841,23 @@@ WARNING: untranslated string: mac filte
  WARNING: untranslated string: maximum
  WARNING: untranslated string: minimum
  WARNING: untranslated string: minute
 +WARNING: untranslated string: model
 +WARNING: untranslated string: modem hardware details
 +WARNING: untranslated string: modem information
 +WARNING: untranslated string: modem network bit error rate
 +WARNING: untranslated string: modem network information
 +WARNING: untranslated string: modem network mode
 +WARNING: untranslated string: modem network operator
 +WARNING: untranslated string: modem network registration
 +WARNING: untranslated string: modem network signal quality
 +WARNING: untranslated string: modem no connection
 +WARNING: untranslated string: modem no connection message
 +WARNING: untranslated string: modem sim information
 +WARNING: untranslated string: modem status
 +WARNING: untranslated string: monitor interface
  WARNING: untranslated string: most preferred
  WARNING: untranslated string: no hardware random number generator
 +WARNING: untranslated string: not a valid dh key
  WARNING: untranslated string: notice
  WARNING: untranslated string: openvpn default
  WARNING: untranslated string: openvpn destination port used
@@@ -871,14 -851,8 +872,15 @@@ WARNING: untranslated string: othe
  WARNING: untranslated string: outgoing firewall access
  WARNING: untranslated string: outgoing firewall p2p allow
  WARNING: untranslated string: outgoing firewall p2p deny
- WARNING: untranslated string: ovpn dh name
 +WARNING: untranslated string: ovpn crypt options
 +WARNING: untranslated string: ovpn dh
++WARNING: untranslated string: ovpn dh upload
++WARNING: untranslated string: ovpn engines
  WARNING: untranslated string: ovpn errmsg green already pushed
  WARNING: untranslated string: ovpn errmsg invalid ip or mask
 +WARNING: untranslated string: ovpn generating the root and host certificates
 +WARNING: untranslated string: ovpn ha
 +WARNING: untranslated string: ovpn hmac
  WARNING: untranslated string: ovpn mgmt in root range
  WARNING: untranslated string: ovpn mtu-disc
  WARNING: untranslated string: ovpn mtu-disc and mtu not 1500
@@@ -907,10 -881,7 +909,10 @@@ WARNING: untranslated string: routing c
  WARNING: untranslated string: routing config changed
  WARNING: untranslated string: routing table
  WARNING: untranslated string: server restart
 +WARNING: untranslated string: show dh
  WARNING: untranslated string: snat new source ip address
 +WARNING: untranslated string: software version
 +WARNING: untranslated string: source ip country
  WARNING: untranslated string: ssh
  WARNING: untranslated string: static routes
  WARNING: untranslated string: support donation
@@@ -966,10 -937,8 +968,10 @@@ WARNING: untranslated string: tor traff
  WARNING: untranslated string: tor traffic read written
  WARNING: untranslated string: tor use exit nodes
  WARNING: untranslated string: uplink
 +WARNING: untranslated string: upload dh key
  WARNING: untranslated string: uptime load average
  WARNING: untranslated string: urlfilter redirect template
 +WARNING: untranslated string: vendor
  WARNING: untranslated string: visit us at
  WARNING: untranslated string: vpn keyexchange
  WARNING: untranslated string: wlan client
diff --combined doc/language_issues.fr
index 935d991e6cf4a699840c56b1b0a3e3ea35c9755d,6ab29e8bb64b4f8e67d1eb0895f72668dd7244f2..0386f243cc5b58d65911517c07f7bcdb0275296a
@@@ -360,6 -360,7 +360,6 @@@ WARNING: translation string unused: opt
  WARNING: translation string unused: optionsfw warning
  WARNING: translation string unused: or
  WARNING: translation string unused: original
 -WARNING: translation string unused: other countries
  WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall
  WARNING: translation string unused: outgoing firewall add ip group
@@@ -381,6 -382,7 +381,6 @@@ WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall view group
  WARNING: translation string unused: outgoing firewall warning
  WARNING: translation string unused: override mtu
 -WARNING: translation string unused: ovpn
  WARNING: translation string unused: ovpn config
  WARNING: translation string unused: ovpn dl
  WARNING: translation string unused: ovpn log
@@@ -431,12 -433,16 +431,12 @@@ WARNING: translation string unused: rel
  WARNING: translation string unused: removable device advice
  WARNING: translation string unused: reportfile
  WARNING: translation string unused: requested data
 -WARNING: translation string unused: reserved dst port
 -WARNING: translation string unused: reserved src port
  WARNING: translation string unused: restore hardware settings
  WARNING: translation string unused: root
  WARNING: translation string unused: root path
  WARNING: translation string unused: root user password
  WARNING: translation string unused: route subnet is invalid
  WARNING: translation string unused: router ip
 -WARNING: translation string unused: rsvd dst port overlap
 -WARNING: translation string unused: rsvd src port overlap
  WARNING: translation string unused: rules already up to date
  WARNING: translation string unused: safe removal of umounted device
  WARNING: translation string unused: save error
@@@ -565,7 -571,6 +565,7 @@@ WARNING: translation string unused: us
  WARNING: translation string unused: use ibod
  WARNING: translation string unused: view log
  WARNING: translation string unused: vpn aggrmode
 +WARNING: translation string unused: vpn configuration main
  WARNING: translation string unused: vpn incompatible use of defaultroute
  WARNING: translation string unused: vpn mtu invalid
  WARNING: translation string unused: vpn on blue
@@@ -586,7 -591,6 +586,7 @@@ WARNING: untranslated string: ConnSche
  WARNING: untranslated string: ConnSched shutdown
  WARNING: untranslated string: MB read
  WARNING: untranslated string: MB written
 +WARNING: untranslated string: Number of Countries for the pie chart
  WARNING: untranslated string: Scan for Songs
  WARNING: untranslated string: addons
  WARNING: untranslated string: advproxy cache-digest
@@@ -598,7 -602,6 +598,7 @@@ WARNING: untranslated string: atm devic
  WARNING: untranslated string: attention
  WARNING: untranslated string: bit
  WARNING: untranslated string: bytes
 +WARNING: untranslated string: capabilities
  WARNING: untranslated string: ccd add
  WARNING: untranslated string: ccd choose net
  WARNING: untranslated string: ccd client options
@@@ -643,9 -646,6 +643,10 @@@ WARNING: untranslated string: countryco
  WARNING: untranslated string: dead peer detection
  WARNING: untranslated string: deprecated fs warn
  WARNING: untranslated string: details
- WARNING: untranslated string: dh name is invalid
 +WARNING: untranslated string: dh
++WARNING: untranslated string: dh key move failed
 +WARNING: untranslated string: dh key warn
++WARNING: untranslated string: dh key warn1
  WARNING: untranslated string: dnat address
  WARNING: untranslated string: dns address deleted txt
  WARNING: untranslated string: dns servers
@@@ -685,7 -685,6 +686,7 @@@ WARNING: untranslated string: fireinfo 
  WARNING: untranslated string: fireinfo why enable
  WARNING: untranslated string: fireinfo why read more
  WARNING: untranslated string: fireinfo your profile id
 +WARNING: untranslated string: firewall logs country
  WARNING: untranslated string: firewall rules
  WARNING: untranslated string: first
  WARNING: untranslated string: flag
@@@ -832,12 -831,8 +833,12 @@@ WARNING: untranslated string: fwhost st
  WARNING: untranslated string: fwhost type
  WARNING: untranslated string: fwhost used
  WARNING: untranslated string: fwhost welcome
 +WARNING: untranslated string: gen dh
 +WARNING: untranslated string: generate dh key
  WARNING: untranslated string: grouptype
  WARNING: untranslated string: hardware support
 +WARNING: untranslated string: imei
 +WARNING: untranslated string: imsi
  WARNING: untranslated string: incoming firewall access
  WARNING: untranslated string: integrity
  WARNING: untranslated string: invalid input for dpd delay
@@@ -851,23 -846,8 +852,23 @@@ WARNING: untranslated string: mac filte
  WARNING: untranslated string: maximum
  WARNING: untranslated string: minimum
  WARNING: untranslated string: minute
 +WARNING: untranslated string: model
 +WARNING: untranslated string: modem hardware details
 +WARNING: untranslated string: modem information
 +WARNING: untranslated string: modem network bit error rate
 +WARNING: untranslated string: modem network information
 +WARNING: untranslated string: modem network mode
 +WARNING: untranslated string: modem network operator
 +WARNING: untranslated string: modem network registration
 +WARNING: untranslated string: modem network signal quality
 +WARNING: untranslated string: modem no connection
 +WARNING: untranslated string: modem no connection message
 +WARNING: untranslated string: modem sim information
 +WARNING: untranslated string: modem status
 +WARNING: untranslated string: monitor interface
  WARNING: untranslated string: most preferred
  WARNING: untranslated string: no hardware random number generator
 +WARNING: untranslated string: not a valid dh key
  WARNING: untranslated string: notice
  WARNING: untranslated string: ntp common settings
  WARNING: untranslated string: ntp sync
@@@ -882,12 -862,6 +883,13 @@@ WARNING: untranslated string: openvpn p
  WARNING: untranslated string: openvpn subnet is used
  WARNING: untranslated string: other
  WARNING: untranslated string: outgoing firewall access
- WARNING: untranslated string: ovpn dh name
 +WARNING: untranslated string: ovpn crypt options
 +WARNING: untranslated string: ovpn dh
++WARNING: untranslated string: ovpn dh upload
++WARNING: untranslated string: ovpn engines
 +WARNING: untranslated string: ovpn generating the root and host certificates
 +WARNING: untranslated string: ovpn ha
 +WARNING: untranslated string: ovpn hmac
  WARNING: untranslated string: ovpn mgmt in root range
  WARNING: untranslated string: ovpn mtu-disc
  WARNING: untranslated string: ovpn mtu-disc and mtu not 1500
@@@ -914,11 -888,8 +916,11 @@@ WARNING: untranslated string: routing c
  WARNING: untranslated string: routing config changed
  WARNING: untranslated string: routing table
  WARNING: untranslated string: server restart
 +WARNING: untranslated string: show dh
  WARNING: untranslated string: snat new source ip address
  WARNING: untranslated string: snort working
 +WARNING: untranslated string: software version
 +WARNING: untranslated string: source ip country
  WARNING: untranslated string: ssh
  WARNING: untranslated string: static routes
  WARNING: untranslated string: support donation
@@@ -974,13 -945,11 +976,13 @@@ WARNING: untranslated string: tor traff
  WARNING: untranslated string: tor traffic read written
  WARNING: untranslated string: tor use exit nodes
  WARNING: untranslated string: uplink
 +WARNING: untranslated string: upload dh key
  WARNING: untranslated string: upload new ruleset
  WARNING: untranslated string: uptime load average
  WARNING: untranslated string: urlfilter file ext block
  WARNING: untranslated string: urlfilter mode block
  WARNING: untranslated string: urlfilter redirect template
 +WARNING: untranslated string: vendor
  WARNING: untranslated string: visit us at
  WARNING: untranslated string: vpn keyexchange
  WARNING: untranslated string: wlan client
diff --combined doc/language_issues.nl
index 6115f6298203ff30c74b69345344c3dfbaf6fc29,6245eefbf175f98fd03d87ebf82e17f5763d752c..7c6f729dd0dcc5f83348b91f3b691b4636947b85
@@@ -413,6 -413,7 +413,6 @@@ WARNING: translation string unused: opt
  WARNING: translation string unused: optionsfw warning
  WARNING: translation string unused: or
  WARNING: translation string unused: original
 -WARNING: translation string unused: other countries
  WARNING: translation string unused: our donors
  WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall
@@@ -435,6 -436,7 +435,6 @@@ WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall view group
  WARNING: translation string unused: outgoing firewall warning
  WARNING: translation string unused: override mtu
 -WARNING: translation string unused: ovpn
  WARNING: translation string unused: ovpn config
  WARNING: translation string unused: ovpn dl
  WARNING: translation string unused: ovpn log
@@@ -485,12 -487,16 +485,12 @@@ WARNING: translation string unused: rel
  WARNING: translation string unused: removable device advice
  WARNING: translation string unused: reportfile
  WARNING: translation string unused: requested data
 -WARNING: translation string unused: reserved dst port
 -WARNING: translation string unused: reserved src port
  WARNING: translation string unused: restore hardware settings
  WARNING: translation string unused: root
  WARNING: translation string unused: root path
  WARNING: translation string unused: root user password
  WARNING: translation string unused: route subnet is invalid
  WARNING: translation string unused: router ip
 -WARNING: translation string unused: rsvd dst port overlap
 -WARNING: translation string unused: rsvd src port overlap
  WARNING: translation string unused: rules already up to date
  WARNING: translation string unused: safe removal of umounted device
  WARNING: translation string unused: save error
@@@ -628,7 -634,6 +628,7 @@@ WARNING: translation string unused: us
  WARNING: translation string unused: use ibod
  WARNING: translation string unused: view log
  WARNING: translation string unused: vpn aggrmode
 +WARNING: translation string unused: vpn configuration main
  WARNING: translation string unused: vpn incompatible use of defaultroute
  WARNING: translation string unused: vpn mtu invalid
  WARNING: translation string unused: vpn on blue
@@@ -644,50 -649,14 +644,52 @@@ WARNING: translation string unused: xta
  WARNING: translation string unused: xtaccess bad transfert
  WARNING: translation string unused: year-graph
  WARNING: translation string unused: yearly firewallhits
 +WARNING: untranslated string: Number of Countries for the pie chart
  WARNING: untranslated string: Scan for Songs
  WARNING: untranslated string: atm device
  WARNING: untranslated string: bytes
- WARNING: untranslated string: dh name is invalid
 +WARNING: untranslated string: capabilities
 +WARNING: untranslated string: dh
++WARNING: untranslated string: dh key move failed
 +WARNING: untranslated string: dh key warn
++WARNING: untranslated string: dh key warn1
  WARNING: untranslated string: dns servers
  WARNING: untranslated string: drop outgoing
 +WARNING: untranslated string: firewall logs country
  WARNING: untranslated string: fwhost err hostip
- WARNING: untranslated string: ovpn dh name
 +WARNING: untranslated string: gen dh
 +WARNING: untranslated string: generate dh key
 +WARNING: untranslated string: imei
 +WARNING: untranslated string: imsi
 +WARNING: untranslated string: model
 +WARNING: untranslated string: modem hardware details
 +WARNING: untranslated string: modem information
 +WARNING: untranslated string: modem network bit error rate
 +WARNING: untranslated string: modem network information
 +WARNING: untranslated string: modem network mode
 +WARNING: untranslated string: modem network operator
 +WARNING: untranslated string: modem network registration
 +WARNING: untranslated string: modem network signal quality
 +WARNING: untranslated string: modem no connection
 +WARNING: untranslated string: modem no connection message
 +WARNING: untranslated string: modem sim information
 +WARNING: untranslated string: modem status
 +WARNING: untranslated string: monitor interface
 +WARNING: untranslated string: not a valid dh key
 +WARNING: untranslated string: ovpn crypt options
 +WARNING: untranslated string: ovpn dh
++WARNING: untranslated string: ovpn dh upload
++WARNING: untranslated string: ovpn engines
 +WARNING: untranslated string: ovpn generating the root and host certificates
 +WARNING: untranslated string: ovpn ha
 +WARNING: untranslated string: ovpn hmac
  WARNING: untranslated string: random number generator daemon
  WARNING: untranslated string: route config changed
  WARNING: untranslated string: routing config added
  WARNING: untranslated string: routing config changed
  WARNING: untranslated string: routing table
 +WARNING: untranslated string: show dh
 +WARNING: untranslated string: software version
 +WARNING: untranslated string: source ip country
 +WARNING: untranslated string: upload dh key
 +WARNING: untranslated string: vendor
diff --combined doc/language_issues.pl
index b274590afc93dee683038be557af5fe9f6171b02,b854a2b7a661cd648cc7d7e9ca4df61b2ea563c9..54cb32e982402487f14ad1a6fd28c85dfc729981
@@@ -360,6 -360,7 +360,6 @@@ WARNING: translation string unused: opt
  WARNING: translation string unused: optionsfw warning
  WARNING: translation string unused: or
  WARNING: translation string unused: original
 -WARNING: translation string unused: other countries
  WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall
  WARNING: translation string unused: outgoing firewall mode0
@@@ -370,6 -371,7 +370,6 @@@ WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall reset
  WARNING: translation string unused: outgoing firewall warning
  WARNING: translation string unused: override mtu
 -WARNING: translation string unused: ovpn
  WARNING: translation string unused: ovpn config
  WARNING: translation string unused: ovpn dl
  WARNING: translation string unused: ovpn log
@@@ -420,12 -422,16 +420,12 @@@ WARNING: translation string unused: rel
  WARNING: translation string unused: removable device advice
  WARNING: translation string unused: reportfile
  WARNING: translation string unused: requested data
 -WARNING: translation string unused: reserved dst port
 -WARNING: translation string unused: reserved src port
  WARNING: translation string unused: restore hardware settings
  WARNING: translation string unused: root
  WARNING: translation string unused: root path
  WARNING: translation string unused: root user password
  WARNING: translation string unused: route subnet is invalid
  WARNING: translation string unused: router ip
 -WARNING: translation string unused: rsvd dst port overlap
 -WARNING: translation string unused: rsvd src port overlap
  WARNING: translation string unused: rules already up to date
  WARNING: translation string unused: safe removal of umounted device
  WARNING: translation string unused: save error
@@@ -552,7 -558,6 +552,7 @@@ WARNING: translation string unused: us
  WARNING: translation string unused: use ibod
  WARNING: translation string unused: view log
  WARNING: translation string unused: vpn aggrmode
 +WARNING: translation string unused: vpn configuration main
  WARNING: translation string unused: vpn incompatible use of defaultroute
  WARNING: translation string unused: vpn mtu invalid
  WARNING: translation string unused: vpn on blue
@@@ -575,7 -580,6 +575,7 @@@ WARNING: untranslated string: ConnSche
  WARNING: untranslated string: ConnSched shutdown
  WARNING: untranslated string: MB read
  WARNING: untranslated string: MB written
 +WARNING: untranslated string: Number of Countries for the pie chart
  WARNING: untranslated string: Scan for Songs
  WARNING: untranslated string: Set time on boot
  WARNING: untranslated string: addons
@@@ -588,7 -592,6 +588,7 @@@ WARNING: untranslated string: atm devic
  WARNING: untranslated string: attention
  WARNING: untranslated string: bit
  WARNING: untranslated string: bytes
 +WARNING: untranslated string: capabilities
  WARNING: untranslated string: ccd add
  WARNING: untranslated string: ccd choose net
  WARNING: untranslated string: ccd client options
@@@ -633,9 -636,6 +633,10 @@@ WARNING: untranslated string: countryco
  WARNING: untranslated string: dead peer detection
  WARNING: untranslated string: deprecated fs warn
  WARNING: untranslated string: details
- WARNING: untranslated string: dh name is invalid
 +WARNING: untranslated string: dh
++WARNING: untranslated string: dh key move failed
 +WARNING: untranslated string: dh key warn
++WARNING: untranslated string: dh key warn1
  WARNING: untranslated string: dnat address
  WARNING: untranslated string: dns servers
  WARNING: untranslated string: dnsforward
@@@ -674,7 -674,6 +675,7 @@@ WARNING: untranslated string: fireinfo 
  WARNING: untranslated string: fireinfo why enable
  WARNING: untranslated string: fireinfo why read more
  WARNING: untranslated string: fireinfo your profile id
 +WARNING: untranslated string: firewall logs country
  WARNING: untranslated string: firewall rules
  WARNING: untranslated string: first
  WARNING: untranslated string: flag
@@@ -821,12 -820,8 +822,12 @@@ WARNING: untranslated string: fwhost st
  WARNING: untranslated string: fwhost type
  WARNING: untranslated string: fwhost used
  WARNING: untranslated string: fwhost welcome
 +WARNING: untranslated string: gen dh
 +WARNING: untranslated string: generate dh key
  WARNING: untranslated string: grouptype
  WARNING: untranslated string: hardware support
 +WARNING: untranslated string: imei
 +WARNING: untranslated string: imsi
  WARNING: untranslated string: incoming firewall access
  WARNING: untranslated string: integrity
  WARNING: untranslated string: invalid input for dpd delay
@@@ -840,23 -835,8 +841,23 @@@ WARNING: untranslated string: mac filte
  WARNING: untranslated string: maximum
  WARNING: untranslated string: minimum
  WARNING: untranslated string: minute
 +WARNING: untranslated string: model
 +WARNING: untranslated string: modem hardware details
 +WARNING: untranslated string: modem information
 +WARNING: untranslated string: modem network bit error rate
 +WARNING: untranslated string: modem network information
 +WARNING: untranslated string: modem network mode
 +WARNING: untranslated string: modem network operator
 +WARNING: untranslated string: modem network registration
 +WARNING: untranslated string: modem network signal quality
 +WARNING: untranslated string: modem no connection
 +WARNING: untranslated string: modem no connection message
 +WARNING: untranslated string: modem sim information
 +WARNING: untranslated string: modem status
 +WARNING: untranslated string: monitor interface
  WARNING: untranslated string: most preferred
  WARNING: untranslated string: no hardware random number generator
 +WARNING: untranslated string: not a valid dh key
  WARNING: untranslated string: notice
  WARNING: untranslated string: openvpn default
  WARNING: untranslated string: openvpn destination port used
@@@ -871,14 -851,8 +872,15 @@@ WARNING: untranslated string: othe
  WARNING: untranslated string: outgoing firewall access
  WARNING: untranslated string: outgoing firewall p2p allow
  WARNING: untranslated string: outgoing firewall p2p deny
- WARNING: untranslated string: ovpn dh name
 +WARNING: untranslated string: ovpn crypt options
 +WARNING: untranslated string: ovpn dh
++WARNING: untranslated string: ovpn dh upload
++WARNING: untranslated string: ovpn engines
  WARNING: untranslated string: ovpn errmsg green already pushed
  WARNING: untranslated string: ovpn errmsg invalid ip or mask
 +WARNING: untranslated string: ovpn generating the root and host certificates
 +WARNING: untranslated string: ovpn ha
 +WARNING: untranslated string: ovpn hmac
  WARNING: untranslated string: ovpn mgmt in root range
  WARNING: untranslated string: ovpn mtu-disc
  WARNING: untranslated string: ovpn mtu-disc and mtu not 1500
@@@ -907,10 -881,7 +909,10 @@@ WARNING: untranslated string: routing c
  WARNING: untranslated string: routing config changed
  WARNING: untranslated string: routing table
  WARNING: untranslated string: server restart
 +WARNING: untranslated string: show dh
  WARNING: untranslated string: snat new source ip address
 +WARNING: untranslated string: software version
 +WARNING: untranslated string: source ip country
  WARNING: untranslated string: ssh
  WARNING: untranslated string: static routes
  WARNING: untranslated string: support donation
@@@ -966,10 -937,8 +968,10 @@@ WARNING: untranslated string: tor traff
  WARNING: untranslated string: tor traffic read written
  WARNING: untranslated string: tor use exit nodes
  WARNING: untranslated string: uplink
 +WARNING: untranslated string: upload dh key
  WARNING: untranslated string: uptime load average
  WARNING: untranslated string: urlfilter redirect template
 +WARNING: untranslated string: vendor
  WARNING: untranslated string: visit us at
  WARNING: untranslated string: vpn keyexchange
  WARNING: untranslated string: wlan client
diff --combined doc/language_issues.ru
index 18d93a7eb2d33371c392d3997e121a939d280f71,4058098609168fbc2f48ed489da08ac8929b9e24..c7c39ec983cb2e8b769532fe3259d27cf907c4e9
@@@ -354,6 -354,7 +354,6 @@@ WARNING: translation string unused: opt
  WARNING: translation string unused: optionsfw warning
  WARNING: translation string unused: or
  WARNING: translation string unused: original
 -WARNING: translation string unused: other countries
  WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall
  WARNING: translation string unused: outgoing firewall add ip group
@@@ -375,6 -376,7 +375,6 @@@ WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall view group
  WARNING: translation string unused: outgoing firewall warning
  WARNING: translation string unused: override mtu
 -WARNING: translation string unused: ovpn
  WARNING: translation string unused: ovpn config
  WARNING: translation string unused: ovpn dl
  WARNING: translation string unused: ovpn log
@@@ -425,12 -427,16 +425,12 @@@ WARNING: translation string unused: rel
  WARNING: translation string unused: removable device advice
  WARNING: translation string unused: reportfile
  WARNING: translation string unused: requested data
 -WARNING: translation string unused: reserved dst port
 -WARNING: translation string unused: reserved src port
  WARNING: translation string unused: restore hardware settings
  WARNING: translation string unused: root
  WARNING: translation string unused: root path
  WARNING: translation string unused: root user password
  WARNING: translation string unused: route subnet is invalid
  WARNING: translation string unused: router ip
 -WARNING: translation string unused: rsvd dst port overlap
 -WARNING: translation string unused: rsvd src port overlap
  WARNING: translation string unused: rules already up to date
  WARNING: translation string unused: safe removal of umounted device
  WARNING: translation string unused: save error
@@@ -557,7 -563,6 +557,7 @@@ WARNING: translation string unused: us
  WARNING: translation string unused: use ibod
  WARNING: translation string unused: view log
  WARNING: translation string unused: vpn aggrmode
 +WARNING: translation string unused: vpn configuration main
  WARNING: translation string unused: vpn incompatible use of defaultroute
  WARNING: translation string unused: vpn mtu invalid
  WARNING: translation string unused: vpn on blue
@@@ -579,7 -584,6 +579,7 @@@ WARNING: untranslated string: ConnSche
  WARNING: untranslated string: Edit an existing route
  WARNING: untranslated string: MB read
  WARNING: untranslated string: MB written
 +WARNING: untranslated string: Number of Countries for the pie chart
  WARNING: untranslated string: Scan for Songs
  WARNING: untranslated string: addons
  WARNING: untranslated string: advproxy cache-digest
@@@ -591,7 -595,6 +591,7 @@@ WARNING: untranslated string: atm devic
  WARNING: untranslated string: attention
  WARNING: untranslated string: bit
  WARNING: untranslated string: bytes
 +WARNING: untranslated string: capabilities
  WARNING: untranslated string: ccd add
  WARNING: untranslated string: ccd choose net
  WARNING: untranslated string: ccd client options
@@@ -637,9 -640,6 +637,10 @@@ WARNING: untranslated string: countryco
  WARNING: untranslated string: dead peer detection
  WARNING: untranslated string: deprecated fs warn
  WARNING: untranslated string: details
- WARNING: untranslated string: dh name is invalid
 +WARNING: untranslated string: dh
++WARNING: untranslated string: dh key move failed
 +WARNING: untranslated string: dh key warn
++WARNING: untranslated string: dh key warn1
  WARNING: untranslated string: disk access per
  WARNING: untranslated string: dnat address
  WARNING: untranslated string: dns servers
@@@ -669,7 -669,6 +670,7 @@@ WARNING: untranslated string: extrahd m
  WARNING: untranslated string: extrahd to
  WARNING: untranslated string: extrahd to root
  WARNING: untranslated string: extrahd you cant mount
 +WARNING: untranslated string: firewall logs country
  WARNING: untranslated string: firewall rules
  WARNING: untranslated string: first
  WARNING: untranslated string: flag
@@@ -816,12 -815,8 +817,12 @@@ WARNING: untranslated string: fwhost st
  WARNING: untranslated string: fwhost type
  WARNING: untranslated string: fwhost used
  WARNING: untranslated string: fwhost welcome
 +WARNING: untranslated string: gen dh
 +WARNING: untranslated string: generate dh key
  WARNING: untranslated string: grouptype
  WARNING: untranslated string: hardware support
 +WARNING: untranslated string: imei
 +WARNING: untranslated string: imsi
  WARNING: untranslated string: incoming firewall access
  WARNING: untranslated string: incoming traffic in bytes per second
  WARNING: untranslated string: integrity
@@@ -836,23 -831,8 +837,23 @@@ WARNING: untranslated string: mac filte
  WARNING: untranslated string: maximum
  WARNING: untranslated string: minimum
  WARNING: untranslated string: minute
 +WARNING: untranslated string: model
 +WARNING: untranslated string: modem hardware details
 +WARNING: untranslated string: modem information
 +WARNING: untranslated string: modem network bit error rate
 +WARNING: untranslated string: modem network information
 +WARNING: untranslated string: modem network mode
 +WARNING: untranslated string: modem network operator
 +WARNING: untranslated string: modem network registration
 +WARNING: untranslated string: modem network signal quality
 +WARNING: untranslated string: modem no connection
 +WARNING: untranslated string: modem no connection message
 +WARNING: untranslated string: modem sim information
 +WARNING: untranslated string: modem status
 +WARNING: untranslated string: monitor interface
  WARNING: untranslated string: most preferred
  WARNING: untranslated string: no hardware random number generator
 +WARNING: untranslated string: not a valid dh key
  WARNING: untranslated string: notice
  WARNING: untranslated string: openvpn default
  WARNING: untranslated string: openvpn destination port used
@@@ -866,12 -846,6 +867,13 @@@ WARNING: untranslated string: openvpn s
  WARNING: untranslated string: other
  WARNING: untranslated string: outgoing firewall access
  WARNING: untranslated string: outgoing traffic in bytes per second
- WARNING: untranslated string: ovpn dh name
 +WARNING: untranslated string: ovpn crypt options
 +WARNING: untranslated string: ovpn dh
++WARNING: untranslated string: ovpn dh upload
++WARNING: untranslated string: ovpn engines
 +WARNING: untranslated string: ovpn generating the root and host certificates
 +WARNING: untranslated string: ovpn ha
 +WARNING: untranslated string: ovpn hmac
  WARNING: untranslated string: ovpn mgmt in root range
  WARNING: untranslated string: ovpn mtu-disc
  WARNING: untranslated string: ovpn mtu-disc and mtu not 1500
@@@ -897,10 -871,7 +899,10 @@@ WARNING: untranslated string: routing c
  WARNING: untranslated string: routing config changed
  WARNING: untranslated string: routing table
  WARNING: untranslated string: server restart
 +WARNING: untranslated string: show dh
  WARNING: untranslated string: snat new source ip address
 +WARNING: untranslated string: software version
 +WARNING: untranslated string: source ip country
  WARNING: untranslated string: ssh
  WARNING: untranslated string: static routes
  WARNING: untranslated string: support donation
@@@ -955,10 -926,8 +957,10 @@@ WARNING: untranslated string: tor traff
  WARNING: untranslated string: tor traffic read written
  WARNING: untranslated string: tor use exit nodes
  WARNING: untranslated string: uplink
 +WARNING: untranslated string: upload dh key
  WARNING: untranslated string: uptime load average
  WARNING: untranslated string: urlfilter redirect template
 +WARNING: untranslated string: vendor
  WARNING: untranslated string: visit us at
  WARNING: untranslated string: vpn keyexchange
  WARNING: untranslated string: wlan client
diff --combined doc/language_issues.tr
index ad6086cf5a7e02907cf88aa0250c4b84efdce983,e6af830a5d47d90f302ff5094fa3d37a3016700e..06cacf10fa353c3e60ed10662bca0cd953f11bca
@@@ -412,6 -412,7 +412,6 @@@ WARNING: translation string unused: opt
  WARNING: translation string unused: optionsfw warning
  WARNING: translation string unused: or
  WARNING: translation string unused: original
 -WARNING: translation string unused: other countries
  WARNING: translation string unused: our donors
  WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall
@@@ -434,6 -435,7 +434,6 @@@ WARNING: translation string unused: out
  WARNING: translation string unused: outgoing firewall view group
  WARNING: translation string unused: outgoing firewall warning
  WARNING: translation string unused: override mtu
 -WARNING: translation string unused: ovpn
  WARNING: translation string unused: ovpn config
  WARNING: translation string unused: ovpn dl
  WARNING: translation string unused: ovpn log
@@@ -484,12 -486,16 +484,12 @@@ WARNING: translation string unused: rel
  WARNING: translation string unused: removable device advice
  WARNING: translation string unused: reportfile
  WARNING: translation string unused: requested data
 -WARNING: translation string unused: reserved dst port
 -WARNING: translation string unused: reserved src port
  WARNING: translation string unused: restore hardware settings
  WARNING: translation string unused: root
  WARNING: translation string unused: root path
  WARNING: translation string unused: root user password
  WARNING: translation string unused: route subnet is invalid
  WARNING: translation string unused: router ip
 -WARNING: translation string unused: rsvd dst port overlap
 -WARNING: translation string unused: rsvd src port overlap
  WARNING: translation string unused: rules already up to date
  WARNING: translation string unused: safe removal of umounted device
  WARNING: translation string unused: save error
@@@ -627,7 -633,6 +627,7 @@@ WARNING: translation string unused: us
  WARNING: translation string unused: use ibod
  WARNING: translation string unused: view log
  WARNING: translation string unused: vpn aggrmode
 +WARNING: translation string unused: vpn configuration main
  WARNING: translation string unused: vpn incompatible use of defaultroute
  WARNING: translation string unused: vpn mtu invalid
  WARNING: translation string unused: vpn on blue
@@@ -643,46 -648,10 +643,48 @@@ WARNING: translation string unused: xta
  WARNING: translation string unused: xtaccess bad transfert
  WARNING: translation string unused: year-graph
  WARNING: translation string unused: yearly firewallhits
 +WARNING: untranslated string: Number of Countries for the pie chart
  WARNING: untranslated string: Scan for Songs
  WARNING: untranslated string: bytes
- WARNING: untranslated string: dh name is invalid
 +WARNING: untranslated string: capabilities
 +WARNING: untranslated string: dh
++WARNING: untranslated string: dh key move failed
 +WARNING: untranslated string: dh key warn
++WARNING: untranslated string: dh key warn1
 +WARNING: untranslated string: firewall logs country
  WARNING: untranslated string: fwhost err hostip
- WARNING: untranslated string: ovpn dh name
 +WARNING: untranslated string: gen dh
 +WARNING: untranslated string: generate dh key
 +WARNING: untranslated string: imei
 +WARNING: untranslated string: imsi
 +WARNING: untranslated string: model
 +WARNING: untranslated string: modem hardware details
 +WARNING: untranslated string: modem information
 +WARNING: untranslated string: modem network bit error rate
 +WARNING: untranslated string: modem network information
 +WARNING: untranslated string: modem network mode
 +WARNING: untranslated string: modem network operator
 +WARNING: untranslated string: modem network registration
 +WARNING: untranslated string: modem network signal quality
 +WARNING: untranslated string: modem no connection
 +WARNING: untranslated string: modem no connection message
 +WARNING: untranslated string: modem sim information
 +WARNING: untranslated string: modem status
 +WARNING: untranslated string: monitor interface
 +WARNING: untranslated string: not a valid dh key
 +WARNING: untranslated string: ovpn crypt options
 +WARNING: untranslated string: ovpn dh
++WARNING: untranslated string: ovpn dh upload
++WARNING: untranslated string: ovpn engines
 +WARNING: untranslated string: ovpn generating the root and host certificates
 +WARNING: untranslated string: ovpn ha
 +WARNING: untranslated string: ovpn hmac
  WARNING: untranslated string: route config changed
  WARNING: untranslated string: routing config added
  WARNING: untranslated string: routing config changed
  WARNING: untranslated string: routing table
 +WARNING: untranslated string: show dh
 +WARNING: untranslated string: software version
 +WARNING: untranslated string: source ip country
 +WARNING: untranslated string: upload dh key
 +WARNING: untranslated string: vendor
diff --combined doc/language_missings
index 939d4b9a5dda80b6a03f3555cb3b8e0ac36f441a,1a386c19c23e1affcf211fec821fc91c669d8013..d25ea40f8dc7e8ece5c4a8803b2c60e591eb4a4b
@@@ -6,6 -6,6 +6,7 @@@
  ############################################################################
  < addon
  < ccd maxclients
++< ovpn_fragment
  ############################################################################
  # Checking install/setup translations for language: fr                     #
  ############################################################################
@@@ -26,7 -26,6 +27,7 @@@
  < atm device
  < attention
  < bit
 +< capabilities
  < ccd add
  < ccd choose net
  < ccd clientip
  < default ip
  < deprecated fs warn
  < details
- < dh name is invalid
 +< dh
++< dh key move failed
 +< dh key warn
++< dh key warn1
  < dnat address
  < dns address deleted txt
  < dnsforward
@@@ -90,6 -86,8 +92,6 @@@
  < dnsforward entries
  < dnsforward forward_server
  < dnsforward zone
 -< dns servers
 -< downlink
  < dpd delay
  < dpd timeout
  < drop action
  < fireinfo why enable
  < fireinfo why read more
  < fireinfo your profile id
 +< firewall logs country
  < firewall rules
 -< first
  < flag
  < forward firewall
  < fw default drop
  < fw settings dropdown
  < fw settings remark
  < fw settings ruletable
 +< gen dh
 +< generate dh key
  < grouptype
  < hardware support
 +< imei
 +< imsi
  < incoming firewall access
  < integrity
  < invalid input for dpd delay
  < ipsec
  < ipsec network
  < ipsec no connections
 -< last
  < least preferred
  < lifetime
  < mac filter
  < MB written
  < minimum
  < minute
 +< model
 +< modem hardware details
 +< modem information
 +< modem network bit error rate
 +< modem network information
 +< modem network mode
 +< modem network operator
 +< modem network registration
 +< modem network signal quality
 +< modem no connection
 +< modem no connection message
 +< modem sim information
 +< modem status
  < most preferred
 +< never
  < no hardware random number generator
 +< not a valid dh key
  < notice
  < ntp common settings
  < ntp sync
 +< Number of Countries for the pie chart
  < openvpn default
  < openvpn destination port used
  < openvpn disabled
  < other
  < our donors
  < outgoing firewall access
- < ovpn dh name
 +< ovpn crypt options
 +< ovpn dh
++< ovpn dh upload
 +< ovpn engines
 +< ovpn generating the root and host certificates
 +< ovpn ha
 +< ovpn hmac
  < ovpn mgmt in root range
  < ovpn mtu-disc
  < ovpn mtu-disc and mtu not 1500
  < ovpn mtu-disc yes
  < ovpn no connections
  < ovpn port in root range
 +< ovpn reneg sec
  < p2p block
  < p2p block save notice
  < proxy reports
  < random number generator daemon
  < red1
  < server restart
 +< show dh
  < snat new source ip address
  < snort working
 +< software version
 +< source ip country
  < ssh
  < static routes
  < support donation
  < tor use exit nodes
  < updxlrtr sources
  < updxlrtr standard view
 -< uplink
 +< upload dh key
  < upload new ruleset
  < uptime
  < uptime load average
  < urlfilter file ext block
  < urlfilter mode block
  < urlfilter redirect template
 +< vendor
  < visit us at
  < vpn keyexchange
  < wlanap access point
  < atm device
  < attention
  < bit
 +< capabilities
  < ccd add
  < ccd choose net
  < ccd clientip
  < default ip
  < deprecated fs warn
  < details
- < dh name is invalid
 +< dh
++< dh key move failed
 +< dh key warn
++< dh key warn1
  < dnat address
  < dnsforward
  < dnsforward add a new entry
  < dnsforward entries
  < dnsforward forward_server
  < dnsforward zone
 -< dns servers
 -< downlink
  < dpd delay
  < dpd timeout
  < drop action
  < fireinfo why enable
  < fireinfo why read more
  < fireinfo your profile id
 +< firewall logs country
  < firewall rules
 -< first
  < flag
  < forward firewall
  < fw default drop
  < fw settings dropdown
  < fw settings remark
  < fw settings ruletable
 +< gen dh
 +< generate dh key
  < grouptype
  < hardware support
 +< imei
 +< imsi
  < incoming firewall access
  < integrity
  < invalid input for dpd delay
  < ipsec
  < ipsec network
  < ipsec no connections
 -< last
  < least preferred
  < lifetime
  < mac filter
  < MB written
  < minimum
  < minute
 +< model
 +< modem hardware details
 +< modem information
 +< modem network bit error rate
 +< modem network information
 +< modem network mode
 +< modem network operator
 +< modem network registration
 +< modem network signal quality
 +< modem no connection
 +< modem no connection message
 +< modem sim information
 +< modem status
  < most preferred
 +< never
  < no hardware random number generator
 +< not a valid dh key
  < notice
 +< Number of Countries for the pie chart
  < openvpn default
  < openvpn destination port used
  < openvpn disabled
  < outgoing firewall p2p description 2
  < outgoing firewall p2p description 3
  < outgoing firewall view group
- < ovpn dh name
 +< ovpn crypt options
 +< ovpn dh
++< ovpn dh upload
 +< ovpn engines
  < ovpn errmsg green already pushed
  < ovpn errmsg invalid ip or mask
 +< ovpn generating the root and host certificates
 +< ovpn ha
 +< ovpn hmac
  < ovpn mgmt in root range
  < ovpn mtu-disc
  < ovpn mtu-disc and mtu not 1500
  < ovpn mtu-disc yes
  < ovpn no connections
  < ovpn port in root range
 +< ovpn reneg sec
  < ovpn routes push
  < ovpn routes push options
  < p2p block
  < red1
  < server restart
  < Set time on boot
 +< show dh
  < snat new source ip address
 +< software version
 +< source ip country
  < ssh
  < static routes
  < support donation
  < tor use exit nodes
  < updxlrtr sources
  < updxlrtr standard view
 -< uplink
 +< upload dh key
  < uptime
  < uptime load average
  < urlfilter redirect template
 +< vendor
  < visit us at
  < vpn keyexchange
  < wlanap country
  < atm device
  < attention
  < bit
 +< capabilities
  < ccd add
  < ccd choose net
  < ccd clientip
  < default ip
  < deprecated fs warn
  < details
- < dh name is invalid
 +< dh
++< dh key move failed
 +< dh key warn
++< dh key warn1
  < dnat address
  < dnsforward
  < dnsforward add a new entry
  < dnsforward entries
  < dnsforward forward_server
  < dnsforward zone
 -< dns servers
 -< downlink
  < dpd delay
  < dpd timeout
  < drop action
  < extrahd unable to read
  < extrahd unable to write
  < extrahd you cant mount
 +< firewall logs country
  < firewall rules
 -< first
  < flag
  < forward firewall
  < fw default drop
  < fw settings dropdown
  < fw settings remark
  < fw settings ruletable
 +< gen dh
 +< generate dh key
  < grouptype
  < hardware support
 +< imei
 +< imsi
  < incoming firewall access
  < integrity
  < invalid input for dpd delay
  < ipsec
  < ipsec network
  < ipsec no connections
 -< last
  < least preferred
  < lifetime
  < mac filter
  < MB written
  < minimum
  < minute
 +< model
 +< modem hardware details
 +< modem information
 +< modem network bit error rate
 +< modem network information
 +< modem network mode
 +< modem network operator
 +< modem network registration
 +< modem network signal quality
 +< modem no connection
 +< modem no connection message
 +< modem sim information
 +< modem status
  < most preferred
 +< never
  < no hardware random number generator
 +< not a valid dh key
  < notice
 +< Number of Countries for the pie chart
  < openvpn default
  < openvpn destination port used
  < openvpn disabled
  < other
  < our donors
  < outgoing firewall access
- < ovpn dh name
 +< ovpn crypt options
 +< ovpn dh
++< ovpn dh upload
 +< ovpn engines
  < ovpn errmsg green already pushed
  < ovpn errmsg invalid ip or mask
 +< ovpn generating the root and host certificates
 +< ovpn ha
 +< ovpn hmac
  < ovpn mgmt in root range
  < ovpn mtu-disc
  < ovpn mtu-disc and mtu not 1500
  < ovpn mtu-disc yes
  < ovpn no connections
  < ovpn port in root range
 +< ovpn reneg sec
  < ovpn routes push
  < ovpn routes push options
  < p2p block
  < random number generator daemon
  < red1
  < server restart
 +< show dh
  < snat new source ip address
 +< software version
 +< source ip country
  < ssh
  < static routes
  < support donation
  < tor use exit nodes
  < updxlrtr sources
  < updxlrtr standard view
 -< uplink
 +< upload dh key
  < uptime
  < uptime load average
  < urlfilter redirect template
 +< vendor
  < visit us at
  < vpn keyexchange
  < wlanap country
  < atm device
  < attention
  < bit
 +< capabilities
  < ccd add
  < ccd choose net
  < ccd clientip
  < default ip
  < deprecated fs warn
  < details
- < dh name is invalid
 +< dh
++< dh key move failed
 +< dh key warn
++< dh key warn1
  < disk access per
  < dnat address
  < dnsforward
  < dnsforward entries
  < dnsforward forward_server
  < dnsforward zone
 -< dns servers
 -< downlink
  < dpd delay
  < dpd timeout
  < drop action
  < extrahd unable to read
  < extrahd unable to write
  < extrahd you cant mount
 +< firewall logs country
  < firewall rules
 -< first
  < flag
  < forward firewall
  < frequency
  < fw settings dropdown
  < fw settings remark
  < fw settings ruletable
 +< gen dh
 +< generate dh key
  < grouptype
  < hardware support
  < hour-graph
 +< imei
 +< imsi
  < incoming firewall access
  < incoming traffic in bytes per second
  < integrity
  < ipsec
  < ipsec network
  < ipsec no connections
 -< last
  < least preferred
  < lifetime
  < mac filter
  < MB written
  < minimum
  < minute
 +< model
 +< modem hardware details
 +< modem information
 +< modem network bit error rate
 +< modem network information
 +< modem network mode
 +< modem network operator
 +< modem network registration
 +< modem network signal quality
 +< modem no connection
 +< modem no connection message
 +< modem sim information
 +< modem status
  < month-graph
  < most preferred
 +< never
  < no hardware random number generator
 +< not a valid dh key
  < notice
 +< Number of Countries for the pie chart
  < openvpn default
  < openvpn destination port used
  < openvpn disabled
  < our donors
  < outgoing firewall access
  < outgoing traffic in bytes per second
- < ovpn dh name
 +< ovpn crypt options
 +< ovpn dh
++< ovpn dh upload
 +< ovpn engines
 +< ovpn generating the root and host certificates
 +< ovpn ha
 +< ovpn hmac
  < ovpn mgmt in root range
  < ovpn mtu-disc
  < ovpn mtu-disc and mtu not 1500
  < ovpn mtu-disc yes
  < ovpn no connections
  < ovpn port in root range
 +< ovpn reneg sec
  < p2p block
  < p2p block save notice
  < proxy reports
  < random number generator daemon
  < red1
  < server restart
 +< show dh
  < snat new source ip address
 +< software version
 +< source ip country
  < ssh
  < static routes
  < support donation
  < tor use exit nodes
  < updxlrtr sources
  < updxlrtr standard view
 -< uplink
 +< upload dh key
  < uptime
  < uptime load average
  < urlfilter redirect template
 +< vendor
  < visit us at
  < vpn keyexchange
  < week-graph
index ceb63d45669ab1799292b5b3ccb9ccffa237eba7,0c9e73d5b86b9662d9315c0e3828626379e18214..df5f9ece2a3a0732c8d21fe07ec471310028e6cc
@@@ -2,7 -2,7 +2,7 @@@
  ###############################################################################
  #                                                                             #
  # IPFire.org - A linux based firewall                                         #
- # Copyright (C) 2007-2013  IPFire Team  <info@ipfire.org>                     #
+ # Copyright (C) 2007-2014  IPFire Team  <info@ipfire.org>                     #
  #                                                                             #
  # This program is free software: you can redistribute it and/or modify        #
  # it under the terms of the GNU General Public License as published by        #
@@@ -19,7 -19,7 +19,6 @@@
  #                                                                             #
  ###############################################################################
  ###
- # Based on IPFireCore 76
 -# Based on IPFireCore 77
  ###
  use CGI;
  use CGI qw/:standard/;
@@@ -90,8 -90,10 +89,10 @@@ $cgiparams{'DCOMPLZO'} = 'off'
  $cgiparams{'MSSFIX'} = '';
  $cgiparams{'number'} = '';
  $cgiparams{'PMTU_DISCOVERY'} = '';
- $cgiparams{'DAUTH'} = '';
  $cgiparams{'DCIPHER'} = '';
+ $cgiparams{'DAUTH'} = '';
+ $cgiparams{'TLSAUTH'} = '';
+ $cgiparams{'ENGINES'} = '';
  $routes_push_file = "${General::swroot}/ovpn/routes_push";
  unless (-e $routes_push_file)    { system("touch $routes_push_file"); }
  unless (-e "${General::swroot}/ovpn/ccd.conf")    { system("touch ${General::swroot}/ovpn/ccd.conf"); }
@@@ -226,51 -228,6 +227,51 @@@ sub checkportin
        }
  }
  
 +# Darren Critchley - certain ports are reserved for IPFire
 +# TCP 67,68,81,222,444
 +# UDP 67,68
 +# Params passed in -> port, rangeyn, protocol
 +sub disallowreserved
 +{
 +      # port 67 and 68 same for tcp and udp, don't bother putting in an array
 +      my $msg = "";
 +      my @tcp_reserved = (81,222,444);
 +      my $prt = $_[0]; # the port or range
 +      my $ryn = $_[1]; # tells us whether or not it is a port range
 +      my $prot = $_[2]; # protocol
 +      my $srcdst = $_[3]; # source or destination
 +      if ($ryn) { # disect port range
 +              if ($srcdst eq "src") {
 +                      $msg = "$Lang::tr{'rsvd src port overlap'}";
 +              } else {
 +                      $msg = "$Lang::tr{'rsvd dst port overlap'}";
 +              }
 +              my @tmprng = split(/\:/,$prt);
 +              unless (67 < $tmprng[0] || 67 > $tmprng[1]) { $errormessage="$msg 67"; return; }
 +              unless (68 < $tmprng[0] || 68 > $tmprng[1]) { $errormessage="$msg 68"; return; }
 +              if ($prot eq "tcp") {
 +                      foreach my $prange (@tcp_reserved) {
 +                              unless ($prange < $tmprng[0] || $prange > $tmprng[1]) { $errormessage="$msg $prange"; return; }
 +                      }
 +              }
 +      } else {
 +              if ($srcdst eq "src") {
 +                      $msg = "$Lang::tr{'reserved src port'}";
 +              } else {
 +                      $msg = "$Lang::tr{'reserved dst port'}";
 +              }
 +              if ($prt == 67) { $errormessage="$msg 67"; return; }
 +              if ($prt == 68) { $errormessage="$msg 68"; return; }
 +              if ($prot eq "tcp") {
 +                      foreach my $prange (@tcp_reserved) {
 +                              if ($prange == $prt) { $errormessage="$msg $prange"; return; }
 +                      }
 +              }
 +      }
 +      return;
 +}
 +
 +
  sub writeserverconf {
      my %sovpnsettings = ();  
      my @temp = ();  
      print CONF "ca ${General::swroot}/ovpn/ca/cacert.pem\n";
      print CONF "cert ${General::swroot}/ovpn/certs/servercert.pem\n";
      print CONF "key ${General::swroot}/ovpn/certs/serverkey.pem\n";
-       print CONF "dh ${General::swroot}/ovpn/ca/dh1024.pem\n";
+     print CONF "dh ${General::swroot}/ovpn/ca/$cgiparams{'DH_NAME'}\n";
      my @tempovpnsubnet = split("\/",$sovpnsettings{'DOVPN_SUBNET'});
      print CONF "server $tempovpnsubnet[0] $tempovpnsubnet[1]\n";
      #print CONF "push \"route $netsettings{'GREEN_NETADDRESS'} $netsettings{'GREEN_NETMASK'}\"\n";
 -   
 +
      # Check if we are using mssfix, fragment or mtu-disc and set the corretct mtu of 1500.
      # If we doesn't use one of them, we can use the configured mtu value.
      if ($sovpnsettings{'MSSFIX'} eq 'on') 
      elsif ($sovpnsettings{'FRAGMENT'} ne '' && $sovpnsettings{'DPROTOCOL'} ne 'tcp') 
        { print CONF "$sovpnsettings{'DDEVICE'}-mtu 1500\n"; }
      elsif (($sovpnsettings{'PMTU_DISCOVERY'} eq 'yes') ||
 -         ($sovpnsettings{'PMTU_DISCOVERY'} eq 'maybe') ||
 -         ($sovpnsettings{'PMTU_DISCOVERY'} eq 'no' ))
 +      ($sovpnsettings{'PMTU_DISCOVERY'} eq 'maybe') ||
 +      ($sovpnsettings{'PMTU_DISCOVERY'} eq 'no' ))
        { print CONF "$sovpnsettings{'DDEVICE'}-mtu 1500\n"; } 
      else 
        { print CONF "$sovpnsettings{'DDEVICE'}-mtu $sovpnsettings{'DMTU'}\n"; }
        print CONF "client-to-client\n";
      }
      if ($sovpnsettings{MSSFIX} eq 'on') {
 -      print CONF "mssfix\n";
 +              print CONF "mssfix\n";
      }
      if ($sovpnsettings{FRAGMENT} ne '' && $sovpnsettings{'DPROTOCOL'} ne 'tcp') {
 -      print CONF "fragment $sovpnsettings{'FRAGMENT'}\n";   
 +              print CONF "fragment $sovpnsettings{'FRAGMENT'}\n";
      }
  
      # Check if a valid operating mode has been choosen and use it.
      print CONF "status-version 1\n";
      print CONF "status /var/log/ovpnserver.log 30\n";
      print CONF "cipher $sovpnsettings{DCIPHER}\n";
-       print CONF "auth $sovpnsettings{DAUTH}\n";
+     if ($sovpnsettings{'DAUTH'} eq '') {
+         print CONF "";
+     } else {
+       print CONF "auth $sovpnsettings{'DAUTH'}\n";
+     }
+     if ($sovpnsettings{'TLSAUTH'} eq 'on') {
+       print CONF "tls-auth ${General::swroot}/ovpn/ca/ta.key 0\n";
+     }
+     if ($sovpnsettings{ENGINES} eq 'disabled') {
+       print CONF "";
+     } else {
+       print CONF "engine $sovpnsettings{ENGINES}\n";
+     }
      if ($sovpnsettings{DCOMPLZO} eq 'on') {
          print CONF "comp-lzo\n";
      }
@@@ -559,7 -528,7 +572,7 @@@ sub getccdadresse
        my @iprange=();
        my %ccdhash=();
        &General::readhasharray("${General::swroot}/ovpn/ovpnconfig", \%ccdhash);
 -      $iprange[0]=$ip1.".".$ip2.".".$ip3.".".($ip4+2);
 +      $iprange[0]=$ip1.".".$ip2.".".$ip3.".".2;
        for (my $i=1;$i<=$count;$i++) {
                my $tmpip=$iprange[$i-1];
                my $stepper=$i*4;
@@@ -782,6 -751,8 +795,8 @@@ if ($cgiparams{'ACTION'} eq $Lang::tr{'
      $vpnsettings{'ROUTES_PUSH'} = $cgiparams{'ROUTES_PUSH'};
      $vpnsettings{'PMTU_DISCOVERY'} = $cgiparams{'PMTU_DISCOVERY'};
      $vpnsettings{'DAUTH'} = $cgiparams{'DAUTH'};
+     $vpnsettings{'TLSAUTH'} = $cgiparams{'TLSAUTH'};
+     $vpnsettings{'ENGINES'} = $cgiparams{'ENGINES'};
      my @temp=();
      
      if ($cgiparams{'FRAGMENT'} eq '') {
                        $vpnsettings{'FRAGMENT'} = $cgiparams{'FRAGMENT'};
        }
      }
      if ($cgiparams{'MSSFIX'} ne 'on') {
        delete $vpnsettings{'MSSFIX'};
      } else {
        $vpnsettings{'MSSFIX'} = $cgiparams{'MSSFIX'};
      }
  
+    # Create ta.key for tls-auth if not presant
+    if ($cgiparams{'TLSAUTH'} eq 'on') {
+       if ( ! -e "${General::swroot}/ovpn/ca/ta.key") {
+               system('/usr/sbin/openvpn', '--genkey', '--secret', "${General::swroot}/ovpn/ca/ta.key")
+       }
+     }
      if (($cgiparams{'PMTU_DISCOVERY'} eq 'yes') ||
          ($cgiparams{'PMTU_DISCOVERY'} eq 'maybe') ||
          ($cgiparams{'PMTU_DISCOVERY'} eq 'no' )) {
@@@ -976,11 -955,21 +999,21 @@@ unless(-d "${General::swroot}/ovpn/n2nc
    print SERVERCONF "ca ${General::swroot}/ovpn/ca/cacert.pem\n"; 
    print SERVERCONF "cert ${General::swroot}/ovpn/certs/servercert.pem\n"; 
    print SERVERCONF "key ${General::swroot}/ovpn/certs/serverkey.pem\n"; 
-   print SERVERCONF "dh ${General::swroot}/ovpn/ca/dh1024.pem\n";
+   print SERVERCONF "dh ${General::swroot}/ovpn/ca/$cgiparams{'DH_NAME'}\n";
    print SERVERCONF "# Cipher\n"; 
    print SERVERCONF "cipher $cgiparams{'DCIPHER'}\n";
-   print SERVERCONF "# HMAC algorithm\n";
-   print SERVERCONF "auth $cgiparams{'DAUTH'}\n";
+   if ($cgiparams{'DAUTH'} eq '') {
+       print SERVERCONF "auth SHA1\n";
+   } else {
+       print SERVERCONF "# HMAC algorithm\n";
+       print SERVERCONF "auth $cgiparams{'DAUTH'}\n";
+   }
+   if ($cgiparams{'ENGINES'} eq 'disabled') {
+       print SERVERCONF "";
+   } else {
+       print SERVERCONF "# Crypto engine\n";
+       print SERVERCONF "engine $cgiparams{'ENGINES'}\n";
+   }
    if ($cgiparams{'COMPLZO'} eq 'on') {
     print SERVERCONF "# Enable Compression\n";
     print SERVERCONF "comp-lzo\r\n";
  
  if ($cgiparams{'ACTION'} eq $Lang::tr{'save'} && $cgiparams{'TYPE'} eq 'net' && $cgiparams{'SIDE'} eq 'client')
  {
 +
          my @ovsubnettemp =  split(/\./,$cgiparams{'OVPN_SUBNET'});
          my $ovsubnet =  "$ovsubnettemp[0].$ovsubnettemp[1].$ovsubnettemp[2]";
          my @remsubnet =  split(/\//,$cgiparams{'REMOTE_SUBNET'});
@@@ -1069,13 -1057,23 +1102,23 @@@ unless(-d "${General::swroot}/ovpn/n2nc
    print CLIENTCONF "tls-client\n"; 
    print CLIENTCONF "# Cipher\n"; 
    print CLIENTCONF "cipher $cgiparams{'DCIPHER'}\n";
-   print CLIENTCONF "# HMAC algorithm\n";
-   print CLIENTCONF "auth $cgiparams{'DAUTH'}\n";
    print CLIENTCONF "pkcs12 ${General::swroot}/ovpn/certs/$cgiparams{'NAME'}.p12\r\n";
+   if ($cgiparams{'DAUTH'} eq '') {
+       print CLIENTCONF "auth SHA1\n";
+   } else {
+       print CLIENTCONF "# HMAC algorithm\n";
+       print CLIENTCONF "auth $cgiparams{'DAUTH'}\n";
+   }
+   if ($cgiparams{'ENGINES'} eq 'disabled') {
+       print CLIENTCONF "";
+   } else {
+       print CLIENTCONF "# Crypto engine\n";
+       print CLIENTCONF "engine $cgiparams{'ENGINES'}\n";
+   }
    if ($cgiparams{'COMPLZO'} eq 'on') {
     print CLIENTCONF "# Enable Compression\n";
     print CLIENTCONF "comp-lzo\r\n";
 -     }
 +  }
    print CLIENTCONF "# Debug Level\n"; 
    print CLIENTCONF "verb 3\n"; 
    print CLIENTCONF "# Tunnel check\n"; 
@@@ -1114,7 -1112,7 +1157,7 @@@ if ($cgiparams{'ACTION'} eq $Lang::tr{'
      
      if (! &General::validipandmask($cgiparams{'DOVPN_SUBNET'})) {
              $errormessage = $Lang::tr{'ovpn subnet is invalid'};
 -      goto SETTINGS_ERROR;
 +                      goto SETTINGS_ERROR;
      }
      my @tmpovpnsubnet = split("\/",$cgiparams{'DOVPN_SUBNET'});
      
@@@ -1205,41 -1203,43 +1248,43 @@@ SETTINGS_ERROR
        }
      }
      while ($file = glob("${General::swroot}/ovpn/ca/*")) {
-               unlink $file
+       unlink $file;
      }
      while ($file = glob("${General::swroot}/ovpn/certs/*")) {
-               unlink $file
+       unlink $file;
      }
      while ($file = glob("${General::swroot}/ovpn/crls/*")) {
-               unlink $file
+       unlink $file;
      }
 -    &cleanssldatabase();
 +      &cleanssldatabase();
      if (open(FILE, ">${General::swroot}/ovpn/caconfig")) {
          print FILE "";
          close FILE;
      }
-       if (open(FILE, ">${General::swroot}/ovpn/ccdroute")) {
-               print FILE "";
-               close FILE;
-       }
-       if (open(FILE, ">${General::swroot}/ovpn/ccdroute2")) {
-               print FILE "";
-               close FILE;
-       }
-       while ($file = glob("${General::swroot}/ovpn/ccd/*")) {
-               unlink $file
-       }
-       if (open(FILE, ">${General::swroot}/ovpn/ovpn-leases.db")) {
-               print FILE "";
-               close FILE;
-       }
-       if (open(FILE, ">${General::swroot}/ovpn/ovpnconfig")) {
-               print FILE "";
-               close FILE;
-       }
-       while ($file = glob("${General::swroot}/ovpn/n2nconf/*")) {
-               system ("rm -rf $file")
-       }
+     if (open(FILE, ">${General::swroot}/ovpn/ccdroute")) {
+       print FILE "";
+       close FILE;
+     }
+     if (open(FILE, ">${General::swroot}/ovpn/ccdroute2")) {
+       print FILE "";
+       close FILE;
+     }
+     while ($file = glob("${General::swroot}/ovpn/ccd/*")) {
+       unlink $file
+     }
+     if (open(FILE, ">${General::swroot}/ovpn/ovpn-leases.db")) {
+       print FILE "";
+       close FILE;
+     }
+     if (open(FILE, ">${General::swroot}/ovpn/ovpnconfig")) {
+       print FILE "";
+       close FILE;
+     }
+     while ($file = glob("${General::swroot}/ovpn/n2nconf/*")) {
+       system ("rm -rf $file");
+     }
+     #&writeserverconf();
  ###
  ### Reset all step 1
  ###
                        <tr>
                                <td align='center'>
                                <input type='hidden' name='AREUSURE' value='yes' />
 +                              <b><font color='${Header::colourred}'>$Lang::tr{'capswarning'}</font></b>: 
+                               <b><font color='${Header::colourred}'>$Lang::tr{'capswarning'}</font></b>:
                                $Lang::tr{'resetting the vpn configuration will remove the root ca, the host certificate and all certificate based connections'}</td>
                        </tr>
                        <tr>
                        </tr>
                </table>
        </form>
 -
  END
      ;
      &Header::closebox();
  ### Generate DH key step 2
  ###
  } elsif ($cgiparams{'ACTION'} eq $Lang::tr{'generate dh key'} && $cgiparams{'AREUSURE'} eq 'yes') {
-       # Delete if old key exists
+     # Delete if old key exists
      if (-f "${General::swroot}/ovpn/ca/$cgiparams{'DH_NAME'}") {
          unlink "${General::swroot}/ovpn/ca/$cgiparams{'DH_NAME'}";
        }
        <table width='100%'>
        <tr>
                <td width='15%'> </td> <td width='15%'></td> <td width='65%'></td>
-     </tr>
+       </tr>
        <tr>
                <td class='base'>$Lang::tr{'ovpn dh'}:</td>
                <td align='center'>
        </table>
        <table width='100%'>
        <tr>
-               <b><font color='${Header::colourred}'>$Lang::tr{'capswarning'}:</font></b>
-               $Lang::tr{'dh key warn'}
-               </td>
+               <b><font color='${Header::colourred}'>$Lang::tr{'capswarning'}: </font></b>$Lang::tr{'dh key warn'}
        </tr>
+       <tr>
+               <td class='base'>$Lang::tr{'dh key warn1'}</td>
+       </tr>
+       <tr><td colspan='2'><br></td></tr>
        <tr>
                <td align='center'><input type='submit' name='ACTION' value='$Lang::tr{'generate dh key'}' /></td>
                </form>
  ### Upload DH key
  ###
  } elsif ($cgiparams{'ACTION'} eq $Lang::tr{'upload dh key'}) {
-     if ($cgiparams{'DH_NAME'} !~ /dh1024.pem/) {
-         $errormessage = $Lang::tr{'dh name is invalid'};
-         goto UPLOADCA_ERROR;
-       }
      if (ref ($cgiparams{'FH'}) ne 'Fh') {
           $errormessage = $Lang::tr{'there was no file upload'};
           goto UPLOADCA_ERROR;
      }
-       # Move uploaded dh key to a temporary file
+     # Move uploaded dh key to a temporary file
      (my $fh, my $filename) = tempfile( );
      if (copy ($cgiparams{'FH'}, $fh) != 1) {
          $errormessage = $!;
-           goto UPLOADCA_ERROR;
+       goto UPLOADCA_ERROR;
      }
-       my $temp = `/usr/bin/openssl dhparam -text -in $filename`;
+     my $temp = `/usr/bin/openssl dhparam -text -in $filename`;
      if ($temp !~ /DH Parameters: \((1024|2048|3072|4096) bit\)/) {
          $errormessage = $Lang::tr{'not a valid dh key'};
          unlink ($filename);
          unlink "${General::swroot}/ovpn/ca/$cgiparams{'DH_NAME'}";
        }
      move($filename, "${General::swroot}/ovpn/ca/$cgiparams{'DH_NAME'}");
-               if ($? ne 0) {
-                       $errormessage = "$Lang::tr{'certificate file move failed'}: $!";
-                       unlink ($filename);
-                       goto UPLOADCA_ERROR;
-               }
+       if ($? ne 0) {
+               $errormessage = "$Lang::tr{'dh key move failed'}: $!";
+               unlink ($filename);
+               goto UPLOADCA_ERROR;
+       }
      }
  
  ###
  ### Upload CA Certificate
  ###
  
      if ($cgiparams{'CA_NAME'} eq 'ca') {
        $errormessage = $Lang::tr{'name is invalid'};
 -      goto UPLOAD_CA_ERROR;
 +      goto UPLOADCA_ERROR;
      }
  
      # Check if there is no other entry with this name
@@@ -1825,7 -1823,7 +1868,7 @@@ EN
            }
        } else {        # child
            unless (exec ('/usr/bin/openssl', 'req', '-x509', '-nodes', '-rand', '/proc/interrupts:/proc/net/rt_cache',
-                       '-days', '999999', '-newkey', 'rsa:4096',
+                       '-days', '999999', '-newkey', 'rsa:4096', '-sha512',
                        '-keyout', "${General::swroot}/ovpn/ca/cakey.pem",
                        '-out', "${General::swroot}/ovpn/ca/cacert.pem",
                        '-config',"${General::swroot}/ovpn/openssl/ovpn.cnf")) {
            &Header::closebox();
        }
        &Header::openbox('100%', 'LEFT', "$Lang::tr{'generate root/host certificates'}:");
-     print <<END;
+       print <<END;
        <form method='post' enctype='multipart/form-data'>
        <table width='100%' border='0' cellspacing='1' cellpadding='0'>
        <tr><td width='30%' class='base'>$Lang::tr{'organization name'}:</td>
@@@ -1968,8 -1966,8 +2011,8 @@@ EN
            }
            print ">$country</option>";
        }
-     print <<END;
-       </select></td>
+       print <<END;
+           </select></td>
        <tr><td class='base'>$Lang::tr{'ovpn dh'}:</td>
                <td class='base'><select name='DHLENGHT'>
                                <option value='1024' $selected{'DHLENGHT'}{'1024'}>1024 $Lang::tr{'bit'}</option>
            <td>&nbsp;</td><td>&nbsp;</td></tr> 
        <tr><td class='base' colspan='4' align='left'>
            <img src='/blob.gif' valign='top' alt='*' />&nbsp;$Lang::tr{'this field may be blank'}</td></tr>
-       <tr><td colspan='4'><br><br></td></tr>
-       <tr><td class='base' colspan='4' align='center'>
-           <b><font color='${Header::colourred}'>$Lang::tr{'capswarning'}:</font></b>
-               $Lang::tr{'ovpn generating the root and host certificates'}
-               </td>
+       <tr><td colspan='2'><br></td></tr>
+       <table width='100%'>
+       <tr>
+               <b><font color='${Header::colourred}'>$Lang::tr{'capswarning'}: </font></b>$Lang::tr{'ovpn generating the root and host certificates'}
+               <td class='base'>$Lang::tr{'dh key warn'}</td>
        </tr>
-       <tr><td class='base' colspan='4' align='center'>
-               $Lang::tr{'dh key warn'}
-               </td>
+       <tr>
+               <td class='base'>$Lang::tr{'dh key warn1'}</td>
        </tr>
+       <tr><td colspan='2'><br></td></tr>
+       <tr>
+       </table>
  
+       <table width='100%'>
        <tr><td colspan='4'><hr></td></tr>
        <tr><td class='base' nowrap='nowrap'>$Lang::tr{'upload p12 file'}:</td>
            <td nowrap='nowrap'><input type='file' name='FH' size='32'></td>
            <td><input type='submit' name='ACTION' value='$Lang::tr{'upload p12 file'}' /></td>
              <td colspan='2'>&nbsp;</td></tr>
        <tr><td class='base' colspan='4' align='left'>
 -          <img src='/blob.gif' valign='top' al='*' >&nbsp;$Lang::tr{'this field may be blank'}</td></tr>
 +          <img src='/blob.gif' valign='top' al='*' >&nbsp;$Lang::tr{'this field may be blank'}</td>
 +      </tr>
        </form></table>
  END
        ;
@@@ -2145,14 -2145,19 +2191,19 @@@ if ($confighash{$cgiparams{'KEY'}}[3] e
     print CLIENTCONF "ns-cert-type server\n";   
     print CLIENTCONF "# Auth. Client\n"; 
     print CLIENTCONF "tls-client\n"; 
-    print CLIENTCONF "# Cipher\n"; 
+    print CLIENTCONF "# Cipher\n";
     print CLIENTCONF "cipher $confighash{$cgiparams{'KEY'}}[40]\n";
-    print CLIENTCONF "# HMAC algorithm\n";
-    print CLIENTCONF "auth $confighash{$cgiparams{'KEY'}}[39]\n";
      if ($confighash{$cgiparams{'KEY'}}[4] eq 'cert' && -f "${General::swroot}/ovpn/certs/$confighash{$cgiparams{'KEY'}}[1].p12") { 
         print CLIENTCONF "pkcs12 ${General::swroot}/ovpn/certs/$confighash{$cgiparams{'KEY'}}[1].p12\r\n";
       $zip->addFile( "${General::swroot}/ovpn/certs/$confighash{$cgiparams{'KEY'}}[1].p12", "$confighash{$cgiparams{'KEY'}}[1].p12") or die "Can't add file $confighash{$cgiparams{'KEY'}}[1].p12\n";
-    } 
+    }
+    if ($confighash{$cgiparams{'KEY'}}[39] eq '') {
+       print CLIENTCONF "# HMAC algorithm\n";
+       print CLIENTCONF "auth SHA1\n";
+    } else {
+    print CLIENTCONF "# HMAC algorithm\n";
+    print CLIENTCONF "auth $confighash{$cgiparams{'KEY'}}[39]\n";
+    }
     if ($confighash{$cgiparams{'KEY'}}[30] eq 'on') {
     print CLIENTCONF "# Enable Compression\n";
     print CLIENTCONF "comp-lzo\r\n";
        $zip->addFile( "${General::swroot}/ovpn/certs/$confighash{$cgiparams{'KEY'}}[1]cert.pem", "$confighash{$cgiparams{'KEY'}}[1]cert.pem") or die "Can't add file $confighash{$cgiparams{'KEY'}}[1]cert.pem\n";    
      }
      print CLIENTCONF "cipher $vpnsettings{DCIPHER}\r\n";
-       print CLIENTCONF "auth $vpnsettings{DAUTH}\r\n";
+     if ($vpnsettings{'DAUTH'} eq '') {
+         print CLIENTCONF "";
+     } else {
+       print CLIENTCONF "auth $vpnsettings{'DAUTH'}\r\n";
+     }
+     if ($vpnsettings{'TLSAUTH'} eq 'on') {
+       print CLIENTCONF "tls-auth ta.key 1\r\n";
+       $zip->addFile( "${General::swroot}/ovpn/ca/ta.key", "ta.key")  or die "Can't add file ta.key\n";
+     }
      if ($vpnsettings{DCOMPLZO} eq 'on') {
          print CLIENTCONF "comp-lzo\r\n";
      }
@@@ -2397,7 -2410,7 +2456,7 @@@ if ($confighash{$cgiparams{'KEY'}}[3] e
  } elsif ($cgiparams{'ACTION'} eq $Lang::tr{'show dh'}) {
  
      if (! -e "${General::swroot}/ovpn/ca/dh1024.pem") {
-               $errormessage = $Lang::tr{'not present'};
+       $errormessage = $Lang::tr{'not present'};
        } else {
                &Header::showhttpheaders();
                &Header::openpage($Lang::tr{'ovpn'}, 1, '');
  } elsif ($cgiparams{'ACTION'} eq $Lang::tr{'show crl'}) {
  #    &General::readhasharray("${General::swroot}/ovpn/ovpnconfig", \%confighash);
  
-     if ( -f "${General::swroot}/ovpn/crls/cacrl.pem") {
+     if (! -e "${General::swroot}/ovpn/crls/cacrl.pem") {
+       $errormessage = $Lang::tr{'not present'};
+       } else {
        &Header::showhttpheaders();
        &Header::openpage($Lang::tr{'ovpn'}, 1, '');
        &Header::openbigbox('100%', 'LEFT', '', '');
  #    }
  ADV_ERROR:
      if ($cgiparams{'MAX_CLIENTS'} eq '') {
 -      $cgiparams{'MAX_CLIENTS'} =  '100';     
 +              $cgiparams{'MAX_CLIENTS'} =  '100';
      }
      if ($cgiparams{'KEEPALIVE_1'} eq '') {
 -      $cgiparams{'KEEPALIVE_1'} =  '10';     
 +              $cgiparams{'KEEPALIVE_1'} =  '10';
      }
      if ($cgiparams{'KEEPALIVE_2'} eq '') {
 -      $cgiparams{'KEEPALIVE_2'} =  '60';     
 +              $cgiparams{'KEEPALIVE_2'} =  '60';
      }
      if ($cgiparams{'LOG_VERB'} eq '') {
 -      $cgiparams{'LOG_VERB'} =  '3';
 +              $cgiparams{'LOG_VERB'} =  '3';
      }
      if ($cgiparams{'PMTU_DISCOVERY'} eq '') {
 -      $cgiparams{'PMTU_DISCOVERY'} = 'off';
 +              $cgiparams{'PMTU_DISCOVERY'} = 'off';
 +    }
 +    if ($cgiparams{'DAUTH'} eq '') {
 +              $cgiparams{'DAUTH'} = 'SHA1';
      }
+     if ($cgiparams{'DAUTH'} eq '') {
+       $cgiparams{'DAUTH'} = 'SHA1';
+     }
+     if ($cgiparams{'ENGINES'} eq '') {
+       $cgiparams{'ENGINES'} = 'disabled';
+     }
+     if ($cgiparams{'TLSAUTH'} eq '') {
+       $cgiparams{'TLSAUTH'} = 'off';
+     }
      $checked{'CLIENT2CLIENT'}{'off'} = '';
      $checked{'CLIENT2CLIENT'}{'on'} = '';
      $checked{'CLIENT2CLIENT'}{$cgiparams{'CLIENT2CLIENT'}} = 'CHECKED';
      $checked{'MSSFIX'}{'on'} = '';
      $checked{'MSSFIX'}{$cgiparams{'MSSFIX'}} = 'CHECKED';
      $checked{'PMTU_DISCOVERY'}{$cgiparams{'PMTU_DISCOVERY'}} = 'checked=\'checked\'';
+     $selected{'LOG_VERB'}{'0'} = '';
      $selected{'LOG_VERB'}{'1'} = '';
      $selected{'LOG_VERB'}{'2'} = '';
      $selected{'LOG_VERB'}{'3'} = '';
      $selected{'LOG_VERB'}{'9'} = '';
      $selected{'LOG_VERB'}{'10'} = '';
      $selected{'LOG_VERB'}{'11'} = '';
-     $selected{'LOG_VERB'}{'0'} = '';
      $selected{'LOG_VERB'}{$cgiparams{'LOG_VERB'}} = 'SELECTED';
      $selected{'DAUTH'}{'whirlpool'} = '';
      $selected{'DAUTH'}{'SHA512'} = '';
      $selected{'DAUTH'}{'SHA384'} = '';
      $selected{'DAUTH'}{'SHA256'} = '';
-     $selected{'DAUTH'}{'ecdsa-with-SHA1'} = '';
      $selected{'DAUTH'}{'SHA1'} = '';
      $selected{'DAUTH'}{$cgiparams{'DAUTH'}} = 'SELECTED';
 -   
+     $checked{'TLSAUTH'}{'off'} = '';
+     $checked{'TLSAUTH'}{'on'} = '';
+     $checked{'TLSAUTH'}{$cgiparams{'TLSAUTH'}} = 'CHECKED';
+     $selected{'ENGINES'}{'cryptodev'} = '';
+     $selected{'ENGINES'}{'dynamic'} = '';
+     $selected{'ENGINES'}{'aesni'} = '';
+     $selected{'ENGINES'}{'padlock'} = '';
+     $selected{'ENGINES'}{'disabled'} = '';
+     $selected{'ENGINES'}{$cgiparams{'ENGINES'}} = 'SELECTED';
 +
      &Header::showhttpheaders();
      &Header::openpage($Lang::tr{'status ovpn'}, 1, '');
      &Header::openbigbox('100%', 'LEFT', '', $errormessage);    
      &Header::openbox('100%', 'LEFT', $Lang::tr{'advanced server'});
      print <<END;
      <form method='post' enctype='multipart/form-data'>
 -    <table width='100%' border='0'>
 -    <tr>
 -      <td colspan='4'><b>$Lang::tr{'dhcp-options'}</b></td>
 +<table width='100%' border=0>
 +      <tr>
 +              <td colspan='4'><b>$Lang::tr{'dhcp-options'}</b></td>
      </tr>
      <tr>
 -      <td width='25%'></td> <td width='20%'> </td><td width='25%'> </td><td width='30%'></td>
 +              <td width='25%'></td> <td width='20%'> </td><td width='25%'> </td><td width='30%'></td>
      </tr>     
      <tr>              
 -      <td class='base'>Domain</td>
 +              <td class='base'>Domain</td>
          <td><input type='TEXT' name='DHCP_DOMAIN' value='$cgiparams{'DHCP_DOMAIN'}' size='30'  /></td>
      </tr>
      <tr>      
 -      <td class='base'>DNS</td>
 -      <td><input type='TEXT' name='DHCP_DNS' value='$cgiparams{'DHCP_DNS'}' size='30' /></td>
 +              <td class='base'>DNS</td>
 +              <td><input type='TEXT' name='DHCP_DNS' value='$cgiparams{'DHCP_DNS'}' size='30' /></td>
      </tr>     
      <tr>      
 -      <td class='base'>WINS</td>
 -      <td><input type='TEXT' name='DHCP_WINS' value='$cgiparams{'DHCP_WINS'}' size='30' /></td>
 -       </tr>
 +              <td class='base'>WINS</td>
 +              <td><input type='TEXT' name='DHCP_WINS' value='$cgiparams{'DHCP_WINS'}' size='30' /></td>
 +      </tr>
      <tr>
 -      <td colspan='4'><b>$Lang::tr{'ovpn routes push options'}</b></td>
 +              <td colspan='4'><b>$Lang::tr{'ovpn routes push options'}</b></td>
      </tr>
      <tr>      
 -      <td class='base'>$Lang::tr{'ovpn routes push'}</td>
 -  <td colspan='2'>
 -       <textarea name='ROUTES_PUSH' cols='26' rows='6' wrap='off'>
 +              <td class='base'>$Lang::tr{'ovpn routes push'}</td>
 +              <td colspan='2'>
 +              <textarea name='ROUTES_PUSH' cols='26' rows='6' wrap='off'>
  END
  ;
  
@@@ -2552,39 -2581,41 +2630,41 @@@ print <<END
      </tr>
  </table>
  <hr size='1'>
 -    <table width='100%'>
 +<table width='100%'>
      <tr>
 -      <td class'base'><b>$Lang::tr{'misc-options'}</b></td>
 +              <td class'base'><b>$Lang::tr{'misc-options'}</b></td>
      </tr>
      <tr>
 -      <td width='20%'></td> <td width='15%'> </td><td width='15%'> </td><td width='15%'></td><td width='35%'></td>
 +              <td width='20%'></td> <td width='15%'> </td><td width='15%'> </td><td width='15%'></td><td width='35%'></td>
      </tr>
      <tr>
 -      <td class='base'>Client-To-Client</td>
 -      <td><input type='checkbox' name='CLIENT2CLIENT' $checked{'CLIENT2CLIENT'}{'on'} /></td>
 +              <td class='base'>Client-To-Client</td>
 +              <td><input type='checkbox' name='CLIENT2CLIENT' $checked{'CLIENT2CLIENT'}{'on'} /></td>
      </tr>
      <tr>      
 -      <td class='base'>Redirect-Gateway def1</td>
 -      <td><input type='checkbox' name='REDIRECT_GW_DEF1' $checked{'REDIRECT_GW_DEF1'}{'on'} /></td>
 +              <td class='base'>Redirect-Gateway def1</td>
 +              <td><input type='checkbox' name='REDIRECT_GW_DEF1' $checked{'REDIRECT_GW_DEF1'}{'on'} /></td>
      </tr>
      <tr>      
          <td class='base'>Max-Clients</td>
          <td><input type='text' name='MAX_CLIENTS' value='$cgiparams{'MAX_CLIENTS'}' size='10' /></td>
      </tr>     
 -      <tr>
 +      <tr>
          <td class='base'>Keepalive <br />
            (ping/ping-restart)</td>
          <td><input type='TEXT' name='KEEPALIVE_1' value='$cgiparams{'KEEPALIVE_1'}' size='10' /></td>
          <td><input type='TEXT' name='KEEPALIVE_2' value='$cgiparams{'KEEPALIVE_2'}' size='10' /></td>
      </tr>
 -      <tr>
 +      <tr>
          <td class='base'>fragment <br></td>
          <td><input type='TEXT' name='FRAGMENT' value='$cgiparams{'FRAGMENT'}' size='10' /></td>
-       </tr>
-       <tr>
+       </tr>
+       <tr>
          <td class='base'>mssfix</td>
          <td><input type='checkbox' name='MSSFIX' $checked{'MSSFIX'}{'on'} /></td>
-       </tr>
+         <td>$Lang::tr{'openvpn default'}: off</td>
+         </tr>
        <tr>
                <td class='base'>$Lang::tr{'ovpn mtu-disc'}</td>
                <td><input type='radio' name='PMTU_DISCOVERY' value='yes' $checked{'PMTU_DISCOVERY'}{'yes'} /> $Lang::tr{'ovpn mtu-disc yes'}</td>
  </table>
  
  <hr size='1'>
 -    <table width='100%'>
 +<table width='100%'>
      <tr>
-               <td class'base'><b>$Lang::tr{'log-options'}</b></td>
+       <td class'base'><b>$Lang::tr{'log-options'}</b></td>
      </tr>
      <tr>
-               <td width='20%'></td> <td width='30%'> </td><td width='25%'> </td><td width='25%'></td>
+       <td width='20%'></td> <td width='30%'> </td><td width='25%'> </td><td width='25%'></td>
      </tr>
  
      <tr><td class='base'>VERB</td>
          <td><select name='LOG_VERB'>
-                               <option value='0'  $selected{'LOG_VERB'}{'0'}>0</option>
-                               <option value='1'  $selected{'LOG_VERB'}{'1'}>1</option>
-                               <option value='2'  $selected{'LOG_VERB'}{'2'}>2</option>
-                               <option value='3'  $selected{'LOG_VERB'}{'3'}>3</option>
-                               <option value='4'  $selected{'LOG_VERB'}{'4'}>4</option>
-                               <option value='5'  $selected{'LOG_VERB'}{'5'}>5</option>
-                               <option value='6'  $selected{'LOG_VERB'}{'6'}>6</option>
-                               <option value='7'  $selected{'LOG_VERB'}{'7'}>7</option>
-                               <option value='8'  $selected{'LOG_VERB'}{'8'}>8</option>
-                               <option value='9'  $selected{'LOG_VERB'}{'9'}>9</option>
-                               <option value='10' $selected{'LOG_VERB'}{'10'}>10</option>
-                               <option value='11' $selected{'LOG_VERB'}{'11'}>11</option>
-                       </select>
-               </td>
-       </tr>
- </table>
+                       <option value='0'  $selected{'LOG_VERB'}{'0'}>0</option>
+                       <option value='1'  $selected{'LOG_VERB'}{'1'}>1</option>
+                       <option value='2'  $selected{'LOG_VERB'}{'2'}>2</option>
+                       <option value='3'  $selected{'LOG_VERB'}{'3'}>3</option>
+                       <option value='4'  $selected{'LOG_VERB'}{'4'}>4</option>
+                       <option value='5'  $selected{'LOG_VERB'}{'5'}>5</option>
+                       <option value='6'  $selected{'LOG_VERB'}{'6'}>6</option>
+                       <option value='7'  $selected{'LOG_VERB'}{'7'}>7</option>
+                       <option value='8'  $selected{'LOG_VERB'}{'8'}>8</option>
+                       <option value='9'  $selected{'LOG_VERB'}{'9'}>9</option>
+                       <option value='10' $selected{'LOG_VERB'}{'10'}>10</option>
+                       <option value='11' $selected{'LOG_VERB'}{'11'}>11</option>
+       </td></select>
+     </table>
  
  <hr size='1'>
  <table width='100%'>
                                <option value='SHA512'                  $selected{'DAUTH'}{'SHA512'}>SHA2 (512 $Lang::tr{'bit'})</option>
                                <option value='SHA384'                  $selected{'DAUTH'}{'SHA384'}>SHA2 (384 $Lang::tr{'bit'})</option>
                                <option value='SHA256'                  $selected{'DAUTH'}{'SHA256'}>SHA2 (256 $Lang::tr{'bit'})</option>
-                               <option value='ecdsa-with-SHA1'         $selected{'DAUTH'}{'ecdsa-with-SHA1'}>ECDSA-SHA1 (160 $Lang::tr{'bit'})</option>
                                <option value='SHA1'                    $selected{'DAUTH'}{'SHA1'}>SHA1 (160 $Lang::tr{'bit'})</option>
                        </select>
                </td>
                <td>Default: <span class="base">SHA1 (160 $Lang::tr{'bit'})</span></td>
- </table><hr>
+     </tr>
+     <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'ovpn engines'}</td>
+               <td><select name='ENGINES'>
+                               <option value='cryptodev'               $selected{'ENGINES'}{'cryptodev'}>Cryptodev</option>
+                               <option value='dynamic'                 $selected{'ENGINES'}{'dynamic'}>Dynamic</option>
+                               <option value='aesni'                   $selected{'ENGINES'}{'aesni'}>AES-NI</option>
+                               <option value='padlock'                 $selected{'ENGINES'}{'padlock'}>Padlock</option>
+                               <option value='disabled'                $selected{'ENGINES'}{'disabled'}>$Lang::tr{'disabled'}</option>
+                       </select>
+               </td>
+               <td>Default: <span class="base">$Lang::tr{'disabled'}</span></td>
+       </tr>
+ </table>
+ <table width='100%'>
+     <tr>
+       <td width='20%'></td> <td width='15%'> </td><td width='15%'> </td><td width='15%'></td><td width='35%'></td>
+     </tr>
  
 -
 -
+     <tr>
+       <td class='base'>HMAC tls-auth</td>
+       <td><input type='checkbox' name='TLSAUTH' $checked{'TLSAUTH'}{'on'} /></td>
+     </tr>
+     </table><hr>
  END
  
  if ( -e "/var/run/openvpn.pid"){
  print"        <br><b><font color='#990000'>$Lang::tr{'attention'}:</b></font><br>
                $Lang::tr{'server restart'}<br><br>
                <hr>";
-               print<<END
+       print<<END;
  <table width='100%'>
  <tr>
      <td>&nbsp;</td>
@@@ -2665,7 -2718,7 +2765,7 @@@ EN
                
  }else{
  
- print<<END
+       print<<END;
  <table width='100%'>
  <tr>
      <td>&nbsp;</td>
@@@ -2720,11 -2773,11 +2820,11 @@@ if ($cgiparams{'ACTION'} eq "edit")
        
        &Header::openbox('100%', 'LEFT', $Lang::tr{'ccd modify'});
  
-     print <<END;
-     <table width='100%' border=0>
+       print <<END;
+     <table width='100%' border='0'>
      <tr><form method='post'>
        <td width='10%' nowrap='nowrap'>$Lang::tr{'ccd name'}:</td><td><input type='TEXT' name='ccdname' value='$cgiparams{'ccdname'}' /></td>
 -      <td width='8%'>$Lang::tr{'ccd subnet'}:</td><td><input type='TEXT' name='ccdsubnet' value='$cgiparams{'ccdsubnet'}' readonly='readonly' /></td></tr>
 +      <td width='8%'>$Lang::tr{'ccd subnet'}:</td><td><input type='TEXT' name='ccdsubnet' value='$cgiparams{'ccdsubnet'}' readonly /></td></tr>
        <tr><td colspan='4' align='right'><hr><input type='submit' value='$Lang::tr{'save'}' /><input type='hidden' name='ACTION' value='editsave'/>
        <input type='hidden' name='ccdname' value='$cgiparams{'ccdname'}'/><input type='submit' value='$Lang::tr{'cancel'}' />
        </td></tr>
@@@ -2734,7 -2787,7 +2834,7 @@@ EN
        &Header::closebox();
  
        &Header::openbox('100%', 'LEFT',$Lang::tr{'ccd net'} );
-     print <<END;
+       print <<END;
      <table width='100%' border='0'  cellpadding='0' cellspacing='1'>
      <tr>
        <td class='boldbase' align='center'><b>$Lang::tr{'ccd name'}</td><td class='boldbase' align='center'><b>$Lang::tr{'network'}</td><td class='boldbase' width='15%' align='center'><b>$Lang::tr{'ccd used'}</td><td width='3%'></td><td width='3%'></td></tr>
@@@ -2744,7 -2797,7 +2844,7 @@@ EN
  else{
        if (! -e "/var/run/openvpn.pid"){
        &Header::openbox('100%', 'LEFT', $Lang::tr{'ccd add'});
-               print <<END;
+       print <<END;
            <table width='100%' border='0'>
            <tr><form method='post'>
                <td colspan='4'>$Lang::tr{'ccd hint'}<br><br></td></tr>
@@@ -2764,7 -2817,7 +2864,7 @@@ EN
                print "$Lang::tr{'ccd noaddnet'}<br><hr>";
        }
        
 -      print <<END
 +    print <<END;
      <table width='100%' cellpadding='0' cellspacing='1'>
      <tr>
        <td class='boldbase' align='center' nowrap='nowrap' width='20%'><b>$Lang::tr{'ccd name'}</td><td class='boldbase' align='center' width='8%'><b>$Lang::tr{'network'}</td><td class='boldbase' width='8%' align='center' nowrap='nowrap'><b>$Lang::tr{'ccd used'}</td><td width='1%' align='center'></td><td width='1%' align='center'></td></tr>
@@@ -2782,9 -2835,9 +2882,9 @@@ EN
                if ($count % 2){ print" <tr bgcolor='$color{'color22'}'>";}
                else{            print" <tr bgcolor='$color{'color20'}'>";}
                print"<td>$ccdconf[0]</td><td align='center'>$ccdconf[1]</td><td align='center'>$ccdhosts/".(&ccdmaxclients($ccdconf[1])+1)."</td><td>";
 -print <<END
 +        print <<END;
                <form method='post' />
 -              <input type='image' src='/images/edit.gif' align='middle' alt='$Lang::tr{'edit'}' title='$Lang::tr{'edit'}' />
 +              <input type='image' src='/images/edit.gif' align='middle' alt=$Lang::tr{'edit'} title=$Lang::tr{'edit'} />
                <input type='hidden' name='ACTION' value='edit'/>
                <input type='hidden' name='ccdname' value='$ccdconf[0]' />
                <input type='hidden' name='ccdsubnet' value='$ccdconf[1]' />
                <td><input type='hidden' name='ACTION' value='kill'/>
                <input type='hidden' name='number' value='$count' />
                <input type='hidden' name='net' value='$ccdconf[0]' />
 -              <input type='image' src='/images/delete.gif' align='middle' alt='$Lang::tr{'remove'}' title='$Lang::tr{'remove'}' /></form></td></tr>
 +              <input type='image' src='/images/delete.gif' align='middle' alt=$Lang::tr{'remove'} title=$Lang::tr{'remove'} /></form></td></tr>
  END
  ;
        }       
@@@ -2897,7 -2950,7 +2997,7 @@@ EN
        }
        
        print "</table>";
-     print <<END;
+       print <<END;
        <table width='100%' border='0' cellpadding='2' cellspacing='0'>
        <tr><td></td></tr>
        <tr><td></td></tr>
@@@ -3012,7 -3065,7 +3112,7 @@@ EN
  
  if ( -s "${General::swroot}/ovpn/settings") {
  
-     print <<END;
+       print <<END;
            <b>$Lang::tr{'connection type'}:</b><br />
            <table border='0' width='100%'><form method='post' ENCTYPE="multipart/form-data">
            <tr><td><input type='radio' name='TYPE' value='host' checked /></td>
                <td class='base'>$Lang::tr{'net to net vpn'} (Upload Client Package)</td></tr>
          <tr><td>&nbsp;</td><td class='base'><input type='file' name='FH' size='30'></td></tr>
          <tr><td>&nbsp;</td><td>Import Connection Name <img src='/blob.gif' /></td></tr>
 -    <tr><td>&nbsp;</td><td class='base'><input type='text' name='n2nname' size='30'>$Lang::tr{'openvpn default'}: Client Packagename</td></tr>
 +    <tr><td>&nbsp;</td><td class='base'><input type='text' name='n2nname' size='30'>Default : Client Packagename</td></tr>
          <tr><td colspan='3'><hr /></td></tr>
      <tr><td align='right' colspan='3'><input type='submit' name='ACTION' value='$Lang::tr{'add'}' /></td></tr>
          <tr><td class='base' colspan='3' align='left'><img src='/blob.gif' alt='*' />&nbsp;$Lang::tr{'this field may be blank'}</td></tr>
@@@ -3033,7 -3086,7 +3133,7 @@@ EN
        
  
  } else {
-     print <<END;
+       print <<END;
                    <b>$Lang::tr{'connection type'}:</b><br />
            <table border='0' width='100%'><form method='post' ENCTYPE="multipart/form-data">
            <tr><td><input type='radio' name='TYPE' value='host' checked /></td> <td class='base'>$Lang::tr{'host to net vpn'}</td></tr>
@@@ -3180,8 -3233,8 +3280,9 @@@ EN
        
  my $complzoactive;
  my $mssfixactive;
 +my $authactive;
  my $n2nfragment;
+ my $authactive;
  my @n2nmtudisc = split(/ /, (grep { /^mtu-disc/ } @firen2nconf)[0]);
  my @n2nproto2 = split(/ /, (grep { /^proto/ } @firen2nconf)[0]);
  my @n2nproto = split(/-/, $n2nproto2[1]);
@@@ -3201,7 -3254,7 +3302,7 @@@ my @n2nmgmt =  split(/ /, (grep { /^man
  my @n2nlocalsub  = split(/ /, (grep { /^# remsub/ } @firen2nconf)[0]);
  my @n2ncipher = split(/ /, (grep { /^cipher/ } @firen2nconf)[0]);
  my @n2nauth = split(/ /, (grep { /^auth/ } @firen2nconf)[0]);
+ my @n2nengine = split(/ /, (grep { /^engine/ } @firen2nconf)[0]);;
  
  ###
  # m.a.d delete CR and LF from arrays for this chomp doesnt work
@@@ -3222,6 -3275,7 +3323,7 @@@ $n2nmgmt[2] =~ s/\n|\r//g
  $n2nmtudisc[1] =~ s/\n|\r//g;
  $n2ncipher[1] =~ s/\n|\r//g;
  $n2nauth[1] =~ s/\n|\r//g;
+ $n2nengine[1] =~ s/\n|\r//g;
  chomp ($complzoactive);
  chomp ($mssfixactive);
  
@@@ -3275,7 -3329,7 +3377,7 @@@ foreach my $dkey (keys %confighash) 
        
    $key = &General::findhasharraykey (\%confighash);
  
-       foreach my $i (0 .. 41) { $confighash{$key}[$i] = "";}
+       foreach my $i (0 .. 42) { $confighash{$key}[$i] = "";}
  
        $confighash{$key}[0] = 'off';
        $confighash{$key}[1] = $n2nname[0];
        $confighash{$key}[29] = $n2nport[1];
        $confighash{$key}[30] = $complzoactive;
        $confighash{$key}[31] = $n2ntunmtu[1];
-       $confighash{$key}[38] = $n2nmtudisc[1]; 
+       $confighash{$key}[38] = $n2nmtudisc[1];
        $confighash{$key}[39] = $n2nauth[1];
        $confighash{$key}[40] = $n2ncipher[1];
+       $confighash{$key}[41] = 'disabled';
  
 -
    &General::writehasharray("${General::swroot}/ovpn/ovpnconfig", \%confighash);
   
    N2N_ERROR:
                &Header::openbox('100%', 'LEFT', 'import ipfire net2net config');
        }
        if ($errormessage eq ''){
-         print <<END;
+       print <<END;
                <!-- ipfire net2net config gui -->
                <table width='100%'>
                <tr><td width='25%'>&nbsp;</td><td width='25%'>&nbsp;</td></tr>
                <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'Act as'}</td><td><b>$confighash{$key}[6]</b></td></tr>                                                              
                <tr><td class='boldbase' nowrap='nowrap'>Remote Host </td><td><b>$confighash{$key}[10]</b></td></tr>
                <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'local subnet'}</td><td><b>$confighash{$key}[8]</b></td></tr>
 -              <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'remote subnet'}</td><td><b>$confighash{$key}[11]</b></td></tr>
 +              <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'remote subnet'}:</td><td><b>$confighash{$key}[11]</b></td></tr>
                <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'ovpn subnet'}</td><td><b>$confighash{$key}[27]</b></td></tr>
                <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'protocol'}</td><td><b>$confighash{$key}[28]</b></td></tr>
                <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'destination port'}:</td><td><b>$confighash{$key}[29]</b></td></tr>
                <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'comp-lzo'}</td><td><b>$confighash{$key}[30]</b></td></tr>
 -              <tr><td class='boldbase' nowrap='nowrap'>MSSFIX </td><td><b>$confighash{$key}[23]</b></td></tr>
 -              <tr><td class='boldbase' nowrap='nowrap'>Fragment </td><td><b>$confighash{$key}[24]</b></td></tr>
 +              <tr><td class='boldbase' nowrap='nowrap'>MSSFIX:</td><td><b>$confighash{$key}[23]</b></td></tr>
 +              <tr><td class='boldbase' nowrap='nowrap'>Fragment:</td><td><b>$confighash{$key}[24]</b></td></tr>
                <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'MTU'}</td><td><b>$confighash{$key}[31]</b></td></tr>
-               <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'ovpn mtu-disc'}:</td><td><b>$confighash{$key}[38]</b></td></tr>
-               <tr><td class='boldbase' nowrap='nowrap'>Management Port:</td><td><b>$confighash{$key}[22]</b></td></tr>
+               <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'ovpn mtu-disc'}</td><td><b>$confighash{$key}[38]</b></td></tr>
+               <tr><td class='boldbase' nowrap='nowrap'>Management Port </td><td><b>$confighash{$key}[22]</b></td></tr>
                <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'ovpn hmac'}:</td><td><b>$confighash{$key}[39]</b></td></tr>
                <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'cipher'}</td><td><b>$confighash{$key}[40]</b></td></tr>
                <tr><td>&nbsp;</td><td>&nbsp;</td></tr> 
@@@ -3438,6 -3494,8 +3541,8 @@@ if ($confighash{$cgiparams{'KEY'}}) 
                $cgiparams{'PMTU_DISCOVERY'}    = $confighash{$cgiparams{'KEY'}}[38];
                $cgiparams{'DAUTH'}             = $confighash{$cgiparams{'KEY'}}[39];
                $cgiparams{'DCIPHER'}           = $confighash{$cgiparams{'KEY'}}[40];
+               $cgiparams{'TLSAUTH'}           = $confighash{$cgiparams{'KEY'}}[41];
+               $cgiparams{'ENGINES'}           = $confighash{$cgiparams{'KEY'}}[42];
        } elsif ($cgiparams{'ACTION'} eq $Lang::tr{'save'}) {
        $cgiparams{'REMARK'} = &Header::cleanhtml($cgiparams{'REMARK'});
        
@@@ -3747,7 -3805,7 +3852,7 @@@ if ($cgiparams{'TYPE'} eq 'net') 
                  goto VPNCONF_ERROR;
                }
  
 -      if ($cgiparams{'OVPN_MGMT'} eq  '') {
 +      if ($cgiparams{'OVPN_MGMT'} eq '') {
                $cgiparams{'OVPN_MGMT'} = $cgiparams{'DEST_PORT'};              
                }
        
        
        if (! $key) {
            $key = &General::findhasharraykey (\%confighash);
-           foreach my $i (0 .. 41) { $confighash{$key}[$i] = "";}
+           foreach my $i (0 .. 43) { $confighash{$key}[$i] = "";}
        }
        $confighash{$key}[0]            = $cgiparams{'ENABLED'};
        $confighash{$key}[1]            = $cgiparams{'NAME'};
        $confighash{$key}[38]           = $cgiparams{'PMTU_DISCOVERY'};
        $confighash{$key}[39]           = $cgiparams{'DAUTH'};
        $confighash{$key}[40]           = $cgiparams{'DCIPHER'};
+       $confighash{$key}[42]           = $cgiparams{'ENGINES'};
  
 -
        &General::writehasharray("${General::swroot}/ovpn/ovpnconfig", \%confighash);
        
        if ($cgiparams{'CHECK1'} ){
  ###   
          $cgiparams{'MSSFIX'} = 'on';
          $cgiparams{'FRAGMENT'} = '1300';
-         $cgiparams{'PMTU_DISCOVERY'} = 'off';
-         $cgiparams{'DAUTH'} = 'SHA1';
+       $cgiparams{'PMTU_DISCOVERY'} = 'off';
+       $cgiparams{'DAUTH'} = 'SHA1';
+       $cgiparams{'ENGINES'} = 'disabled';
  ###
  # m.a.d n2n end
  ###   
 -      $cgiparams{'SIDE'} = 'left';
 +        $cgiparams{'SIDE'} = 'left';
        if ( ! -f "${General::swroot}/ovpn/ca/cakey.pem" ) {
            $cgiparams{'AUTH'} = 'psk';
        } elsif ( ! -f "${General::swroot}/ovpn/ca/cacert.pem") {
      }
      $checked{'PMTU_DISCOVERY'}{$cgiparams{'PMTU_DISCOVERY'}} = 'checked=\'checked\'';
  
-     $selected{'DAUTH'}{'whirlpool'} = '';
-     $selected{'DAUTH'}{'SHA512'} = '';
-     $selected{'DAUTH'}{'SHA384'} = '';
-     $selected{'DAUTH'}{'SHA256'} = '';
-     $selected{'DAUTH'}{'ecdsa-with-SHA1'} = '';
-     $selected{'DAUTH'}{'SHA1'} = '';
-     $selected{'DAUTH'}{$cgiparams{'DAUTH'}} = 'SELECTED';
      $selected{'DCIPHER'}{'CAMELLIA-256-CBC'} = '';
      $selected{'DCIPHER'}{'CAMELLIA-192-CBC'} = '';
      $selected{'DCIPHER'}{'CAMELLIA-128-CBC'} = '';
      $selected{'DCIPHER'}{'DES-CBC'} = '';
      $selected{'DCIPHER'}{'RC2-64-CBC'} = '';
      $selected{'DCIPHER'}{'RC2-40-CBC'} = '';
+     # If no cipher has been chossen yet, select
+     # the old default (AES-256-CBC) for compatiblity reasons.
+     if ($cgiparams{'DCIPHER'} eq '') {
+       $cgiparams{'DCIPHER'} = 'AES-256-CBC';
+     }
      $selected{'DCIPHER'}{$cgiparams{'DCIPHER'}} = 'SELECTED';
+     $selected{'DAUTH'}{'whirlpool'} = '';
+     $selected{'DAUTH'}{'SHA512'} = '';
+     $selected{'DAUTH'}{'SHA384'} = '';
+     $selected{'DAUTH'}{'SHA256'} = '';
+     $selected{'DAUTH'}{'SHA1'} = '';
+     # If no hash algorythm has been choosen yet, select
+     # the old default value (SHA1) for compatiblity reasons.
+     if ($cgiparams{'DAUTH'} eq '') {
+       $cgiparams{'DAUTH'} = 'SHA1';
+     }
+     $selected{'DAUTH'}{$cgiparams{'DAUTH'}} = 'SELECTED';
+     $selected{'ENGINES'}{'disabled'} = '';
+     $selected{'ENGINES'}{'cryptodev'} = '';
+     $selected{'ENGINES'}{'dynamic'} = '';
+     $selected{'ENGINES'}{'aesni'} = '';
+     $selected{'ENGINES'}{'padlock'} = '';
+     # If no engine has been choosen yet, select
+     # a default one (disabled).
+     if ($cgiparams{'ENGINES'} eq '') {
+         $cgiparams{'ENGINES'} = 'disabled';
+     }
+     $selected{'ENGINES'}{$cgiparams{'ENGINES'}} = 'SELECTED';
  
      if (1) {
        &Header::showhttpheaders();
  
        &Header::openbox('100%', 'LEFT', "$Lang::tr{'connection'}:");
        print "<table width='100%'  border='0'>\n";
 -      
 -      
 -      
 +
        print "<tr><td width='14%' class='boldbase'>$Lang::tr{'name'}: </td>";
        
        if ($cgiparams{'TYPE'} eq 'host') {
            if ($cgiparams{'KEY'}) {
                print "<td width='35%' class='base'><input type='hidden' name='NAME' value='$cgiparams{'NAME'}' />$cgiparams{'NAME'}</td>";
            } else {
 -                      
                print "<td width='35%'><input type='text' name='NAME' value='$cgiparams{'NAME'}' maxlength='20' size='30' /></td>";
            }
  #         print "<tr><td>$Lang::tr{'interface'}</td>";
  #         print "<td><select name='INTERFACE'>";
  #         print "<option value='RED' $selected{'INTERFACE'}{'RED'}>RED</option>";
 -#         if ($netsettings{'BLUE_DEV'} ne '') {
 -#             print "<option value='BLUE' $selected{'INTERFACE'}{'BLUE'}>BLUE</option>";
 -#         }
 -#         print "<option value='GREEN' $selected{'INTERFACE'}{'GREEN'}>GREEN</option>";
 -#         print "<option value='ORANGE' $selected{'INTERFACE'}{'ORANGE'}>ORANGE</option>";
 -#         print "</select></td></tr>";
 -#         print <<END
 +#             if ($netsettings{'BLUE_DEV'} ne '') {
 +#                     print "<option value='BLUE' $selected{'INTERFACE'}{'BLUE'}>BLUE</option>";
 +#             }
 +#             print "<option value='GREEN' $selected{'INTERFACE'}{'GREEN'}>GREEN</option>";
 +#             print "<option value='ORANGE' $selected{'INTERFACE'}{'ORANGE'}>ORANGE</option>";
 +#             print "</select></td></tr>";
 +#             print <<END;
        } else {
            print "<input type='hidden' name='INTERFACE' value='red' />";
            if ($cgiparams{'KEY'}) {
            } else {
                print "<td width='25%'><input type='text' name='NAME' value='$cgiparams{'NAME'}' maxlength='20' /></td>";
            }
 -          
 -          
 -          
            print <<END;
                    <td width='25%'>&nbsp;</td>
                    <td width='25%'>&nbsp;</td></tr>
 +
                <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'Act as'}</td>
                    <td><select name='SIDE'><option value='server' $selected{'SIDE'}{'server'}>$Lang::tr{'openvpn server'}</option>
                                            <option value='client' $selected{'SIDE'}{'client'}>$Lang::tr{'openvpn client'}</option></select></td>
                    <td><input type='text' name='REMOTE_SUBNET' value='$cgiparams{'REMOTE_SUBNET'}' /></td></tr>
  
                <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'ovpn subnet'}</td>
-                   <td><input type='TEXT' name='OVPN_SUBNET' value='$cgiparams{'OVPN_SUBNET'}' /></td>
-                       <td class='boldbase'>$Lang::tr{'destination port'}:</td>
-                       <td><input type='TEXT' name='DEST_PORT' value='$cgiparams{'DEST_PORT'}' size='5' /></td>
+                   <td><input type='TEXT' name='OVPN_SUBNET' value='$cgiparams{'OVPN_SUBNET'}' /></td></tr>
  
+                   
                <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'protocol'}</td>
                        <td><select name='PROTOCOL'><option value='udp' $selected{'PROTOCOL'}{'udp'}>UDP</option>
-                                               <option value='tcp' $selected{'PROTOCOL'}{'tcp'}>TCP</option></select></td>
+                                       <option value='tcp' $selected{'PROTOCOL'}{'tcp'}>TCP</option></select></td>
  
-               <td class='boldbase' nowrap='nowrap'>Management Port ($Lang::tr{'openvpn default'}: <span class="base">$Lang::tr{'destination port'}): &nbsp;<img src='/blob.gif' /></td>
-                       <td> <input type='TEXT' name='OVPN_MGMT' VALUE='$cgiparams{'OVPN_MGMT'}'size='5' /></td>
+                       <td class='boldbase'>$Lang::tr{'destination port'}:</td>
+                       <td><input type='TEXT' name='DEST_PORT' value='$cgiparams{'DEST_PORT'}' size='5' /></td>
                </tr>
  
                <tr><td class='boldbase'>$Lang::tr{'cipher'}</td>
                        <td><select name='DCIPHER'>
-                                       <option value='CAMELLIA-256-CBC' $selected{'DCIPHER'}{'CAMELLIA-256-CBC'}>CAMELLIA-CBC (256 $Lang::tr{'bit'})</option>
-                                       <option value='CAMELLIA-192-CBC' $selected{'DCIPHER'}{'CAMELLIA-192-CBC'}>CAMELLIA-CBC (196 $Lang::tr{'bit'})</option>
-                                       <option value='CAMELLIA-128-CBC' $selected{'DCIPHER'}{'CAMELLIA-128-CBC'}>CAMELLIA-CBC (128 $Lang::tr{'bit'})</option>
-                                       <option value='AES-256-CBC'     $selected{'DCIPHER'}{'AES-256-CBC'}>AES-CBC (256 $Lang::tr{'bit'})</option>
-                                       <option value='AES-192-CBC'     $selected{'DCIPHER'}{'AES-192-CBC'}>AES-CBC (192 $Lang::tr{'bit'})</option>
-                                       <option value='AES-128-CBC'     $selected{'DCIPHER'}{'AES-128-CBC'}>AES-CBC (128 $Lang::tr{'bit'})</option>
-                                       <option value='DES-EDE3-CBC'    $selected{'DCIPHER'}{'DES-EDE3-CBC'}>DES-EDE3-CBC (192 $Lang::tr{'bit'})</option>
-                                       <option value='DESX-CBC'        $selected{'DCIPHER'}{'DESX-CBC'}>DESX-CBC (192 $Lang::tr{'bit'})</option>
-                                       <option value='SEED-CBC'        $selected{'DCIPHER'}{'SEED-CBC'}>SEED-CBC (128 $Lang::tr{'bit'})</option>
-                                       <option value='DES-EDE-CBC'     $selected{'DCIPHER'}{'DES-EDE-CBC'}>DES-EDE-CBC (128 $Lang::tr{'bit'})</option>
-                                       <option value='BF-CBC'          $selected{'DCIPHER'}{'BF-CBC'}>BF-CBC (128 $Lang::tr{'bit'})</option>
-                                       <option value='CAST5-CBC'       $selected{'DCIPHER'}{'CAST5-CBC'}>CAST5-CBC (128 $Lang::tr{'bit'})</option>
-                                       <option value='RC2-CBC'         $selected{'DCIPHER'}{'RC2-CBC'}>RC2-CBC (128 $Lang::tr{'bit'})</option>
-                                       <option value='DES-CBC'         $selected{'DCIPHER'}{'DES-CBC'}>DES-CBC (64 $Lang::tr{'bit'} not recommended)</option>
-                                       <option value='RC2-64-CBC'      $selected{'DCIPHER'}{'RC2-64-CBC'}>RC2-CBC (64 $Lang::tr{'bit'} not recommended)</option>
-                                       <option value='RC2-40-CBC'      $selected{'DCIPHER'}{'RC2-40-CBC'}>RC2-CBC (40 $Lang::tr{'bit'} not recommended)</option>
+                                       <option value='CAMELLIA-256-CBC'        $selected{'DCIPHER'}{'CAMELLIA-256-CBC'}>CAMELLIA-CBC (256 $Lang::tr{'bit'})</option>
+                                       <option value='CAMELLIA-192-CBC'        $selected{'DCIPHER'}{'CAMELLIA-192-CBC'}>CAMELLIA-CBC (196 $Lang::tr{'bit'})</option>
+                                       <option value='CAMELLIA-128-CBC'        $selected{'DCIPHER'}{'CAMELLIA-128-CBC'}>CAMELLIA-CBC (128 $Lang::tr{'bit'})</option>
+                                       <option value='AES-256-CBC'             $selected{'DCIPHER'}{'AES-256-CBC'}>AES-CBC (256 $Lang::tr{'bit'})</option>
+                                       <option value='AES-192-CBC'             $selected{'DCIPHER'}{'AES-192-CBC'}>AES-CBC (192 $Lang::tr{'bit'})</option>
+                                       <option value='AES-128-CBC'             $selected{'DCIPHER'}{'AES-128-CBC'}>AES-CBC (128 $Lang::tr{'bit'})</option>
+                                       <option value='DES-EDE3-CBC'            $selected{'DCIPHER'}{'DES-EDE3-CBC'}>DES-EDE3-CBC (192 $Lang::tr{'bit'})</option>
+                                       <option value='DESX-CBC'                $selected{'DCIPHER'}{'DESX-CBC'}>DESX-CBC (192 $Lang::tr{'bit'})</option>
+                                       <option value='SEED-CBC'                $selected{'DCIPHER'}{'SEED-CBC'}>SEED-CBC (128 $Lang::tr{'bit'})</option>
+                                       <option value='DES-EDE-CBC'             $selected{'DCIPHER'}{'DES-EDE-CBC'}>DES-EDE-CBC (128 $Lang::tr{'bit'})</option>
+                                       <option value='BF-CBC'                  $selected{'DCIPHER'}{'BF-CBC'}>BF-CBC (128 $Lang::tr{'bit'})</option>
+                                       <option value='CAST5-CBC'               $selected{'DCIPHER'}{'CAST5-CBC'}>CAST5-CBC (128 $Lang::tr{'bit'})</option>
+                                       <option value='RC2-CBC'                 $selected{'DCIPHER'}{'RC2-CBC'}>RC2-CBC (128 $Lang::tr{'bit'})</option>
+                                       <option value='DES-CBC'                 $selected{'DCIPHER'}{'DES-CBC'}>DES-CBC (64 $Lang::tr{'bit'} not recommended)</option>
+                                       <option value='RC2-64-CBC'              $selected{'DCIPHER'}{'RC2-64-CBC'}>RC2-CBC (64 $Lang::tr{'bit'} not recommended)</option>
+                                       <option value='RC2-40-CBC'              $selected{'DCIPHER'}{'RC2-40-CBC'}>RC2-CBC (40 $Lang::tr{'bit'} not recommended)</option>
                                </select>
                        </td>
  
                        <td class='boldbase'>$Lang::tr{'ovpn ha'}:</td>
                        <td><select name='DAUTH'>
-                                       <option value='whirlpool'       $selected{'DAUTH'}{'whirlpool'}>Whirlpool (512 $Lang::tr{'bit'})</option>
-                                       <option value='SHA512'          $selected{'DAUTH'}{'SHA512'}>SHA2 (512 $Lang::tr{'bit'})</option>
-                                       <option value='SHA384'          $selected{'DAUTH'}{'SHA384'}>SHA2 (384 $Lang::tr{'bit'})</option>
-                                       <option value='SHA256'          $selected{'DAUTH'}{'SHA256'}>SHA2 (256 $Lang::tr{'bit'})</option>
-                                       <option value='ecdsa-with-SHA1' $selected{'DAUTH'}{'ecdsa-with-SHA1'}>ECDSA-SHA1 (160 $Lang::tr{'bit'})</option>
-                                       <option value='SHA1'            $selected{'DAUTH'}{'SHA1'}>SHA1 (160 $Lang::tr{'bit'} Default)</option>
+                                       <option value='whirlpool'               $selected{'DAUTH'}{'whirlpool'}>Whirlpool (512 $Lang::tr{'bit'})</option>
+                                       <option value='SHA512'                  $selected{'DAUTH'}{'SHA512'}>SHA2 (512 $Lang::tr{'bit'})</option>
+                                       <option value='SHA384'                  $selected{'DAUTH'}{'SHA384'}>SHA2 (384 $Lang::tr{'bit'})</option>
+                                       <option value='SHA256'                  $selected{'DAUTH'}{'SHA256'}>SHA2 (256 $Lang::tr{'bit'})</option>
+                                       <option value='SHA1'                    $selected{'DAUTH'}{'SHA1'}>SHA1 (160 $Lang::tr{'bit'} Default)</option>
+                               </select>
+                       </td>
+               </tr>
+               <tr>    <td class='boldbase' nowrap='nowrap'>$Lang::tr{'ovpn engines'} &nbsp;<img src='/blob.gif'</td>
+                       <td><select name='ENGINES'>
+                                       <option value='cryptodev'               $selected{'ENGINES'}{'cryptodev'}>Cryptodev</option>
+                                       <option value='dynamic'                 $selected{'ENGINES'}{'dynamic'}>Dynamic</option>
+                                       <option value='aesni'                   $selected{'ENGINES'}{'aesni'}>AES-NI</option>
+                                       <option value='padlock'                 $selected{'ENGINES'}{'padlock'}>Padlock</option>
+                                       <option value='disabled'                $selected{'ENGINES'}{'disabled'}>$Lang::tr{'disabled'} (Default)</option>
                                </select>
                        </td>
                </tr>
  
-               <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'MTU'}&nbsp;<img src='/blob.gif' /></td>
+               <tr><td colspan=2><hr /></td></tr><tr>
+                       <tr><td class='boldbase' nowrap='nowrap'>Management Port ($Lang::tr{'openvpn default'}: <span class="base">$Lang::tr{'destination port'}): &nbsp;<img src='/blob.gif' /></td>
+                       <td> <input type='TEXT' name='OVPN_MGMT' VALUE='$cgiparams{'OVPN_MGMT'}'size='5' /></td>
+               </tr>
+               <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'MTU'}&nbsp;<img src='/blob.gif' /></td>
                        <td> <input type='TEXT' name='MTU' VALUE='$cgiparams{'MTU'}'size='5' /></td>
                        <td colspan='2'>$Lang::tr{'openvpn default'}: udp/tcp <span class="base">1500/1400</span></td>
+               </tr>
  
-               <tr><td class='boldbase' nowrap='nowrap'>fragment: &nbsp;<img src='/blob.gif' /></td>
+               <tr><td class='boldbase' nowrap='nowrap'>fragment &nbsp;<img src='/blob.gif' /></td>
                        <td><input type='TEXT' name='FRAGMENT' VALUE='$cgiparams{'FRAGMENT'}'size='5' /></td>
                        <td>$Lang::tr{'openvpn default'}: <span class="base">1300</span></td>
+               </tr>
  
-               <tr><td class='boldbase' nowrap='nowrap'>mssfix: &nbsp;<img src='/blob.gif' /></td>
+               <tr><td class='boldbase' nowrap='nowrap'>mssfix &nbsp;<img src='/blob.gif' /></td>
                        <td><input type='checkbox' name='MSSFIX' $checked{'MSSFIX'}{'on'} /></td>
                        <td>$Lang::tr{'openvpn default'}: <span class="base">on</span></td>
-         <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'comp-lzo'} &nbsp;<img src='/blob.gif'</td>
-                       <td><input type='checkbox' name='COMPLZO' $checked{'COMPLZO'}{'on'} /></td>
                </tr>
  
-               <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'ovpn mtu-disc'}:</td>
-                       <td colspan='3'>
-                               <input type='radio' name='PMTU_DISCOVERY' value='yes' $checked{'PMTU_DISCOVERY'}{'yes'} /> $Lang::tr{'ovpn mtu-disc yes'}
-                               <input type='radio' name='PMTU_DISCOVERY' value='maybe' $checked{'PMTU_DISCOVERY'}{'maybe'} /> $Lang::tr{'ovpn mtu-disc maybe'}
-                               <input type='radio' name='PMTU_DISCOVERY' value='no' $checked{'PMTU_DISCOVERY'}{'no'} /> $Lang::tr{'ovpn mtu-disc no'}
-                               <input type='radio' name='PMTU_DISCOVERY' value='off' $checked{'PMTU_DISCOVERY'}{'off'} /> $Lang::tr{'ovpn mtu-disc off'}
-                       </td>
+               <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'comp-lzo'} &nbsp;<img src='/blob.gif'</td>
+                       <td><input type='checkbox' name='COMPLZO' $checked{'COMPLZO'}{'on'} /></td>
                </tr>
  
 -
+       <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'ovpn mtu-disc'}</td>
+               <td colspan='3'>
+                       <input type='radio' name='PMTU_DISCOVERY' value='yes' $checked{'PMTU_DISCOVERY'}{'yes'} /> $Lang::tr{'ovpn mtu-disc yes'}
+                       <input type='radio' name='PMTU_DISCOVERY' value='maybe' $checked{'PMTU_DISCOVERY'}{'maybe'} /> $Lang::tr{'ovpn mtu-disc maybe'}
+                       <input type='radio' name='PMTU_DISCOVERY' value='no' $checked{'PMTU_DISCOVERY'}{'no'} /> $Lang::tr{'ovpn mtu-disc no'}
+                       <input type='radio' name='PMTU_DISCOVERY' value='off' $checked{'PMTU_DISCOVERY'}{'off'} /> $Lang::tr{'ovpn mtu-disc off'}
+               </td>
+       </tr>
  END
  ;
        }
@@@ -4570,7 -4672,7 +4712,7 @@@ if ($cgiparams{'TYPE'} eq 'host') 
   
   if ($cgiparams{'TYPE'} eq 'host') {
  
-     print <<END;
+       print <<END;
            <table width='100%' cellpadding='0' cellspacing='5' border='0'>
            
            <tr><td><input type='radio' name='AUTH' value='certreq' $checked{'AUTH'}{'certreq'} $cakeydisabled /></td><td class='base'>$Lang::tr{'upload a certificate request'}</td><td class='base' rowspan='2'><input type='file' name='FH' size='30' $cacrtdisabled></td></tr>
@@@ -4595,7 -4697,7 +4737,7 @@@ EN
  
  } else {
  
-     print <<END;
+       print <<END;
            <table width='100%' cellpadding='0' cellspacing='5' border='0'>
        
            <tr><td><input type='radio' name='AUTH' value='certgen' $checked{'AUTH'}{'certgen'} $cakeydisabled /></td><td class='base'>$Lang::tr{'generate a certificate'}</td><td>&nbsp;</td></tr>
@@@ -4629,7 -4731,7 +4771,7 @@@ EN
  ###
  
  if ($cgiparams{'TYPE'} eq 'host') {
-     print <<END;
+       print <<END;
            </select></td></tr>
  
        <td>&nbsp;</td><td class='base'>$Lang::tr{'valid till'} (days):</td>
     <tr><td>&nbsp;</td>
                <td class='base'>$Lang::tr{'pkcs12 file password'}:</td>
                <td class='base' nowrap='nowrap'><input type='password' name='CERT_PASS1' value='$cgiparams{'CERT_PASS1'}' size='32' $cakeydisabled /></td></tr>
 -          <tr><td>&nbsp;</td><td class='base'>$Lang::tr{'pkcs12 file password'}:<br>($Lang::tr{'confirmation'})</td>
 +          <tr><td>&nbsp;</td><td class='base'>$Lang::tr{'pkcs12 file password'}:<BR>($Lang::tr{'confirmation'})</td>
                <td class='base' nowrap='nowrap'><input type='password' name='CERT_PASS2' value='$cgiparams{'CERT_PASS2'}' size='32' $cakeydisabled /></td></tr>
       <tr><td colspan='3'>&nbsp;</td></tr>
       <tr><td colspan='3'><hr /></td></tr>
       </table>
  END
  }else{
-     print <<END;
+       print <<END;
            </select></td></tr>
     <tr><td>&nbsp;</td><td>&nbsp;</td><td>&nbsp;</td></tr>
         <tr><td>&nbsp;</td><td>&nbsp;</td><td>&nbsp;</td></tr>
@@@ -4773,7 -4875,7 +4915,7 @@@ EN
        if (&haveOrangeNet() && $selorange == '1'){ print"<option selected>$Lang::tr{'orange'}</option>";$selorange=0;}elsif(&haveOrangeNet() && $selorange == '0'){print"<option>$Lang::tr{'orange'}</option>";}                       
        if ($selgreen == '1' || $other == '0'){ print"<option selected>$Lang::tr{'green'}</option>";$set=0;}else{print"<option>$Lang::tr{'green'}</option>";};
        
-       print<<END
+       print<<END;
        </select></td><td valign='top'>DNS1:</td><td valign='top'><input type='TEXT' name='CCD_DNS1' value='$cgiparams{'CCD_DNS1'}' size='30' /></td></tr>
        <tr valign='top'><td>DNS2:</td><td><input type='TEXT' name='CCD_DNS2' value='$cgiparams{'CCD_DNS2'}' size='30' /></td></tr>
        <tr valign='top'><td valign='top'>WINS:</td><td><input type='TEXT' name='CCD_WINS' value='$cgiparams{'CCD_WINS'}' size='30' /></td></tr></table><br><hr>
      
  #default setzen
      if ($cgiparams{'DCIPHER'} eq '') {
 -      $cgiparams{'DCIPHER'} =  'AES-256-CBC';
 +              $cgiparams{'DCIPHER'} =  'AES-256-CBC';
      }
      if ($cgiparams{'DDEST_PORT'} eq '') {
 -      $cgiparams{'DDEST_PORT'} =  '1194';     
 +              $cgiparams{'DDEST_PORT'} =  '1194';
      }
      if ($cgiparams{'DMTU'} eq '') {
 -      $cgiparams{'DMTU'} =  '1400';     
 +              $cgiparams{'DMTU'} =  '1400';
 +    }
 +    if ($cgiparams{'MSSFIX'} eq '') {
 +              $cgiparams{'MSSFIX'} = 'off';
 +    }
 +      if ($cgiparams{'DAUTH'} eq '') {
 +              $cgiparams{'DAUTH'} = 'SHA1';
      }
+     if ($cgiparams{'ENGINES'} eq '') {
+       $cgiparams{'ENGINES'} = 'disabled';
+     }
      if ($cgiparams{'DOVPN_SUBNET'} eq '') {
 -      $cgiparams{'DOVPN_SUBNET'} = '10.' . int(rand(256)) . '.' . int(rand(256)) . '.0/255.255.255.0';
 +              $cgiparams{'DOVPN_SUBNET'} = '10.' . int(rand(256)) . '.' . int(rand(256)) . '.0/255.255.255.0';
      }
      $checked{'ENABLED'}{'off'} = '';
      $checked{'ENABLED'}{'on'} = '';
      $selected{'DPROTOCOL'}{'udp'} = '';
      $selected{'DPROTOCOL'}{'tcp'} = '';
      $selected{'DPROTOCOL'}{$cgiparams{'DPROTOCOL'}} = 'SELECTED';
 -    
 +
      $selected{'DCIPHER'}{'CAMELLIA-256-CBC'} = '';
      $selected{'DCIPHER'}{'CAMELLIA-192-CBC'} = '';
      $selected{'DCIPHER'}{'CAMELLIA-128-CBC'} = '';
      $selected{'DAUTH'}{'SHA512'} = '';
      $selected{'DAUTH'}{'SHA384'} = '';
      $selected{'DAUTH'}{'SHA256'} = '';
-     $selected{'DAUTH'}{'ecdsa-with-SHA1'} = '';
      $selected{'DAUTH'}{'SHA1'} = '';
      $selected{'DAUTH'}{$cgiparams{'DAUTH'}} = 'SELECTED';
  
+     $selected{'ENGINES'}{'cryptodev'} = '';
+     $selected{'ENGINES'}{'dynamic'} = '';
+     $selected{'ENGINES'}{'aesni'} = '';
+     $selected{'ENGINES'}{'padlock'} = '';
+     $selected{'ENGINES'}{'disabled'} = '';
+     $selected{'ENGINES'}{$cgiparams{'ENGINES'}} = 'SELECTED';
      $checked{'DCOMPLZO'}{'off'} = '';
      $checked{'DCOMPLZO'}{'on'} = '';
      $checked{'DCOMPLZO'}{$cgiparams{'DCOMPLZO'}} = 'CHECKED';
 +
  # m.a.d
      $checked{'MSSFIX'}{'off'} = '';
      $checked{'MSSFIX'}{'on'} = '';
      } 
      &Header::openbox('100%', 'LEFT', $Lang::tr{'global settings'});   
        print <<END;
-     <table width='100%' border=0>
+     <table width='100%' border='0'>
      <form method='post'>
      <td width='25%'>&nbsp;</td>
      <td width='25%'>&nbsp;</td>
@@@ -4942,7 -5046,7 +5093,7 @@@ EN
        print "<tr><td class='boldbase'>$Lang::tr{'ovpn on orange'}</td>";
        print "<td><input type='checkbox' name='ENABLED_ORANGE' $checked{'ENABLED_ORANGE'}{'on'} /></td>";
      } 
 -    print <<END       
 +    print <<END;
      <tr><td class='base' nowrap='nowrap' colspan='2'>$Lang::tr{'local vpn hostname/ip'}:<br /><input type='text' name='VPN_IP' value='$cgiparams{'VPN_IP'}' size='30' /></td>
        <td class='boldbase' nowrap='nowrap' colspan='2'>$Lang::tr{'ovpn subnet'}<br /><input type='TEXT' name='DOVPN_SUBNET' value='$cgiparams{'DOVPN_SUBNET'}' size='30' /></td></tr>
      <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'ovpn device'}</td>
          <td><input type='TEXT' name='DDEST_PORT' value='$cgiparams{'DDEST_PORT'}' size='5' /></td></tr>
      <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'MTU'}&nbsp;</td>
          <td> <input type='TEXT' name='DMTU' VALUE='$cgiparams{'DMTU'}'size='5' /></td>
 -
                <td class='boldbase' nowrap='nowrap'>$Lang::tr{'cipher'}</td>
                <td><select name='DCIPHER'>
                                <option value='CAMELLIA-256-CBC' $selected{'DCIPHER'}{'CAMELLIA-256-CBC'}>CAMELLIA-CBC (256 $Lang::tr{'bit'})</option>
      <tr><td class='boldbase' nowrap='nowrap'>$Lang::tr{'comp-lzo'}</td>
          <td><input type='checkbox' name='DCOMPLZO' $checked{'DCOMPLZO'}{'on'} /></td>
        </tr>
 -
      <tr><td colspan='4'><br><br></td></tr>
  END
  ;                                
      &Header::closebox();
  
      if ( -f "${General::swroot}/ovpn/ca/cacert.pem" ) {
 -
  ###
  # m.a.d net2net
  #<td width='25%' class='boldbase' align='center'><b>$Lang::tr{'remark'}</b><br /><img src='/images/null.gif' width='125' height='1' border='0' alt='L2089' /></td>
        </tr>
  
        <tr>
-               <td class='base' nowrap='nowrap'>$Lang::tr{'ovpn dh name'}:</td>
-               <td nowrap='nowrap'><input type='text' name='DH_NAME' value='$cgiparams{'DH_NAME'}' size='15' align='left'/></td>
+               <td class='base' nowrap='nowrap'>$Lang::tr{'ovpn dh upload'}:</td>
+               <td nowrap='nowrap'><size='15' align='left'/></td>
                <td nowrap='nowrap'><input type='file' name='FH' size='25' />
-               <td nowrap='nowrap' align='right'><input type='submit' name='ACTION' value='$Lang::tr{'upload dh key'}' /></td>
+               <td colspan='4' align='right'><input type='submit' name='ACTION' value='$Lang::tr{'upload dh key'}' /></td>
        </tr>
        <tr><td colspan='4'><br></td></tr>
        <tr>
diff --combined langs/de/cgi-bin/de.pl
index ab12e9ead69b29728f501056dab39e04e7a18031,6a1f3f28637b7b80eaeb0aa5ec5ad00f1ab76d08..6cf4dfcecb3bfa2288ddf894bf22716349680b3c
@@@ -1,15 -1,17 +1,15 @@@
  %tr = ( 
  %tr,
  
 -'Act as' => 'Konfiguriert als',
 +'Act as' => 'Konfiguriert als:',
  'Add Level7 rule' => 'Level7-Regel hinzufügen',
  'Add Port Rule' => 'Port-Regel hinzufügen',
  'Add Rule' => 'Regel hinzufügen',
  'Add a route' => 'Eine Route hinzufügen',
  'Async logging enabled' => 'Aktiviere asynchrones Schreiben des Syslogs',
 -'bit' => 'Bit',
  'Choose Rule' => 'Wählen Sie <u>eine</u> der untenstehenden Regeln aus.',
  'Class' => 'Klasse',
  'Class was deleted' => 'wurde mit eventuell vorhandenen Unterklassen gelöscht',
 -'Client status and controlc' => 'Client-Status und -Kontrolle',
  'ConnSched action' => 'Aktion:',
  'ConnSched add action' => 'Aktion hinzufügen',
  'ConnSched change profile title' => 'Wechsle zu Profil:',
@@@ -38,8 -40,7 +38,8 @@@
  'Local VPN IP' => 'Internes Netzwerk (GREEN)',
  'MB read' => 'MB gelesen',
  'MB written' => 'MB geschrieben',
- 'MTU' => 'MTU Size',
+ 'MTU' => 'MTU Size:',
 +'Number of Countries for the pie chart' => 'Anzahl der angezeigten Länder im Diagramm',
  'Number of IPs for the pie chart' => 'Anzahl der angezeigten IPs im Diagramm',
  'Number of Ports for the pie chart' => 'Anzahl der angezeigten Ports im Diagramm',
  'OVPN' => 'OpenVPN',
  'cant change certificates' => 'Kann Zertifikate nicht ändern.',
  'cant enable xtaccess' => 'Die zugehörige Port-Weiterleitungsregel ist deaktiviert, daher können Sie den externen Zugang für diese Regel nicht aktivieren.',
  'cant start openssl' => 'Kann OpenSSL nicht starten',
 +'capabilities' => 'Unterstützte Features',
  'caps all' => 'ALLE',
  'capsclosed' => 'GETRENNT',
  'capsinactive' => 'INAKTIV',
  'device' => 'Gerät',
  'devices on blue' => 'Geräte auf Blau',
  'dh' => 'Diffie-Hellman Key',
- 'dh key warn' => 'Keys mit 1024 und 2048 Bit können mehrere Minuten, 3072 und 4096 Bit bis zu mehreren Stunden dauern. Bitte haben sie Geduld.',
- 'dh name is invalid' => 'Name ist ungültig, bitte "dh1024.pem" verwenden.',
+ 'dh key move failed' => 'Verschieben des Diffie-Hellman keys fehlgeschlagen.',
+ 'dh key warn' => 'Diffie-Hellman Keys mit 1024 und 2048 Bit können mehrere Minuten, 3072 und 4096 Bit bis zu mehreren Stunden dauern. Bitte haben sie Geduld.',
+ 'dh key warn1' => 'Bei schwachen Systemen oder Systeme mit wenig Entropie wird empfohlen lange Diffie-Hellman Keys über die Upload Funktion zu integrieren.',
  'dhcp advopt add' => 'DHCP Option hinzufügen',
  'dhcp advopt added' => 'DHCP Option hinzugefügt',
  'dhcp advopt blank value' => 'Wert für DHCP Option darf nicht leer sein',
  'dns proxy server' => 'DNS-Proxyserver',
  'dns saved' => 'Erfolgreich gespeichert!',
  'dns saved txt' => 'Die beiden eingegebenen DNS-Server-Adressen wurde erfolgreich gespeichert.<br/>Um die Änderung wirksam zu machen, müssen Sie neustarten oder wiederverbinden!',
 -'dns server' => 'DNS-Server',
 -'dns servers' => 'DNS-Server',
 +'dns server' => 'DNS Server',
  'dns title' => 'Domain Name System',
  'dnsforward' => 'DNS-Weiterleitung',
  'dnsforward add a new entry' => 'Neuen Eintrag hinzufügen',
  'donation-text' => '<strong>IPFire</strong> wird von Freiwilligen in ihrer Freizeit betrieben und auch betreut. Um dieses Projekt am Laufen zu halten, entstehen uns natürlich auch Kosten. Wenn Sie uns unterstützen wollen, würden wir uns über eine kleine Spende sehr freuen.',
  'dos charset' => 'DOS Charset',
  'down and up speed' => 'Geben Sie bitte hier ihre Download- bzw. Upload-Geschwindigkeit ein <br /> und klicken Sie danach auf <i>Speichern</i>.',
 -'downlink' => 'Downlink',
  'downlink speed' => 'Downlink-Geschwindigkeit (kBit/sek)',
  'downlink std class' => 'Downloadstandardklasse',
  'download' => 'herunterladen',
  'firewall log' => 'Firewall-Protokoll',
  'firewall log viewer' => 'Betrachter der Firewall-Logdateien',
  'firewall logs' => 'Firewall-Logdateien',
 +'firewall logs country' => 'Fw-Logdiagramme (Land)',
  'firewall logs ip' => 'Fw-Logdiagramme (IP)',
  'firewall logs port' => 'Fw-Logdiagramme (Port)',
  'firewall rules' => 'Firewallregeln',
  'firewallhits' => 'Firewalltreffer',
  'firmware' => 'Firmware',
  'firmware upload' => 'Hochladen der Firmware/Treiber',
 -'first' => 'Erste',
  'fixed ip lease added' => 'Feste IP-Zuordnung hinzugefügt',
  'fixed ip lease modified' => 'Feste IP-Zuordnung geändert',
  'fixed ip lease removed' => 'Feste IP-Zuordnung gelöscht',
  'ike integrity' => 'IKE Integrität:',
  'ike lifetime' => 'IKE Lebensdauer:',
  'ike lifetime should be between 1 and 8 hours' => 'IKE Lebensdauer sollte zwischen 1 und 8 Stunden betragen.',
 +'imei' => 'IMEI',
  'import' => 'Import',
  'importkey' => 'PSK importieren',
 +'imsi' => 'IMSI',
  'in' => 'Ein',
  'inactive' => 'inaktiv',
  'include logfiles' => 'mit Logdateien',
  'lan' => 'LAN',
  'lang' => 'de',
  'languagepurpose' => 'Wählen Sie eine Sprache, in der IPFire angezeigt werden soll:',
 -'last' => 'Letzte',
  'last activity' => 'Letzte Aktivität',
  'lateprompting' => 'Late prompting',
  'lease expires' => 'Zuordnung verfällt',
  'missing dat' => 'Verschlüsseltes Archiv wurde nicht gefunden',
  'missing gz' => 'Nichtverschlüsseltes Archiv wurde nicht gefunden',
  'mode' => 'Modus',
 +'model' => 'Modell',
  'modem' => 'Modem',
  'modem configuration' => 'Modem-Konfiguration',
 +'modem hardware details' => 'Modem-Hardware',
 +'modem information' => 'Modem-Informationen',
 +'modem network bit error rate' => 'Bit-Fehlerrate',
 +'modem network information' => 'Netzwerkinformationen',
 +'modem network mode' => 'Netzwerkmodus',
 +'modem network operator' => 'Netzbetreiber',
 +'modem network registration' => 'Netzregistrierung',
 +'modem network signal quality' => 'Signalqualität',
 +'modem no connection' => 'Keine Verbindung',
 +'modem no connection message' => 'Es konnte keine Verbindung zum Modem aufgebaut werden.',
  'modem on com1' => 'Modem an COM1',
  'modem on com2' => 'Modem an COM2',
  'modem on com3' => 'Modem an COM3',
  'modem on com4' => 'Modem an COM4',
  'modem on com5' => 'Modem an COM5',
  'modem settings have errors' => 'Modemeinstellungen fehlerhaft',
 +'modem sim information' => 'SIM-Informationen',
  'modem speaker on' => 'Modemlautsprecher an:',
 +'modem status' => 'Modem-Status',
  'modify' => 'Ändern',
  'modulation' => 'Modulation',
  'monday' => 'Montag',
  'network traffic graphs others' => 'Netzwerk (sonstige)',
  'network updated' => 'Benutzerdefiniertes Netzwerk aktualisiert',
  'networks settings' => 'Firewall - Netzwerkeinstellungen',
 +'never' => 'Nie',
  'new optionsfw later' => 'Einige Einstellungen werden erst nach einem Neustart aktiv',
  'new optionsfw must boot' => 'Sie müssen Ihren IPFire neu starten',
  'newer' => 'Neuer',
  'outgoing traffic in bytes per second' => 'Abgehender Verkehr',
  'override mtu' => 'Überschreibe Standard MTU',
  'ovpn' => 'OpenVPN',
 -'ovpn crypt options' => 'Kryptografieoptionen',
  'ovpn con stat' => 'OpenVPN Verbindungs-Statistik',
  'ovpn config' => 'OVPN-Konfiguration',
- 'ovpn device' => 'OpenVPN-Gerät:',
 +'ovpn crypt options' => 'Kryptografieoptionen',
+ 'ovpn device' => 'OpenVPN-Gerät',
  'ovpn dh' => 'Diffie-Hellman Key Länge',
- 'ovpn dh name' => 'Diffie-Hellman Key Name',
+ 'ovpn dh upload' => 'Upload Diffie-Hellman Key',
  'ovpn dl' => 'OVPN-Konfiguration downloaden',
  'ovpn engines' => 'Krypto Engine',
  'ovpn errmsg green already pushed' => 'Route für grünes Netzwerk wird immer gesetzt',
  'ovpn errmsg invalid ip or mask' => 'Ungültige Netzwerk-Adresse oder Subnetzmaske',
  'ovpn generating the root and host certificates' => 'Die Erzeugung der Root- und Host-Zertifikate kann lange Zeit dauern.',
 -'ovpn hmac' => 'HMAC Optionen',
  'ovpn ha' => 'Hash Algorithmus',
 +'ovpn hmac' => 'HMAC Optionen',
  'ovpn log' => 'OVPN-Log',
  'ovpn mgmt in root range' => 'Ein Port von 1024 oder höher ist erforderlich.',
  'ovpn mtu-disc' => 'Path MTU Discovery',
  'ovpn on orange' => 'OpenVPN auf ORANGE:',
  'ovpn on red' => 'OpenVPN auf ROT:',
  'ovpn port in root range' => 'Ein Port von 1024 oder höher ist erforderlich.',
 +'ovpn reneg sec' => 'Session Key Lifetime',
  'ovpn routes push' => 'Routen (eine pro Zeile) z.b. 192.168.10.0/255.255.255.0 192.168.20.0/24',
  'ovpn routes push options' => 'Route push Optionen',
- 'ovpn server status' => 'OpenVPN-Server-Status:',
+ 'ovpn server status' => 'OpenVPN-Server-Status',
  'ovpn subnet' => 'OpenVPN-Subnetz:',
  'ovpn subnet is invalid' => 'Das OpenVPN-Subnetz ist ungültig.',
  'ovpn subnet overlap' => 'OpenVPNSubnetz überschneidet sich mit  ',
  'profile saved' => 'Profil gespeichert: ',
  'profiles' => 'Profile:',
  'proto' => 'Proto',
 -'protocol' => 'Protokoll',
 +'protocol' => 'Protokoll:',
  'proxy' => 'Proxy',
  'proxy access graphs' => 'Diagramme zur Proxyauslastung',
  'proxy admin password' => 'Cache Administrator Passwort',
  'snort hits' => 'Gesamtanzahl der aktivierten Intrusion-Regeln für',
  'snort working' => 'Snort führt gerade eine Aufgabe aus... Bitte warten Sie, bis diese erfolgreich beendet wurde.',
  'socket options' => 'Socket Options',
 +'software version' => 'Software-Version',
  'sort ascending' => 'Sortiere aufsteigend',
  'sort descending' => 'Sortiere absteigend',
  'sound' => 'Klang',
  'source ip' => 'Quell-IP-Adresse',
  'source ip and port' => 'Quell-IP:Port',
  'source ip bad' => 'Ungültige Quell-IP-Adresse.',
 +'source ip country' => 'Quell-IP-Adresse Land',
  'source ip in use' => 'Benutzte Quell-IP:',
  'source ip or net' => 'Quellen-IP oder Netz',
  'source net' => 'Quell-Netz',
  'updxlrtr weekly' => 'wöchentlich',
  'updxlrtr year' => 'einem Jahr',
  'upgrade' => 'upgrade',
 -'uplink' => 'Uplink',
  'uplink speed' => 'Uplink-Geschwindigkeit (kBit/sek)',
  'uplink std class' => 'Uploadstandardklasse',
  'upload' => 'Hochladen',
  'valid root certificate already exists' => 'Ein gültiges Root-Zertifikat existiert bereits.',
  'valid till' => 'Gültig bis',
  'vci number' => 'VCI-Nummer:',
 +'vendor' => 'Hersteller',
  'view log' => 'Log anzeigen',
  'virtual address' => 'Virtuelle Addresse',
  'virtual private networking' => 'Virtuelles Privates Netzwerk',
  'vpn aggrmode' => 'IKE Aggressive Mode zugelassen. Wenn möglich, vermeiden (preshared Schlüssel wird im Klartext übertragen)!',
  'vpn altname syntax' => 'Der Subjekt Alternativ Name ist eine durch Komma getrennte Liste von Email, DNS, URI, RID und IP Objekten. <br />Email: eine Email Adresse. Syntax Email: \'copy\' benutzt die Email Adresse aus dem Zertifikatfeld. <br />DNS: ein gültiger Domain Name.<br />URI: eine gültige URI.<br />RID: Registriertes Objekt Identifikation.<br />IP: eine IP Adresse.<br />Bitte beachten: der Zeichensatz ist eingeschränkt und die Groß-/Kleinschreibung ist entscheidend.<br />Beispiel:<br /><b>email:</b>info@ipfire.org<b>,email:</b>copy<b>,DNS:</b>www.ipfire.org<b>,IP:</b>127.0.0.1<b>,URI:</b>http://url/nach/irgendwo',
  'vpn auth-dn' => 'Peer wird identifiziert durch entweder ein IPV4_ADDR, FQDN, USER_FQDN oder DER_ASN1_DN string in Remote ID Feld',
 -'vpn configuration main' => 'VPN-Konfiguration',
  'vpn delayed start' => 'Verzögerung bevor VPN gestartet wird (Sekunden)',
  'vpn delayed start help' => 'Falls notwendig, kann diese Verzögerung dazu verwendet werden, um Dynamic-DNS-Updates ordnungsgemäß anzuwenden. 60 ist ein gängiger Wert, wenn ROT (RED) eine dynamische IP Adresse ist.',
  'vpn incompatible use of defaultroute' => 'Hostname=%defaultroute nicht zulässig',
diff --combined langs/en/cgi-bin/en.pl
index a865fea4528236845940b745cf983e7cfe3acbfc,99d905e41fa7d94e59ebf56345588dd1dcebfd46..e1186323b628e93272265773a6a3627b2941dc02
@@@ -7,9 -7,11 +7,9 @@@
  'Add Rule' => 'Add rule',
  'Add a route' => 'Add a route',
  'Async logging enabled' => 'Enable asynchronous writing of the syslog file',
 -'bit' => 'bit',
  'Choose Rule' => 'Choose <u>one</u> of the following rules.',
  'Class' => 'Class',
  'Class was deleted' => 'with potential subclasses was deleted',
 -'Client status and controlc' => 'Client status and control:',
  'ConnSched action' => 'Action:',
  'ConnSched add action' => 'Add action',
  'ConnSched change profile title' => 'Change to profile:',
@@@ -39,7 -41,6 +39,7 @@@
  'MB read' => 'MB read',
  'MB written' => 'MB written',
  'MTU' => 'MTU size:',
 +'Number of Countries for the pie chart' => 'Number of Countries for the pie chart',
  'Number of IPs for the pie chart' => 'Number of IPs for the pie chart',
  'Number of Ports for the pie chart' => 'Number of ports for the pie chart',
  'OVPN' => 'OpenVPN',
  'behind a proxy' => 'Behind a proxy:',
  'bewan adsl pci st' => 'TO BE REMOVED',
  'bewan adsl usb' => 'TO BE REMOVED',
 -'bit' => 'Bit',
 +'bit' => 'bit',
  'bitrate' => 'Bitrate',
  'bleeding rules' => 'Bleeding Edge Snort Rules',
  'blue' => 'BLUE',
  'cant change certificates' => 'Can\'t change certificates.',
  'cant enable xtaccess' => 'The associated port forwarding rule is disabled, therefore you cannot enable external access for this rule.',
  'cant start openssl' => 'Can\'t start OpenSSL',
 +'capabilities' => 'Capabilities',
  'caps all' => 'ALL',
  'capsclosed' => 'DISCONNECTED',
  'capsinactive' => 'INACTIVE',
  'device' => 'Device',
  'devices on blue' => 'Devices on BLUE',
  'dh' => 'Diffie-Hellman Key',
- 'dh key warn' => 'Keys with 1024 and 2048 bit takes up to several minutes, 3072 and 4096 bit might needs several hours. Please be patient.',
++'dh key move failed' => 'Diffie-Hellman key move failed.',
++'dh key warn' => 'Diffie-Hellman keys with 1024 and 2048 bit takes up to several minutes, 3072 and 4096 bit might needs several hours. Please be patient.',
++'dh key warn1' => 'For weak systems or systems with little entropy it is recommended to integrate long Diffie-Hellman Keys by usage of the upload function.',
 +'dh name is invalid' => 'Name is invalid, please use "dh1024.pem".',
  'dhcp advopt add' => 'Add a DHCP option',
  'dhcp advopt added' => 'DHCP option added',
  'dhcp advopt blank value' => 'DHCP Option value cannot be empty.',
  'dhcp server enabled' => 'DHCP server enabled.  Restarting.',
  'dhcp server enabled on blue interface' => 'DHCP server enabled on BLUE interface',
  'dhcp-options' => 'DHCP push options',
 -'dh key warn' => 'Diffie-Hellman keys with 1024 and 2048 bit takes up to several minutes, 3072 and 4096 bit might needs several hours. Please be patient.',
 -'dh key warn1' => 'For weak systems or systems with little entropy it is recommended to integrate long Diffie-Hellman Keys by usage of the upload function.',
 -'dh key move failed' => 'Diffie-Hellman key move failed.',
  'dial' => 'Connect',
  'dial profile' => 'Connect with profile',
  'dial user password' => 'Dial user password:',
  'dns saved' => 'Successfully saved!',
  'dns saved txt' => 'The two entered DNS server addresses have been saved successfully.<br />You have to reboot or reconnect that the changes have effect!',
  'dns server' => 'DNS Server',
 -'dns servers' => 'DNS Servers',
  'dns title' => 'Domain Name System',
  'dnsforward' => 'DNS Forwarding',
  'dnsforward add a new entry' => 'Add a new entry',
  'done' => 'Do it',
  'dos charset' => 'DOS Charset',
  'down and up speed' => 'Enter your Down- and Uplink-Speed <br /> and then press <i>Save</i>.',
 -'downlink' => 'Downlink',
  'downlink speed' => 'Downlink speed (kbit/sec)',
  'downlink std class' => 'downlink standard class',
  'download' => 'download',
  'firewall log' => 'Firewall log',
  'firewall log viewer' => 'Firewall Log Viewer',
  'firewall logs' => 'Firewall Logs',
 +'firewall logs country' => 'Fw-Loggraphs (Country)',
  'firewall logs ip' => 'Fw-Loggraphs (IP)',
  'firewall logs port' => 'Fw-Loggraphs (Port)',
  'firewall rules' => 'Firewall Rules',
  'firewallhits' => 'firewallhits',
  'firmware' => 'Firmware',
  'firmware upload' => 'Upload Firmware/Drivers',
 -'first' => 'First',
  'fixed ip lease added' => 'Fixed IP lease added',
  'fixed ip lease modified' => 'Fixed IP lease modified',
  'fixed ip lease removed' => 'Fixed IP lease removed',
  'ike integrity' => 'IKE Integrity:',
  'ike lifetime' => 'IKE Lifetime:',
  'ike lifetime should be between 1 and 8 hours' => 'IKE lifetime should be between 1 and 8 hours.',
 +'imei' => 'IMEI',
  'import' => 'Import',
  'importkey' => 'Import PSK',
 +'imsi' => 'IMSI',
  'in' => 'In',
  'inactive' => 'inactive',
  'include logfiles' => 'Include logfiles',
  'lan' => 'LAN',
  'lang' => 'en',
  'languagepurpose' => 'Select the language you wish IPFire to display in:',
 -'last' => 'Last',
  'last activity' => 'Last Activity',
  'lateprompting' => 'Lateprompting',
  'lease expires' => 'Lease expires',
  'missing dat' => 'Encrypted archive not found',
  'missing gz' => 'Unencrypted archive not found',
  'mode' => 'Mode',
 +'model' => 'Model',
  'modem' => 'Modem',
  'modem configuration' => 'Modem configuration',
 +'modem hardware details' => 'Modem Hardware',
 +'modem information' => 'Modem Information',
 +'modem network bit error rate' => 'Bit Error Rate',
 +'modem network information' => 'Network Information',
 +'modem network mode' => 'Network Mode',
 +'modem network operator' => 'Network Operator',
 +'modem network registration' => 'Network Registration',
 +'modem network signal quality' => 'Signal Quality',
 +'modem no connection' => 'No Connection',
 +'modem no connection message' => 'No connection to the modem could be established.',
  'modem on com1' => 'Modem on COM1',
  'modem on com2' => 'Modem on COM2',
  'modem on com3' => 'Modem on COM3',
  'modem on com4' => 'Modem on COM4',
  'modem on com5' => 'Modem on COM5',
  'modem settings have errors' => 'Modem settings have errors',
 +'modem sim information' => 'SIM Information',
  'modem speaker on' => 'Modem speaker on:',
 +'modem status' => 'Modem Status',
  'modify' => 'Modify',
  'modulation' => 'Modulation',
  'monday' => 'Monday',
  'network traffic graphs others' => 'Network (others)',
  'network updated' => 'Custom Network updated',
  'networks settings' => 'Firewall - Network settings',
 +'never' => 'Never',
  'new optionsfw later' => 'Some options need a reboot to take effect',
  'new optionsfw must boot' => 'You must reboot your IPFire',
  'newer' => 'Newer',
  'ovpn con stat' => 'OpenVPN Connection Statistics',
  'ovpn config' => 'OVPN-Config',
  'ovpn crypt options' => 'Cryptographic options',
 -'ovpn engines' => 'Crypto engine',
  'ovpn device' => 'OpenVPN device:',
  'ovpn dh' => 'Diffie-Hellman key lenght',
- 'ovpn dh name' => 'Diffie-Hellman key name',
+ 'ovpn dh upload' => 'Upload Diffie-Hellman Key',
  'ovpn dl' => 'OVPN-Config Download',
 +'ovpn engines' => 'Crypto engine',
  'ovpn errmsg green already pushed' => 'Route for green network is always set',
  'ovpn errmsg invalid ip or mask' => 'Invalid network-address or subnetmask',
  'ovpn generating the root and host certificates' => 'Generating the root and host certifictae can take a long time.',
  'ovpn on orange' => 'OpenVPN on ORANGE:',
  'ovpn on red' => 'OpenVPN on RED:',
  'ovpn port in root range' => 'A port number of 1024 or higher is required.',
 +'ovpn reneg sec' => 'Session key lifetime:',
  'ovpn routes push' => 'Routes (one per line) e.g. 192.168.10.0/255.255.255.0 192.168.20.0/24',
  'ovpn routes push options' => 'Route push options',
  'ovpn server status' => 'Current OpenVPN server status:',
  'ovpn subnet is invalid' => 'OpenVPN subnet is invalid.',
  'ovpn subnet overlap' => 'OpenVPN Subnet overlaps with : ',
  'ovpn_fastio' => 'Fast-IO',
- 'ovpn_fragment' => 'Fragmentsize',
 -'teovpn_fragment' => 'Fragmentsize',
  'ovpn_mssfix' => 'MSSFIX Size',
  'ovpn_mtudisc' => 'MTU-Discovery',
  'ovpn_processprio' => 'Process priority',
  'snort hits' => 'Total of number of Intrusion rules activated for',
  'snort working' => 'Snort is working ... Please wait until all operations have completed successfully.',
  'socket options' => 'Socket options',
 +'software version' => 'Software Version',
  'sort ascending' => 'Sort ascending',
  'sort descending' => 'Sort descending',
  'sound' => 'Sound',
  'source ip' => 'Source IP',
  'source ip and port' => 'Source IP: Port',
  'source ip bad' => 'Not a valid IP address or a network address.',
 +'source ip country' => 'Source IP Country',
  'source ip in use' => 'Source IP in use:',
  'source ip or net' => 'Source IP or Net',
  'source net' => 'Source Net',
  'telephone not set' => 'Telephone not set.',
  'template' => 'Preset',
  'template warning' => 'You have two options to set up Qos. The First, you press the save button and generate the classes and rules on your own. The second, you press the preset button and classes and rules will be set up by a template.',
++'teovpn_fragment' => 'Fragmentsize',
  'test' => 'test',
  'test email could not be sent' => 'Could not sent Testemail',
  'test email was sent' => 'Testemail was send successfully',
  'updxlrtr weekly' => 'weekly',
  'updxlrtr year' => 'one year',
  'upgrade' => 'upgrade',
 -'uplink' => 'Uplink',
  'uplink speed' => 'Uplink speed (kbit/sec)',
  'uplink std class' => 'uplink standard class',
  'upload' => 'Upload',
  'valid root certificate already exists' => 'A valid root certificate already exists.',
  'valid till' => 'Valid till',
  'vci number' => 'VCI number:',
 +'vendor' => 'Vendor',
  'view log' => 'view log',
  'virtual address' => 'Virtual Address',
  'virtual private networking' => 'Virtual Private Networking',
  'vpn aggrmode' => 'IKE aggressive mode allowed. Avoid if possible (preshared key is transmitted in clear text)!',
  'vpn altname syntax' => 'SubjectAltName is a comma separated list of e-mail, dns, uri, rid and ip objects.<br />email:an email address. Syntax email:copy takes the email field from the cert to be used.<br />DNS:a valid domain name.<br />URI:any valid uri.<br />RID:registered object identifier.<br />IP:an IP address.<br />Note:charset is limited and case is significant.<br />Example:<br /><b>e-mail:</b>ipfire@foo.org<b>,email:</b>copy<b>,DNS:</b>www.ipfire.org<b>,IP:</b>127.0.0.1<b>,URI:</b>http://url/to/something',
  'vpn auth-dn' => 'Peer is identified by either IPV4_ADDR, FQDN, USER_FQDN or DER_ASN1_DN string in remote ID field',
 -'vpn configuration main' => 'VPN Configuration',
  'vpn delayed start' => 'Delay before launching VPN (seconds)',
  'vpn delayed start help' => 'If required, this delay can be used to allow dynamic DNS updates to propagate properly. 60 is a common value when RED is a dynamic IP.',
  'vpn incompatible use of defaultroute' => 'hostname=%defaultroute not allowed',