Unterschiede

Hier werden die Unterschiede zwischen zwei Versionen angezeigt.

Link zu dieser Vergleichsansicht

Beide Seiten der vorigen Revision Vorhergehende Überarbeitung
Nächste Überarbeitung
Vorhergehende Überarbeitung
centos:mail_c7:pfadmin_1 [08.09.2014 16:30. ] – [SSL geschützten Apache vHost anlegen] djangocentos:mail_c7:pfadmin_1 [22.07.2019 15:11. ] (aktuell) – Externe Bearbeitung 127.0.0.1
Zeile 13: Zeile 13:
  
 Dann laden wir das **tar.gz**-Archiv auf unseren Webserver herunter. Dann laden wir das **tar.gz**-Archiv auf unseren Webserver herunter.
-   wget http://downloads.sourceforge.net/project/postfixadmin/postfixadmin/postfixadmin-2.91/postfixadmin-2.91.tar.gz+   wget http://downloads.sourceforge.net/project/postfixadmin/postfixadmin/postfixadmin-2.93/postfixadmin-2.93.tar.gz
  
 Im nächsten Schritt entpacken wir das Verzeichnis in den Webseiten-Speicherbereiches unseres [[centos:web_c7:start|Apache-Webservers]]. Im nächsten Schritt entpacken wir das Verzeichnis in den Webseiten-Speicherbereiches unseres [[centos:web_c7:start|Apache-Webservers]].
-   # tar -zxf postfixadmin-2.91.tar.gz -C /var/www/+   # tar -zxf postfixadmin-2.93.tar.gz -C /var/www/
  
 Die Datei und Nutzerrechte passen wir entsprechend an. Die Datei und Nutzerrechte passen wir entsprechend an.
-   # chown root.apache /var/www/postfixadmin-2.91/ -R+   # chown root.apache /var/www/postfixadmin-2.93/ -R
  
-===== vorbereitende Konfiguration =====+===== Installation/Upgrade Informationen ===== 
 +==== Installations-Dokument ====
 Wichtige Informationen zur Installation finden wir in der Datei **INSTALL.TXT**. Wichtige Informationen zur Installation finden wir in der Datei **INSTALL.TXT**.
-  # less /var/www/postfixadmin-2.91/INSTALL.TXT+   # less /var/www/postfixadmin-*/INSTALL.TXT
  
-<file /var/www/postfixadmin-2.91/INSTALL.TXT>#+<file /var/www/postfixadmin-*/INSTALL.TXT>
 +#
 # Postfix Admin # Postfix Admin
 # by Mischa Peters <mischa at high5 dot net> # by Mischa Peters <mischa at high5 dot net>
Zeile 66: Zeile 68:
 Postfix Admin archive (whatever the filename is): Postfix Admin archive (whatever the filename is):
  
-  $ tar -zxvf postfixadmin-2.2.0.tgz+  $ tar -zxvf postfixadmin-$version.tgz
  
  
Zeile 96: Zeile 98:
 ----------------------------------------------------- -----------------------------------------------------
  
-Edit the config.inc.php file - or - create config.local.php and add your settings there.+Create a config.local.php file for your local configuration: 
 + 
 +<?php 
 +$CONF['database_type'] = 'mysqli'; 
 +$CONF['database_user'] = 'postfix'; 
 +$CONF['database_password'] = 'postfixadmin'; 
 +$CONF['database_name'] = 'postfix'; 
 + 
 +$CONF['configured'] = true; 
 +?> 
 + 
 +See config.inc.php for all available config options and their default value. 
 + 
 +You can also edit config.inc.php instead of creating a config.local.php
 +but this will make updates harder and is therefore not recommended.
  
 The most important settings are those for your database server. The most important settings are those for your database server.
Zeile 109: Zeile 125:
  
  
-PostfixAdmin does not require write access to any files except the tempates_c +PostfixAdmin does not require write access to any files except the templates_c 
 directory (smarty cache). You can therefore leave the files owned as root (or directory (smarty cache). You can therefore leave the files owned as root (or
 another user); as long as the web server user (e.g. www-data) can read them, it another user); as long as the web server user (e.g. www-data) can read them, it
Zeile 172: Zeile 188:
 See config.inc.php - see xmlrpc_enabled key (defaults to off). See config.inc.php - see xmlrpc_enabled key (defaults to off).
  
-You'll need to install a copy of the Zend Framework within Postfixadmin (see header within xmlrpc.php)+You'll need to install a copy of the Zend Framework (version 1.12.x) within Postfixadmin 
 +or your PHP include_path (see header within xmlrpc.php)
 +NOTE: The XMLRPC interface is _not compatible_ with Zend Framework version 2.x.
 You'll need to enable the xmlrpc link (see config.inc.php) You'll need to enable the xmlrpc link (see config.inc.php)
  
