Florian Schaal
2013-11-24 03200f17fb330b13f2ca9a13057fb97c672cdf1d
interface/web/mail/mail_domain_dkim_create.php
@@ -27,11 +27,13 @@
 OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
 NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
 EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
 This script is invoked by interface/js/mail_domain_dkim.js
 to generate or show the DKIM Private-key and to show the Private-key.
 returns DKIM Private-Key and DKIM Public-Key
 */
/**
* This script is invoked by interface/js/mail_domain_dkim.js
* to generate or show the DKIM Private-key and to show the Private-key.
* returns DKIM Private-Key and DKIM Public-Key
*/
require_once '../../lib/config.inc.php';
@@ -45,7 +47,6 @@
header('Content-Type: text/xml; charset=utf-8');
header('Cache-Control: must-revalidate, pre-check=0, no-store, no-cache, max-age=0, post-check=0');
/**
 * This function fix PHP's messing up POST input containing characters space, dot,
@@ -64,7 +65,6 @@
   return $vars;
}
/**
 * This function formats the public-key
 * @param array $pubkey
@@ -76,32 +76,39 @@
   return $public_key;
}
function get_public_key($private_key) {
   require_once('../../lib/classes/validate_dkim.inc.php');
   $validate_dkim=new validate_dkim ();
   if($validate_dkim->validate_post('private',$private_key)) { /* validate the $_POST-value */
      exec('echo '.escapeshellarg($private_key).'|openssl rsa -pubout -outform PEM',$pubkey,$result);
      $public_key=pub_key($pubkey);
   } else {
      $public_key='invalid key';
   }
   return $public_key;
}
$_POST=getRealPOST();
switch ($_POST['action']) {
case 'create': /* create DKIM Private-key */
   exec('openssl rand -out /usr/local/ispconfig/server/temp/random-data.bin 4096', $output, $result);
   exec('openssl genrsa -rand /usr/local/ispconfig/server/temp/random-data.bin 1024', $privkey, $result);
   unlink("/usr/local/ispconfig/server/temp/random-data.bin");
   $private_key='';
   foreach($privkey as $values) $private_key=$private_key.$values."\n";
   if($validate_dkim->validate_post('private', $private_key)) { /* validate the $_POST-value */
      exec('echo '.escapeshellarg($private_key).'|openssl rsa -pubout -outform PEM', $pubkey, $result);
      $public_key=pub_key($pubkey);
   } else { $public_key='invalid key'; }
   case 'create': /* create DKIM Private-key */
      exec('openssl rand -out /usr/local/ispconfig/server/temp/random-data.bin 4096', $output, $result);
      exec('openssl genrsa -rand /usr/local/ispconfig/server/temp/random-data.bin 1024', $privkey, $result);
      unlink("/usr/local/ispconfig/server/temp/random-data.bin");
      foreach($privkey as $values) $private_key=$private_key.$values."\n";
   break;
case 'show': /* show the DNS-Record onLoad */
   $private_key=$_POST['pkey'];
   if($validate_dkim->validate_post('private', $private_key)) { /* validate the $_POST-value */
      /* get the public-key */
      exec('echo '.escapeshellarg($private_key).'|openssl rsa -pubout -outform PEM', $pubkey, $result);
      $public_key=pub_key($pubkey);
   } else { $public_key='invalid key'; }
   case 'show': /* show the DNS-Record onLoad */
      $private_key=$_POST['pkey'];
   break;
}
$public_key=get_public_key($private_key);
$dns_record=str_replace(array('-----BEGIN PUBLIC KEY-----','-----END PUBLIC KEY-----',"\r","\n"),'',$public_key);
echo "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n";
echo "<formatname>\n";
echo "<privatekey>".$private_key."</privatekey>\n";
echo "<publickey>".$public_key."</publickey>\n";
echo "<dns_record>v=DKIM1; t=s; p=".$dns_record."</dns_record>\n";
echo "</formatname>\n";
?>