dolibarr/htdocs/core/modules/modMailing.class.php

175 lines
6.0 KiB
PHP
Raw Normal View History

2011-09-21 18:40:52 +02:00
<?php
2011-09-21 15:05:32 +02:00
/* Copyright (C) 2005 Rodolphe Quiedeville <rodolphe@quiedeville.org>
* Copyright (C) 2005-2008 Laurent Destailleur <eldy@users.sourceforge.net>
2018-10-27 14:43:12 +02:00
* Copyright (C) 2005-2009 Regis Houssin <regis.houssin@inodbox.com>
2011-09-21 15:05:32 +02:00
*
* 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
* the Free Software Foundation; either version 3 of the License, or
2011-09-21 15:05:32 +02:00
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
2019-09-23 21:55:30 +02:00
* along with this program. If not, see <https://www.gnu.org/licenses/>.
2011-09-21 15:05:32 +02:00
*/
/**
* \defgroup mailing Module emailing
* \brief Module to manage EMailings
* \file htdocs/core/modules/modMailing.class.php
2011-09-21 15:05:32 +02:00
* \ingroup mailing
2021-03-20 13:55:43 +01:00
* \brief Description and activation file for the module Mailing
2011-09-21 15:05:32 +02:00
*/
include_once DOL_DOCUMENT_ROOT.'/core/modules/DolibarrModules.class.php';
2011-09-21 15:05:32 +02:00
/**
2015-09-07 15:55:26 +02:00
* Class to describe and enable module Mailing
2011-09-21 15:05:32 +02:00
*/
class modMailing extends DolibarrModules
{
/**
2011-09-26 16:22:35 +02:00
* Constructor. Define names, constants, directories, boxes, permissions
*
2012-01-04 21:23:50 +01:00
* @param DoliDB $db Database handler
2011-09-21 15:05:32 +02:00
*/
2019-02-25 20:35:59 +01:00
public function __construct($db)
2011-09-21 15:05:32 +02:00
{
2012-01-04 21:23:50 +01:00
$this->db = $db;
$this->numero = 22;
2011-09-21 15:05:32 +02:00
2018-11-07 16:33:06 +01:00
// Family can be 'base' (core modules),'crm','financial','hr','projects','products','ecm','technic' (transverse modules),'interface' (link with external tools),'other','...'
// It is used to group modules by family in module setup page
$this->family = "interface";
// Module position in the family on 2 digits ('01', '10', '20', ...)
2021-04-05 13:52:19 +02:00
$this->module_position = '23';
2018-11-07 16:33:06 +01:00
2011-09-21 15:05:32 +02:00
// Module label (no space allowed), used if translation string 'ModuleXXXName' not found (where XXX is value of numeric property 'numero' of module)
$this->name = preg_replace('/^mod/i', '', get_class($this));
2011-09-21 15:05:32 +02:00
$this->description = "Gestion des EMailings";
2017-08-22 18:34:58 +02:00
// Possible values for version are: 'development', 'experimental', 'dolibarr' or version
$this->version = 'dolibarr';
2011-09-21 15:05:32 +02:00
$this->const_name = 'MAIN_MODULE_'.strtoupper($this->name);
$this->picto = 'email';
2011-09-21 15:05:32 +02:00
// Data directories to create when module is enabled
$this->dirs = array("/mailing/temp");
2015-09-07 15:29:51 +02:00
// Dependencies
$this->hidden = false; // A condition to hide module
$this->depends = array(); // List of module class names as string that must be enabled if this module is enabled
$this->requiredby = array(); // List of module ids to disable if this one is disabled
$this->conflictwith = array(); // List of module class names as string this module is in conflict with
2022-09-27 20:48:47 +02:00
$this->phpmin = array(7, 0); // Minimum version of PHP required by module
2011-09-21 15:05:32 +02:00
$this->langfiles = array("mails");
// Config pages
$this->config_page_url = array("mailing.php");
2015-09-07 15:40:55 +02:00
// Constants
2011-09-21 15:05:32 +02:00
$this->const = array();
2021-01-07 17:23:02 +01:00
$r = 0;
$this->const[$r][0] = "MAILING_CONTACT_DEFAULT_BULK_STATUS";
$this->const[$r][1] = "chaine";
$this->const[$r][2] = "0";
$this->const[$r][3] = 'Default value for field "Refuse bulk email" when creating a contact';
2021-01-07 17:23:02 +01:00
$this->const[$r][4] = 0;
$r++;
2011-09-21 15:05:32 +02:00
2015-09-07 15:46:57 +02:00
// Boxes
2011-09-21 15:05:32 +02:00
$this->boxes = array();
// Permissions
$this->rights = array();
$this->rights_class = 'mailing';
$r = 0;
2012-10-03 00:30:50 +02:00
$r++;
$this->rights[$r][0] = 221; // id de la permission
$this->rights[$r][1] = 'Consulter les mailings'; // libelle de la permission
$this->rights[$r][2] = 'r'; // type de la permission (deprecie a ce jour)
$this->rights[$r][3] = 0; // La permission est-elle une permission par defaut
$this->rights[$r][4] = 'lire';
2012-10-03 00:30:50 +02:00
$r++;
$this->rights[$r][0] = 222;
$this->rights[$r][1] = 'Creer/modifier les mailings (sujet, destinataires...)';
$this->rights[$r][2] = 'w';
$this->rights[$r][3] = 0;
$this->rights[$r][4] = 'creer';
2012-10-03 00:30:50 +02:00
$r++;
$this->rights[$r][0] = 223;
$this->rights[$r][1] = 'Valider les mailings (permet leur envoi)';
$this->rights[$r][2] = 'w';
$this->rights[$r][3] = 0;
$this->rights[$r][4] = 'valider';
2012-10-03 00:30:50 +02:00
$r++;
$this->rights[$r][0] = 229;
$this->rights[$r][1] = 'Supprimer les mailings';
$this->rights[$r][2] = 'd';
$this->rights[$r][3] = 0;
$this->rights[$r][4] = 'supprimer';
2012-10-03 00:30:50 +02:00
2012-07-02 19:30:37 +02:00
$r++;
$this->rights[$r][0] = 237;
$this->rights[$r][1] = 'View recipients and info';
$this->rights[$r][2] = 'r';
$this->rights[$r][3] = 0;
$this->rights[$r][4] = 'mailing_advance'; // Visible if option MAIN_USE_ADVANCED_PERMS is on
2012-06-14 20:08:46 +02:00
$this->rights[$r][5] = 'recipient';
2012-10-03 00:30:50 +02:00
2012-07-02 19:30:37 +02:00
$r++;
$this->rights[$r][0] = 238;
$this->rights[$r][1] = 'Manually send mailings';
$this->rights[$r][2] = 'w';
$this->rights[$r][3] = 0;
$this->rights[$r][4] = 'mailing_advance'; // Visible if option MAIN_USE_ADVANCED_PERMS is on
2012-06-14 20:08:46 +02:00
$this->rights[$r][5] = 'send';
2012-10-03 00:30:50 +02:00
2012-07-02 19:30:37 +02:00
$r++;
$this->rights[$r][0] = 239;
$this->rights[$r][1] = 'Delete mailings after validation and/or sent';
$this->rights[$r][2] = 'd';
$this->rights[$r][3] = 0;
$this->rights[$r][4] = 'mailing_advance'; // Visible if option MAIN_USE_ADVANCED_PERMS is on
2012-06-14 20:08:46 +02:00
$this->rights[$r][5] = 'delete';
2011-09-21 15:05:32 +02:00
// Menus
//-------
$this->menu = 1; // This module add menu entries. They are coded into menu manager.
2011-09-21 15:05:32 +02:00
}
/**
2019-02-26 21:13:07 +01:00
* Function called when module is enabled.
* The init function add constants, boxes, permissions and menus (defined in constructor) into Dolibarr database.
* It also creates data directories
2012-01-04 21:23:50 +01:00
*
* @param string $options Options when enabling module ('', 'noboxes')
2019-02-26 21:13:07 +01:00
* @return int 1 if OK, 0 if KO
2011-09-21 15:05:32 +02:00
*/
2019-02-26 21:13:07 +01:00
public function init($options = '')
2011-09-21 15:05:32 +02:00
{
$result = $this->_load_tables('/install/mysql/', 'mailing');
if ($result < 0) {
return -1; // Do not activate module if error 'not allowed' returned when loading module SQL queries (the _load_table run sql with run_sql with the error allowed parameter set to 'default')
}
2011-09-21 15:05:32 +02:00
// Permissions
$this->remove($options);
2011-09-21 15:05:32 +02:00
2011-12-05 19:03:36 +01:00
$sql = array();
return $this->_init($sql, $options);
2011-09-21 15:05:32 +02:00
}
}