Zeile 183: Zeile 201:
  
 There is also #postfixadmin on irc.freenode.net. There is also #postfixadmin on irc.freenode.net.
 +
 </file> </file>
  
 +==== Upgrade-Dokument ====
 +Wichtige Informationen zum Upgrade einer vorhandenen Installation finden wir in der Datei **UPGRADE.txt**.
 +   # less /var/www/postfixadmin-*/DOCUMENTS/UPGRADE.txt
 +  
 +<file /var/www/postfixadmin-*/DOCUMENTS/UPGRADE.txt>#
 +# Postfix Admin
 +# by Mischa Peters <mischa at high5 dot net>
 +# Copyright (c) 2002 - 2005 High5!
 +# Licensed under GPL for more info check GPL-LICENSE.TXT
 +#
 +
 +REQUIRED!!
 +----------
 +- You are using Postfix 2.0 or higher.
 +- You are using Apache 1.3.27 / Lighttpd 1.3.15 or higher.
 +- You are using PHP 5.1.2 or higher.
 +- You are using MySQL 3.23 or higher OR PostgreSQL v7.4+
 +
 +
 +READ THIS FIRST!
 +----------------
 +
 +This document describes upgrading from an older PostfixAdmin version
 +(>= v1.5x)
 +
 +It's recommend that you install Postfix Admin in a new folder and not
 +on-top of the old install!! (At the very least, make sure you have backups of 
 +the database and relevant filesystem!)
 +
 +When upgrading Postfix Admin, make sure you backup your database before
 +running upgrade.php.
 +
 +
 +1. Backup the Database
 +----------------------
 +When you install from a previous version make sure you backup your database
 +first. There are a lot of changes in the database structure since Postfix Admin
 +1.5.4.
 +
 +  $ mysqldump -a -u root -p > /tmp/postfixadmin-backup.sql
 +or
 +  $ pg_dump -ad -u postfix postfix > /tmp/postfixadmin-backup.sql
 +
 +
 +2. Unarchive new Postfix Admin
 +------------------------------
 +Make sure that you are in your WWW directory and then unarchive the
 +Postfix Admin archive (whatever the filename is):
 +
 +  $ tar -zxvf postfixadmin-X.X.tgz
 +
 +
 +3. Change permissions
 +----------------------
 +Since the database password is stored in the config.inc.php it's a good idea
 +to have change the permissions for Postfix Admin.
 +
 +  $ cd /usr/local/www/postfixadmin
 +  $ find -type f -print0 | xargs -0 chmod 640
 +  $ find -type f -print0 | xargs -0 chown root:www
 +
 +(the last command assumes your Apache is running with group "www")
 +
 +Since version 2.4 we use smarty templates. That means the templates_c directory
 +needs to be writeable for your webserver.
 +
 +  $ chown -R www-data templates_c/
 +
 +(if your Apache runs as user "www-data")
 +
 +
 +4. Configure
 +------------
 +Check the config.inc.php file. There you can specify settings that are
 +relevant to your setup.
 +
 +Comparing config.inc.php with your previous using "diff" might save you some
 +time.
 +
 +You can use a config.local.php file to contain your local settings. These will override any 
 +defined in config.inc.php - and save some time when upgrading to a new version of PostfixAdmin ;-)
 +
 +5. Run setup.php
 +----------------------------------------
 +
 +Access setup.php through a web browser.
 +
 +It will attempt to upgrade your database, and also allow you to create a superadmin user.
 +(In case the database upgrade fails, you can run setup.php?debug=1 to see the last executed query.)
 +
 +From version 2.3, you need to specify a setup_password in config.inc.php - 
 +setup.php should guide you through this process. If you do not have a setup_password, type one
 +into the form, and setup.php will echo out the hashed value (which needs to go into config.inc.php).
 +The setup_password removes the requirement for you to delete setup.php, and also closes a security hole.
 +
 +Since version 2.2 of Postfixadmin, setup.php can perform the needed database 
 +updates automatically .
 +
 +If you update from 2.1 or older, also create a superadmin account using setup.php.
 +
 +Note that admin/ has been merged into the main directory. Login with the
 +superadmin account to setup domains and domain admins.
 +
 +6. Upgrade your postfix config
 +------------------------------
 +
 +Since version 2.3, PostfixAdmin supports alias domains ($CONF['alias_domain']).
 +If you want to use them, you have to add some queries to your postfix config -
 +see POSTFIX_CONF for details.
 +
 +
 +7. Done
 +-------
 +This is all that is needed. Fire up your browser and go to the site that you
 +specified to host Postfix Admin.
 +
 +</file>
 ==== mySQL Datenbank und -user anlegen ==== ==== mySQL Datenbank und -user anlegen ====
 Wie Eingangs erwähnt, nutzen wir für die Verwaltung unserer Maildomänen und deren Nutzerkonten sowie Aliasen eine [[centos:mysql|mySQL-Datenbank]].  Wie Eingangs erwähnt, nutzen wir für die Verwaltung unserer Maildomänen und deren Nutzerkonten sowie Aliasen eine [[centos:mysql|mySQL-Datenbank]]. 
Zeile 236: Zeile 372:
    # vim /etc/httpd/conf.d/vhost_443_postfixadmin.conf    # vim /etc/httpd/conf.d/vhost_443_postfixadmin.conf
  
-<file http /etc/httpd/conf.d/vhost_443_postfixadmin.conf>#+<file apache /etc/httpd/conf.d/vhost_443_postfixadmin.conf>#
 # postfixadmin.nausch.org # postfixadmin.nausch.org
 #                                                                                                                                                                                 #                                                                                                                                                                                
Zeile 291: Zeile 427:
    # systemctl reload httpd.service    # systemctl reload httpd.service
  
-Wollen wir den Restart kontrollieren, fragen wir den Status des Webservers ab.+Wollen wir den Reload kontrollieren, fragen wir den Status des Webservers ab.
    # systemctl status httpd.service    # systemctl status httpd.service
  
Zeile 312: Zeile 448:
 Sep 08 18:25:25 vml000097.dmz.nausch.org systemd[1]: Reloaded The Apache HTTP Server. Sep 08 18:25:25 vml000097.dmz.nausch.org systemd[1]: Reloaded The Apache HTTP Server.
 </code> </code>
 +
 +===== Anwendungs-Konfiguration =====
 +Die Konfiguration von PostfixAdmin erfolgt über die Konfigurationsdatei **config.inc.php**. Rufen wir jetzt schon die WEB-GUI auf, erhalten wir "nur" Informationen zur weiteren Installation und Querverweise angezeigt.
 +
 +{{ :centos:mail_c7:postfixadmin_01.png?direct&850 |Bild: Willkommensbildschirm von postfixadmin}}
 +
 +Diese Datei versehen wir nun mit den entsprechenden Daten unserer Produktionsumgebung.
 +
 +<WRAP center round alert>
 +**WICHTIG:** \\
 +Die vorerst wichtigsten Daten sind neben der Datenbank-Definitionen, der Parameter ''$CONF['configured'] = true;'' sowie die Definition der Art und Weise, wie die Passwörter in der Datenbank gespeichert werden sollen. ''$CONF['encrypt'] = 'cleartext';'' Diese Festlegung muss vor dem Anlegen des superadmin accounts erfolgen. Bei unbedachten Änderungen nachher, ist unter Umständen die Webanwendung mit den gewohnten Zugangsdaten nicht mehr erreichbar!
 +</WRAP>
 +
 +   # vim /var/www/postfixadmin-2.91/config.inc.php
 +
 +Die Änderungen in der Datei sind im nachfolgendem Beispiel mit dem Namen des Admins und dem Datum versehen.
 +<file php /var/www/postfixadmin-2.91/config.inc.php><?php
 +/** 
 + * Postfix Admin 
 + 
 + * LICENSE 
 + * This source file is subject to the GPL license that is bundled with  
 + * this package in the file LICENSE.TXT. 
 + 
 + * Further details on the project are available at http://postfixadmin.sf.net 
 + 
 + * @version $Id: config.inc.php 1613 2013-12-26 14:35:02Z christian_boltz $ 
 + * @license GNU GPL v2 or later. 
 + 
 + * File: config.inc.php
 + * Contains configuration options.
 + */
 +
 +/*****************************************************************
 +  !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 
 + * You have to set $CONF['configured'] = true; before the
 + * application will run!
 + * Doing this implies you have changed this file as required.
 + * i.e. configuring database etc; specifying setup.php password etc.
 + */
 +// Django : 2014-09-07
 +// default: $CONF['configured'] = false;
 +$CONF['configured'] = true;
 +
 +// In order to setup Postfixadmin, you MUST specify a hashed password here.
 +// To create the hash, visit setup.php in a browser and type a password into the field,
 +// on submission it will be echoed out to you as a hashed value.
 +$CONF['setup_password'] = 'changeme';
 +
 +// Language config
 +// Language files are located in './languages', change as required..
 +// Django : 2014-09-07
 +// default: $CONF['default_language'] = 'en';
 +$CONF['default_language'] = 'de';
 +
 +// Hook to override or add translations in $PALANG
 +// Set to the function name you want to use as hook function (see language_hook example function below)
 +$CONF['language_hook'] = '';
 +
 +/*
 +    language_hook example function
 + 
 +    Called if $CONF['language_hook'] == '<name_of_the_function>'
 +    Allows to add or override $PALANG interface texts.
 +
 +    If you add new texts, please always prefix them with 'x_' (for example 
 +    $PALANG['x_mytext'] = 'foo') to avoid they clash with texts that might be
 +    added to languages/*.lang in future versions of PostfixAdmin.
 +
 +    Please also make sure that all your added texts are included in all
 +    sections - that includes all 'case "XY":' sections and the 'default:'
 +    section (for users that don't have any of the languages specified
 +    in the 'case "XY":' section). 
 +    Usually the 'default:' section should contain english text.
 +
 +    If you modify an existing text/translation, please consider to report it
 +    to the bugtracker on http://sf.net/projects/postfixadmin so that all users
 +    can benefit from the corrected text/translation.
 +
 +    Returns: modified $PALANG array
 +*/
 +/*
 +function language_hook($PALANG, $language) {
 +    switch ($language) {
 +        case "de":
 +            $PALANG['x_whatever'] = 'foo';
 +            break;
 +        case "fr":
 +            $PALANG['x_whatever'] = 'bar';
 +            break;
 +        default:
 +            $PALANG['x_whatever'] = 'foobar';
 +    }
 +
 +    return $PALANG;
 +}
 +*/
 +
 +// Database Config
 +// mysql = MySQL 3.23 and 4.0, 4.1 or 5
 +// mysqli = MySQL 4.1+ 
 +// pgsql = PostgreSQL
 +// Django : 2014-09-07
 +// default: $CONF['database_type'] = 'mysqli';
 +//          $CONF['database_host'] = 'localhost';
 +//          $CONF['database_user'] = 'postfix';
 +//          $CONF['database_password'] = 'postfixadmin';
 +//          $CONF['database_name'] = 'postfix';
 +$CONF['database_type'] = 'mysqli';
 +$CONF['database_host'] = 'mysql.dmz.nausch.org';
 +$CONF['database_user'] = 'pfadmin_user';
 +$CONF['database_password'] = 'rbgsDK39DeM2b2btx9iMHfzd';
 +$CONF['database_name'] = 'postfix';
 +
 +// If you need to specify a different port for a MYSQL database connection, use e.g.
 +//   $CONF['database_host'] = '172.30.33.66:3308';
 +// If you need to specify a different port for POSTGRESQL database connection
 +//   uncomment and change the following
 +// $CONF['database_port'] = '5432';
 +
 +// Here, if you need, you can customize table names.
 +$CONF['database_prefix'] = '';
 +$CONF['database_tables'] = array (
 +    'admin' => 'admin',
 +    'alias' => 'alias',
 +    'alias_domain' => 'alias_domain',
 +    'config' => 'config',
 +    'domain' => 'domain',
 +    'domain_admins' => 'domain_admins',
 +    'fetchmail' => 'fetchmail',
 +    'log' => 'log',
 +    'mailbox' => 'mailbox',
 +    'vacation' => 'vacation',
 +    'vacation_notification' => 'vacation_notification',
 +    'quota' => 'quota',
 +        'quota2' => 'quota2',
 +);
 +
 +// Site Admin
 +// Define the Site Admin's email address below.
 +// This will be used to send emails from to create mailboxes and
 +// from Send Email / Broadcast message pages.
 +// Leave blank to send email from the logged-in Admin's Email address.
 +// Django : 2014-09-07
 +// default: $CONF['admin_email'] = '';
 +$CONF['admin_email'] = 'postmaster@nausch.org';
 +
 +// Mail Server
 +// Hostname (FQDN) of your mail server.
 +// This is used to send email to Postfix in order to create mailboxes.
 +// Django : 2014-09-07
 +// default: $CONF['smtp_server'] = 'localhost';
 +$CONF['smtp_server'] = 'smtp.dmz.nausch.org';
 +$CONF['smtp_port'] = '25';
 +
 +// Encrypt
 +// In what way do you want the passwords to be crypted?
 +// md5crypt = internal postfix admin md5
 +// md5 = md5 sum of the password
 +// system = whatever you have set as your PHP system default
 +// cleartext = clear text passwords (ouch!)
 +// mysql_encrypt = useful for PAM integration
 +// authlib = support for courier-authlib style passwords
 +// dovecot:CRYPT-METHOD = use dovecotpw -s 'CRYPT-METHOD'. Example: dovecot:CRAM-MD5
 +//   (WARNING: don't use dovecot:* methods that include the username in the hash - you won't be able to login to PostfixAdmin in this case)
 +// Django : 2014-09-07
 +// default: $CONF['encrypt'] = 'md5crypt';
 +// nix ouch! Da wir später CRAM-Verfahren einsetzen wollen, werden die Passwörter in Klartext gespeichert! Denn die Nutzerkonten müssen nicht
 +// vor dem angeblichen bösen Admin verborgen werden, sondern vor den bösen Buben im Internet, wie NSA, BND und GCHQ, welche unsere Grund- und
 +// Freiheitsrechte bedrohen und natürlich auch all die anderen Verbrecher und Bösewichter!
 +$CONF['encrypt'] = 'cleartext';
 +
 +// In what flavor should courier-authlib style passwords be encrypted?
 +// md5 = {md5} + base64 encoded md5 hash
 +// md5raw = {md5raw} + plain encoded md5 hash
 +// SHA = {SHA} + base64-encoded sha1 hash
 +// crypt = {crypt} + Standard UNIX DES-encrypted with 2-character salt
 +$CONF['authlib_default_flavor'] = 'md5raw';
 +
 +// If you use the dovecot encryption method: where is the dovecotpw binary located?
 +// for dovecot 1.x
 +// $CONF['dovecotpw'] = "/usr/sbin/dovecotpw";
 +// for dovecot 2.x (dovecot 2.0.0 - 2.0.7 is not supported!)
 +$CONF['dovecotpw'] = "/usr/sbin/doveadm pw";
 +
 +// Password validation
 +// New/changed passwords will be validated using all regular expressions in the array.
 +// If a password doesn't match one of the regular expressions, the corresponding
 +// error message from $PALANG (see languages/*) will be displayed.
 +// See http://de3.php.net/manual/en/reference.pcre.pattern.syntax.php for details
 +// about the regular expression syntax.
 +// If you need custom error messages, you can add them using $CONF['language_hook'].
 +// If a $PALANG text contains a %s, you can add its value after the $PALANG key
 +// (separated with a space).
 +$CONF['password_validation'] = array(
 +#    '/regular expression/' => '$PALANG key (optional: + parameter)',
 +// Django : 2014-09-07
 +// default: '/.{5}/'        => 'password_too_short 5',      # minimum length 5 characters
 +    '/.{5}/'                => 'password_too_short 5',      # minimum length 8 characters
 +    '/([a-zA-Z].*){3}/'     => 'password_no_characters 3',  # must contain at least 3 characters
 +    '/([0-9].*){2}/'        => 'password_no_digits 2',      # must contain at least 2 digits
 +);
 +
 +// Generate Password
 +// Generate a random password for a mailbox or admin and display it.
 +// If you want to automagically generate passwords set this to 'YES'.
 +// Django : 2014-09-07
 +// default: $CONF['generate_password'] = 'NO';
 +$CONF['generate_password'] = 'YES';
 +
 +// Show Password
 +// Always show password after adding a mailbox or admin.
 +// If you want to always see what password was set set this to 'YES'.
 +$CONF['show_password'] = 'NO';
 +
 +// Page Size
 +// Set the number of entries that you would like to see
 +// in one page.
 +// Django : 2014-05-22
 +// default: $CONF['page_size'] = '10';
 +$CONF['page_size'] = '50';
 +
 +// Default Aliases
 +// The default aliases that need to be created for all domains.
 +$CONF['default_aliases'] = array (
 +// Django : 2014-05-22
 +// default: 'abuse' => 'abuse@change-this-to-your.domain.tld',
 +//          'hostmaster' => 'hostmaster@change-this-to-your.domain.tld',
 +//          'postmaster' => 'postmaster@change-this-to-your.domain.tld',
 +//              'webmaster' => 'webmaster@change-this-to-your.domain.tld'
 +    'abuse' => 'abuse@nausch.org',
 +    'hostmaster' => 'hostmaster@nausch.org',
 +    'postmaster' => 'postmaster@nausch.org',
 +    'webmaster' => 'webmaster@nausch.org'
 +);
 +
 +// Mailboxes
 +// If you want to store the mailboxes per domain set this to 'YES'.
 +// Examples:
 +//   YES: /usr/local/virtual/domain.tld/username@domain.tld
 +//   NO:  /usr/local/virtual/username@domain.tld
 +$CONF['domain_path'] = 'YES';
 +// If you don't want to have the domain in your mailbox set this to 'NO'.
 +// Examples: 
 +//   YES: /usr/local/virtual/domain.tld/username@domain.tld
 +//   NO:  /usr/local/virtual/domain.tld/username
 +// Note: If $CONF['domain_path'] is set to NO, this setting will be forced to YES.
 +$CONF['domain_in_mailbox'] = 'NO';
 +// If you want to define your own function to generate a maildir path set this to the name of the function.
 +// Notes: 
 +//   - this configuration directive will override both domain_path and domain_in_mailbox
 +//   - the maildir_name_hook() function example is present below, commented out
 +//   - if the function does not exist the program will default to the above domain_path and domain_in_mailbox settings
 +$CONF['maildir_name_hook'] = 'NO';
 +
 +/*
 +    maildir_name_hook example function
 + 
 +    Called when creating a mailbox if $CONF['maildir_name_hook'] == '<name_of_the_function>'
 +    - allows for customized maildir paths determined by a custom function
 +    - the example below will prepend a single-character directory to the
 +      beginning of the maildir, splitting domains more or less evenly over
 +      36 directories for improved filesystem performance with large numbers
 +      of domains.
 +
 +    Returns: maildir path
 +    ie. I/example.com/user/
 +*/
 +/*
 +function maildir_name_hook($domain, $user) {
 +    $chars = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
 +
 +    $dir_index = hexdec(substr(md5($domain), 28)) % strlen($chars);
 +    $dir = substr($chars, $dir_index, 1);
 +    return sprintf("%s/%s/%s/", $dir, $domain, $user);
 +}
 +*/
 +
 +/*  
 +    *_struct_hook - change, add or remove fields
 +
 +    If you need additional fields or want to change or remove existing fields,
 +    you can write a hook function to modify $struct in the *Handler classes. 
 +
 +    The edit form will automatically be updated according to the modified
 +    $struct. The list page is not yet updated automatically.
 +
 +    You can define one hook function per class, named like the primary database
 +    table of that class.
 +    The hook function is called with $struct as parameter and must return the
 +    modified $struct. 
 +
 +    Note: Adding a field to $struct adds the handling of this field in
 +    PostfixAdmin, but it does not create it in the database. You have to do
 +    that yourself. 
 +    Please follow the naming policy for custom database fields and tables on
 +    http://sourceforge.net/apps/mediawiki/postfixadmin/index.php?title=Custom_fields
 +    to avoid clashes with future versions of PostfixAdmin.
 +
 +    See initStruct() in the *Handler class for the default $struct.
 +    See pacol() in functions.inc.php for the available flags on each column.
 +    
 +    Example:
 +
 +    function x_struct_admin_modify($struct) {
 +        $struct['superadmin']['editable'] = 0;          # make the 'superadmin' flag read-only
 +        $struct['superadmin']['display_in_form'] = 0;   # don't display the 'superadmin' flag in edit form
 +        $struct['x_newfield'] = pacol( [...] );        # additional field 'x_newfield'
 +        return $struct; # important!
 +    }
 +    $CONF['admin_struct_hook'] = 'x_struct_admin_modify';
 +*/
 +$CONF['admin_struct_hook'         = '';
 +$CONF['domain_struct_hook'        = '';
 +$CONF['alias_struct_hook'         = '';
 +$CONF['mailbox_struct_hook'       = '';
 +$CONF['alias_domain_struct_hook'  = '';
 +
 +
 +// Default Domain Values
 +// Specify your default values below. Quota in MB.
 +// Django : 2014-09-07
 +// default: $CONF['aliases'] = '10';
 +//          $CONF['mailboxes'] = '10';
 +//          $CONF['maxquota'] = '10';
 +//          $CONF['domain_quota_default'] = '2048';
 +$CONF['aliases'] = '100';
 +$CONF['mailboxes'] = '100';
 +$CONF['maxquota'] = '100';
 +$CONF['domain_quota_default'] = '20480';
 +
 +// Quota
 +// When you want to enforce quota for your mailbox users set this to 'YES'.
 +$CONF['quota'] = 'NO';
 +// If you want to enforce domain-level quotas set this to 'YES'.
 +$CONF['domain_quota'] = 'YES';
 +// You can either use '1024000' or '1048576'
 +$CONF['quota_multiplier'] = '1024000';
 +
 +// Transport
 +// If you want to define additional transport options for a domain set this to 'YES'.
 +// Read the transport file of the Postfix documentation.
 +$CONF['transport'] = 'NO';
 +// Transport options
 +// If you want to define additional transport options put them in array below.
 +$CONF['transport_options'] = array (
 +    'virtual',  // for virtual accounts
 +    'local',    // for system accounts
 +    'relay'     // for backup mx
 +);
 +// Transport default
 +// You should define default transport. It must be in array above.
 +$CONF['transport_default'] = 'virtual';
 +
 +
 +//
 +//
 +// Virtual Vacation Stuff
 +//
 +//
 +
 +// If you want to use virtual vacation for you mailbox users set this to 'YES'.
 +// NOTE: Make sure that you install the vacation module. (See VIRTUAL-VACATION/)
 +$CONF['vacation'] = 'NO';
 +
 +// This is the autoreply domain that you will need to set in your Postfix
 +// transport maps to handle virtual vacations. It does not need to be a
 +// real domain (i.e. you don't need to setup DNS for it).
 +// Django : 2014-09-07
 +// default: $CONF['vacation_domain'] = 'autoreply.change-this-to-your.domain.tld';
 +$CONF['vacation_domain'] = 'autoreply.nausch.org';
 +
 +// Vacation Control
 +// If you want users to take control of vacation set this to 'YES'.
 +// Django : 2014-09-07
 +// default: $CONF['vacation_control'] ='YES';
 +$CONF['vacation_control'] ='NO';
 +
 +// Vacation Control for admins
 +// Set to 'YES' if your domain admins should be able to edit user vacation.
 +$CONF['vacation_control_admin'] = 'YES';
 +
 +// ReplyType options
 +// If you want to define additional reply options put them in array below.
 +// The array has the format   seconds between replies => $PALANG text
 +// Special values for seconds are: 
 +// 0 => only reply to the first mail while on vacation 
 +// 1 => reply on every mail
 +$CONF['vacation_choice_of_reply'] = array (
 +   0 => 'reply_once',        // Sends only Once the message during Out of Office
 +   # considered annoying - only send a reply on every mail if you really need it
 +   # 1 => 'reply_every_mail',       // Reply on every email
 +   60*60 *24*7 => 'reply_once_per_week'        // Reply if last autoreply was at least a week ago
 +);
 +
 +//
 +// End Vacation Stuff.
 +//
 +
 +// Users Control for Domain Admin
 +// Set to "Yes" if your domain admins schould be able to  edit  field userscontrole in  table domain
 +// Userscontrol is edited in admin_create-domain.tpl and admin_edit-domain.tpl
 +// Userscontrol is default set  to  on when creating a domain
 +$CONF['users_domain_controle'] = 'YES';
 +
 +
 +// Alias Control
 +// Postfix Admin inserts an alias in the alias table for every mailbox it creates.
 +// The reason for this is that when you want catch-all and normal mailboxes
 +// to work you need to have the mailbox replicated in the alias table.
 +// If you want to take control of these aliases as well set this to 'YES'.
 +
 +// Alias control for superadmins
 +$CONF['alias_control'] = 'YES';
 +
 +// Alias Control for domain admins
 +$CONF['alias_control_admin'] = 'YES';
 +
 +// Special Alias Control
 +// Set to 'NO' if your domain admins shouldn't be able to edit the default aliases
 +// as defined in $CONF['default_aliases']
 +$CONF['special_alias_control'] = 'NO';
 +
 +// Alias Goto Field Limit
 +// Set the max number of entries that you would like to see
 +// in one 'goto' field in overview, the rest will be hidden and "[and X more...]" will be added.
 +// '0' means no limits.
 +$CONF['alias_goto_limit'] = '0';
 +
 +// Alias Domains
 +// Alias domains allow to "mirror" aliases and mailboxes to another domain. This makes 
 +// configuration easier if you need the same set of aliases on multiple domains, but
 +// also requires postfix to do more database queries.
 +// Note: If you update from 2.2.x or earlier, you will have to update your postfix configuration.
 +// Set to 'NO' to disable alias domains.
 +$CONF['alias_domain'] = 'YES';
 +
 +// Backup
 +// If you don't want backup tab set this to 'NO';
 +$CONF['backup'] = 'NO';
 +
 +// Send Mail
 +// If you don't want sendmail tab set this to 'NO';
 +$CONF['sendmail'] = 'YES';
 +
 +// Logging
 +// If you don't want logging set this to 'NO';
 +$CONF['logging'] = 'YES';
 +
 +// Fetchmail
 +// If you don't want fetchmail tab set this to 'NO';
 +// Django : 2014-09-07
 +// default: $CONF['fetchmail'] = 'NO';
 +$CONF['fetchmail'] = 'YES';
 +
 +// fetchmail_extra_options allows users to specify any fetchmail options and any MDA
 +// (it will even accept 'rm -rf /' as MDA!)
 +// This should be set to NO, except if you *really* trust *all* your users.
 +$CONF['fetchmail_extra_options'] = 'NO';
 +
 +// Header
 +$CONF['show_header_text'] = 'NO';
 +$CONF['header_text'] = ':: Postfix Admin ::';
 +
 +// Footer
 +// Below information will be on all pages.
 +// If you don't want the footer information to appear set this to 'NO'.
 +$CONF['show_footer_text'] = 'YES';
 +// Django : 2014-09-07
 +// default: $CONF['footer_text'] = 'Return to change-this-to-your.domain.tld';
 +//          $CONF['footer_link'] = 'http://change-this-to-your.domain.tld';
 +$CONF['footer_text'] = 'nausch.org';
 +$CONF['footer_link'] = 'http://nausch.org';
 +
 +// MOTD ("Motto of the day")
 +// You can display a MOTD below the menu on all pages.
 +// This can be configured seperately for users, domain admins and superadmins
 +$CONF['motd_user'] = '';
 +$CONF['motd_admin'] = '';
 +$CONF['motd_superadmin'] = '';
 +
 +// Welcome Message
 +// This message is send to every newly created mailbox.
 +// Change the text between EOM.
 +// Django : 2014-09-07
 +// default; $CONF['welcome_text'] = <<<EOM
 +//          Hi,
 +//
 +//          Welcome to your new account.
 +//          EOM;
 +$CONF['welcome_text'] = <<<EOM
 +Griasde!
 +
 +Herzlich Willkommen auf dem Mailserver von nausch.org!
 +
 +Wenn Du Probleme, Fragen und/oder Anregungen zu diesem Dienst hast, dann schreib
 +einfach eine eMail an django@nausch.org.
 +
 +Den Webmaildienst erreichst du unter dieser Adresse:
 +https://buero.nausch.org
 +
 +Viel Spass und viele Gruesse
 +
 +BOfH aka Django
 +Bastard Operator from Hell
 +http://dokuwiki.nausch.org
 +EOM;
 +
 +// When creating mailboxes or aliases, check that the domain-part of the
 +// address is legal by performing a name server look-up.
 +$CONF['emailcheck_resolve_domain']='YES';
 +
 +
 +// Optional:
 +// Analyze alias gotos and display a colored block in the first column
 +// indicating if an alias or mailbox appears to deliver to a non-existent
 +// account.  Also, display indications, for POP/IMAP mailboxes and
 +// for custom destinations (such as mailboxes that forward to a UNIX shell
 +// account or mail that is sent to a MS exchange server, or any other
 +// domain or subdomain you use)
 +// See http://www.w3schools.com/html/html_colornames.asp for a list of
 +// color names available on most browsers
 +
 +//set to YES to enable this feature
 +$CONF['show_status']='YES';
 +//display a guide to what these colors mean
 +$CONF['show_status_key']='YES';
 +// 'show_status_text' will be displayed with the background colors
 +// associated with each status, you can customize it here
 +$CONF['show_status_text']='&nbsp;&nbsp;';
 +// show_undeliverable is useful if most accounts are delivered to this
 +// postfix system.  If many aliases and mailboxes are forwarded
 +// elsewhere, you will probably want to disable this.
 +$CONF['show_undeliverable']='YES';
 +$CONF['show_undeliverable_color']='tomato';
 +// mails to these domains will never be flagged as undeliverable
 +$CONF['show_undeliverable_exceptions']=array("unixmail.domain.ext","exchangeserver.domain.ext");
 +$CONF['show_popimap']='YES';
 +$CONF['show_popimap_color']='darkgrey';
 +// you can assign special colors to some domains. To do this,
 +// - add the domain to show_custom_domains
 +// - add the corresponding color to show_custom_colors
 +$CONF['show_custom_domains']=array("subdomain.domain.ext","domain2.ext");
 +$CONF['show_custom_colors']=array("lightgreen","lightblue");
 +// If you use a recipient_delimiter in your postfix config, you can also honor it when aliases are checked.
 +// Example: $CONF['recipient_delimiter'] = "+";
 +// Set to "" to disable this check.
 +$CONF['recipient_delimiter'] = "";
 +
 +// Optional:
 +// Script to run after creation of mailboxes.
 +// Note that this may fail if PHP is run in "safe mode", or if
 +// operating system features (such as SELinux) or limitations
 +// prevent the web-server from executing external scripts.
 +// Parameters: (1) username (2) domain (3) maildir (4) quota
 +// $CONF['mailbox_postcreation_script']='sudo -u courier /usr/local/bin/postfixadmin-mailbox-postcreation.sh';
 +$CONF['mailbox_postcreation_script'] = '';
 +
 +// Optional:
 +// Script to run after alteration of mailboxes.
 +// Note that this may fail if PHP is run in "safe mode", or if
 +// operating system features (such as SELinux) or limitations
 +// prevent the web-server from executing external scripts.
 +// Parameters: (1) username (2) domain (3) maildir (4) quota
 +// $CONF['mailbox_postedit_script']='sudo -u courier /usr/local/bin/postfixadmin-mailbox-postedit.sh';
 +$CONF['mailbox_postedit_script'] = '';
 +
 +// Optional:
 +// Script to run after deletion of mailboxes.
 +// Note that this may fail if PHP is run in "safe mode", or if
 +// operating system features (such as SELinux) or limitations
 +// prevent the web-server from executing external scripts.
 +// Parameters: (1) username (2) domain
 +// $CONF['mailbox_postdeletion_script']='sudo -u courier /usr/local/bin/postfixadmin-mailbox-postdeletion.sh';
 +$CONF['mailbox_postdeletion_script'] = '';
 +
 +// Optional:
 +// Script to run after creation of domains.
 +// Note that this may fail if PHP is run in "safe mode", or if
 +// operating system features (such as SELinux) or limitations
 +// prevent the web-server from executing external scripts.
 +// Parameters: (1) domain
 +//$CONF['domain_postcreation_script']='sudo -u courier /usr/local/bin/postfixadmin-domain-postcreation.sh';
 +$CONF['domain_postcreation_script'] = '';
 +
 +// Optional:
 +// Script to run after deletion of domains.
 +// Note that this may fail if PHP is run in "safe mode", or if
 +// operating system features (such as SELinux) or limitations
 +// prevent the web-server from executing external scripts.
 +// Parameters: (1) domain
 +// $CONF['domain_postdeletion_script']='sudo -u courier /usr/local/bin/postfixadmin-domain-postdeletion.sh';
 +$CONF['domain_postdeletion_script'] = '';
 +
 +// Optional:
 +// Sub-folders which should automatically be created for new users.
 +// The sub-folders will also be subscribed to automatically.
 +// Will only work with IMAP server which implement sub-folders.
 +// Will not work with POP3.
 +// If you define create_mailbox_subdirs, then the
 +// create_mailbox_subdirs_host must also be defined.
 +//
 +// $CONF['create_mailbox_subdirs']=array('Spam');
 +$CONF['create_mailbox_subdirs'] = array();
 +$CONF['create_mailbox_subdirs_host']='localhost';
 +//
 +// Specify '' for Dovecot and 'INBOX.' for Courier.
 +// Django : 2014-09-07
 +// default: $CONF['create_mailbox_subdirs_prefix']='INBOX.';
 +$CONF['create_mailbox_subdirs_prefix']='';
 +
 +// Optional:
 +// Show used quotas from Dovecot dictionary backend in virtual
 +// mailbox listing.
 +// See: DOCUMENTATION/DOVECOT.txt
 +//      http://wiki.dovecot.org/Quota/Dict
 +//
 +// Django : 2014-09-07
 +// default: $CONF['used_quotas'] = 'NO';
 +$CONF['used_quotas'] = 'YES';
 +
 +// if you use dovecot >= 1.2, set this to yes.
 +// Note about dovecot config: table "quota" is for 1.0 & 1.1, table "quota2" is for dovecot 1.2 and newer
 +$CONF['new_quota_table'] = 'YES';
 +
 +//
 +// Normally, the TCP port number does not have to be specified.
 +// $CONF['create_mailbox_subdirs_hostport']=143;
 +//
 +// If you have trouble connecting to the IMAP-server, then specify
 +// a value for $CONF['create_mailbox_subdirs_hostoptions']. These
 +// are some examples to experiment with:
 +// $CONF['create_mailbox_subdirs_hostoptions']=array('notls');
 +// $CONF['create_mailbox_subdirs_hostoptions']=array('novalidate-cert','norsh');
 +// See also the "Optional flags for names" table at
 +// http://www.php.net/manual/en/function.imap-open.php
 +$CONF['create_mailbox_subdirs_hostoptions'] = array('');
 +
 +
 +// Theme Config
 +// Specify your own logo and CSS file
 +$CONF['theme_logo'] = 'images/logo-default.png';
 +$CONF['theme_css'] = 'css/default.css';
 +// If you want to customize some styles without editing the $CONF['theme_css'] file,
 +// you can add a custom CSS file. It will be included after $CONF['theme_css'].
 +$CONF['theme_custom_css'] = '';
 +
 +// XMLRPC Interface.
 +// This should be only of use if you wish to use e.g the
 +// Postfixadmin-Squirrelmail package
 +//  change to boolean true to enable xmlrpc
 +$CONF['xmlrpc_enabled'] = false;
 +
 +// If you want to keep most settings at default values and/or want to ensure 
 +// that future updates work without problems, you can use a separate config 
 +// file (config.local.php) instead of editing this file and override some
 +// settings there.
 +if (file_exists(dirname(__FILE__) . '/config.local.php')) {
 +    include(dirname(__FILE__) . '/config.local.php');
 +}
 +
 +//
 +// END OF CONFIG FILE
 +//
 +/* vim: set expandtab softtabstop=4 tabstop=4 shiftwidth=4: */
 +</file>
 +
 +===== Initialisierung =====
 +Die Erstinitialisierung nehmen wir nun über unserem Browser vor.
 +   $ firefox http://postfixadmin.nausch.org/setup.php
 +
 +Als erstes erzeugen wir den Passworthash unseres Konfigurationspasswortes.
 +
 +{{ :centos:mail_c7:postfixadmin_02.png?direct&850 |Bild: Postfixadmin - Passworthash des Konfigurationspasswortes erzeugen }}
 +
 +Nachdem wir das Passwort 2x eingegeben haben klicken wir auf die Schaltfläche **[Generate password hash]**.
 +
 +{{ :centos:mail_c7:postfixadmin_03.png?direct&850 |Bild: Postfixadmin - Passworthash des Konfigurationspasswortes erzeugen }}
 +
 +Diesen tragen wir in die Konfigurationsdatei **config.inc.php** ein.
 +   # vim /var/www/postfixadmin-2.*/config.inc.php
 +<code php>...
 +
 +// In order to setup Postfixadmin, you MUST specify a hashed password here.
 +// To create the hash, visit setup.php in a browser and type a password into the field,
 +// on submission it will be echoed out to you as a hashed value.
 +// Django : 2014-09-07
 +// default: $CONF['setup_password'] = 'changeme';
 +$CONF['setup_password'] = 'f2b4da227352f36822a7d2e59b656822:7e86954d0fae508f7f808b8c868854eaabd6822d';
 +
 +...
 +</code>
 +Anschließend rufen wir die Konfigurationsseite nochmals auf und legen unseren Superadmin- aka BOfH((**B**astard **O**perator **f**rom **H**ell))-Account an.
 +   $ firefox http://postfixadmin.nausch.org/setup.php
 +
 +{{ :centos:mail_c7:postfixadmin_03.png?direct&850 |Bild: Postfixadmin - Superadmin-Account anlegen }}
 +
 +Nach Eingabe der betreffenden Daten klicken wir die Schaltfläche **[Add Admin]**.
 +
 +{{ :centos:mail_c7:postfixadmin_04.png?direct&850 |Bild: Postfixadmin - Superadmin-Account anlegen}}
 +
 +Wir haben nun die Konfiguration von PostfixAdmin erfolgreich abgeschlossen und können nun die Loginseite unserer WEB-GUI aufrufen.
 +      $ firefox http://postfixadmin.nausch.org
 +
 +{{ :centos:mail_c7:postfixadmin_05.png?direct&850 |Bild: Postfixadmin - Admin-Zugang}}
 +
 +===== Postfix Konfiguration ====
 +==== virtual_alias files in Verbindung mit postfixadmin ====
 +Damit unser Postfix-Mailserver auch Kenntnis von den Domänen und Konten in der MariaDB erhält müssen wir unsere Postfix-Konfigurationsdatei //**/etc/postfix/main.cf**// um folgenden Block erweitern.
 +
 +<code># Django : 2014-10-15 - virtuelle Mail-Domains und Mailboxen mit Anbindung an
 +#          das mySQL-Datenbankbackend (Verwaltung mit Hilfe von postfixadmin)
 +# default: virtual_mailbox_domains = $virtual_mailbox_maps
 +#          virtual_alias_maps = $virtual_maps
 +#          virtual_mailbox_maps =
 +virtual_mailbox_domains = proxy:mysql:/etc/postfix/mysql_virtual_domains_maps.cf
 + 
 +virtual_alias_maps =      proxy:mysql:/etc/postfix/mysql_virtual_alias_maps.cf
 +                          proxy:mysql:/etc/postfix/mysql_virtual_alias_domain_maps.cf
 +                          proxy:mysql:/etc/postfix/mysql_virtual_alias_domain_catchall_maps.cf
 + 
 +virtual_mailbox_maps =    proxy:mysql:/etc/postfix/mysql_virtual_mailbox_maps.cf
 +                          proxy:mysql:/etc/postfix/mysql_virtual_alias_domain_mailbox_maps.cf</code>
 +
 +Die zugehörigen Dateien, haben dann folgende Inhalte.
 +=== mysql_virtual_domains_maps.cf ===
 +   # vim /etc/postfix/mysql_virtual_domains_maps.cf
 +<file bash /etc/postfix/mysql_virtual_domains_maps.cf># Django : 2013-02-07
 +# Definition der Datenbankanbindung zur Abfrage der virtuellen Domaenen
 +#
 +user = postfix_user
 +password = rbgsDK39DeM2b2btx9iMHfzd
 +hosts = mariadb.dmz.nausch.org
 +dbname = postfix
 +query = SELECT domain FROM domain WHERE domain='%s' AND active = '1'
 +</file>
 +
 +=== mysql_virtual_alias_maps.cf ===
 +   # vim /etc/postfix/mysql_virtual_alias_maps.cf
 +<file bash /etc/postfix/mysql_virtual_alias_maps.cf># Django : 2012-02-07
 +# Definition der Datenbankanbindung zur Abfrage der virtual Alias Maps
 +#
 +user = postfix_user
 +password = rbgsDK39DeM2b2btx9iMHfzd
 +hosts = mariadb.dmz.nausch.org
 +dbname = postfix
 +query = SELECT goto FROM alias WHERE address='%s' AND active = '1'
 +</file>
 +
 +=== mysql_virtual_alias_domain_maps.cf ===
 +   # vim /etc/postfix/mysql_virtual_alias_domain_maps.cf
 +<file bash /etc/postfix/mysql_virtual_alias_domain_maps.cf># Django : 2013-02-07
 +# Definition der Datenbankanbindung zur Abfrage der virtual Alias Domain Maps
 +#
 +user = postfix_user
 +password = rbgsDK39DeM2b2btx9iMHfzd
 +hosts = mariadb.dmz.nausch.org
 +dbname = postfix
 +query = SELECT goto FROM alias,alias_domain WHERE alias_domain.alias_domain = '%d' AND
 +           alias.address = CONCAT('%u', '@', alias_domain.target_domain) AND alias.active = 1
 +           AND alias_domain.active='1'
 +</file>
 +
 +=== mysql_virtual_alias_domain_catchall_maps.cf ===
 +   # vim /etc/postfix/mysql_virtual_alias_domain_catchall_maps.cf
 +<file bash /etc/postfix/mysql_virtual_alias_domain_catchall_maps.cf># Django : 2013-02-07
 +# Definition der Datenbankanbindung zur Abfrage der virtual Alias Domain Catchall Maps
 +#
 +user = postfix_user
 +password = rbgsDK39DeM2b2btx9iMHfzd
 +hosts = mariadb.dmz.nausch.org
 +dbname = postfix
 +query = SELECT goto FROM alias,alias_domain WHERE alias_domain.alias_domain = '%d' AND
 +           alias.address = CONCAT('@', alias_domain.target_domain) AND alias.active = 1
 +           AND alias_domain.active='1'
 +</file> 
 +
 +=== mysql_virtual_mailbox_maps.cf ===
 +   # vim /etc/postfix/mysql_virtual_mailbox_maps.cf
 +<file bash /etc/postfix/mysql_virtual_mailbox_maps.cf># Django : 2013-02-07
 +# Definition der Datenbankanbindung zur Abfrage der virtual Mailbox Maps
 +#
 +user = postfix_user
 +password = rbgsDK39DeM2b2btx9iMHfzd
 +hosts = mariadb.dmz.nausch.org
 +dbname = postfix
 +query = SELECT maildir FROM mailbox WHERE username='%s' AND active = '1'
 +</file>
 +
 +=== mysql_virtual_alias_domain_mailbox_maps.cf ===
 +   # vim /etc/postfix/mysql_virtual_alias_domain_mailbox_maps.cf
 +<file bash /etc/postfix/mysql_virtual_alias_domain_mailbox_maps.cf># Django : 2012-10-09
 +# Definition der Datenbankanbindung zur Abfrage der virtual Alias Domain Mailbox Maps
 +#
 +user = postfix_user
 +password = rbgsDK39DeM2b2btx9iMHfzd
 +hosts = mariadb.dmz.nausch.org
 +dbname = postfix
 +query = SELECT maildir FROM mailbox,alias_domain WHERE alias_domain.alias_domain = '%d'
 +           AND mailbox.username = CONCAT('%u', '@', alias_domain.target_domain) AND
 +           mailbox.active = 1 AND alias_domain.active='1'
 +</file>
 +
 +====== Links ======
 +  * **[[centos:mail_c7:start|Zurück zum Kapitel >>Mailserverinstallation unter CentOS 7<<]]**
 +  * **[[wiki:start|Zurück zu >>Projekte und Themenkapitel<<]]**
 +  * **[[http://dokuwiki.nausch.org/doku.php/|Zurück zur Startseite]]**
 +
  
  • centos/mail_c7/pfadmin_1.1410193847.txt.gz
  • Zuletzt geändert: 08.09.2014 16:30.
  • von django