-
dockx thibault authored
Repeatable options are static array values and mandatory.
Verifiede914a335
<?php
/*
This code is part of FusionDirectory (http://www.fusiondirectory.org/)
Copyright (C) 2012-2022 FusionDirectory
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 2 of the License, or
(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
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
*/
class tasks extends simplePlugin
{
protected $displayHeader = FALSE;
static function plInfo (): array
{
return [
'plShortName' => _('Tasks'),
'plDescription' => _('Tasks'),
'plObjectClass' => ['fdTasks'],
'plFilter' => '(objectClass=fdTasks)',
'plPriority' => 41,
'plObjectType' => ['tasks' => [
'name' => _('Tasks'),
'ou' => get_ou('tasksRDN'),
'icon' => 'geticon.php?context=applications&icon=tasks&size=16',
]],
'plProvidedAcls' => parent::generatePlProvidedAcls(static::getAttributesInfo())
];
}
static function getAttributesInfo (): array
{
return [
// Attributes are grouped by section
'tasks' => [
'name' => _('Tasks Generic'),
'attrs' => [
new StringAttribute(
_('Task Name'), _('Name for this task'),
'cn', TRUE
),
new DateTimeAttribute(
_('Schedule'), '',
'fdTasksScheduleDate', FALSE
),
new HiddenAttribute('fdTasksStatus', TRUE, '1', '', 'Status', 'Status of the task'),
new HiddenAttribute('fdTasksLastExec', FALSE, '', '', 'LastExec', 'Last exec date'),
new HiddenAttribute('fdTasksCreationDate', TRUE, date("Y-m-d h:i:sa"), '', 'StartDate', 'Start Date And Time Of A Task'),
]
],
'subTasks' => [
'name' => _('Creation of Sub Tasks - Starting this task'),
'attrs' => [
new BooleanAttribute(
_('Activate SubTasks'), _('Trigger the creation of this task and related subtasks'),
'fdSubTasksActivation', FALSE
),
7172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
]
],
'taskSetting' => [
'name' => _('Advanced settings'),
'attrs' => [
new BooleanAttribute(
_('Only with new members'), _('Allows creation of sub-tasks for "NEW MEMBERS" only. (Case of Dynamic Group)'),
'fdTasksUpdatable', FALSE, TRUE
),
new BooleanAttribute(
_('Repeatable Task'), _('Set the task to be repeatable.'),
'fdTasksRepeatable', FALSE
),
new SelectAttribute(
_('Repeatable Schedule'), _('Select the desired schedule.'),
'fdTasksRepeatableSchedule', TRUE, ['Yearly', 'Monthly', 'Weekly', 'Daily', 'Hourly'], 'Daily',
['Yearly', 'Monthly', 'Weekly', 'Daily', 'Hourly']
),
]
],
];
}
function __construct ($dn = NULL, $object = NULL, $parent = NULL, $mainTab = FALSE)
{
parent::__construct($dn, $object, $parent, $mainTab);
$this->attributesAccess['fdTasksRepeatable']->setManagedAttributes(
[
'disable' => [
FALSE => [
'fdTasksRepeatableSchedule',
]
]
]
);
$this->attributesAccess['fdSubTasksActivation']->setInLdap(FALSE);
}
function save (): array
{
// Verification if the bool of activation is ticked and activate the last exec accordingly.
if ($this->fdSubTasksActivation === TRUE) {
$currentDateTime = date("Y-m-d H:i:s");
$this->fdTasksLastExec = $currentDateTime;
}
return parent::save();
}
/**
* @param array $listOfDN
* @param string $attributeType
* @param array|NULL $attrs
* @param string $taskType
* @return void
* Note : $taskType is present to define the object name related to life cycle (core) and any new plugins added to tasks.
*/
public function createSlaveTasks (array $listOfDN, string $attributeType, array $attrs = NULL, string $taskType = ''): void
{
global $config;
$ldap = $config->get_ldap_link();
// Take the attribute from the other tabs - attribute cannot be null or unset by default
$schedule = $this->fdTasksScheduleDate ?? NULL;
// Verify if members can have multiple sub-tasks for that main task.
$newMemberOnly = $this->fdTasksUpdatable;
// remove 'dn' keeping only 'cn'
141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
$rmDn = preg_replace('/(?=,).*/', '', $this->dn);
// only take the cn without dc
preg_match('/cn=(.*)/', $rmDn, $matches);
if (!empty($listOfDN)) {
// Condition allowing the creation of subtasks for existing members
if ($newMemberOnly === TRUE) {
$ldap->cd($config->current['BASE']);
$filter = '(&(objectClass=fdTasksGranular)(fdTasksGranularMaster=' . $this->dn . '))';
$ldap->search($filter, [$attributeType]);
// The while loop is important to get all info from ldap into the array.
while ($info = $ldap->fetch()) {
$subTasks[] = $info;
}
if (!empty($subTasks)) {
// Recuperate members DN from the ldap search.
foreach ($subTasks as $subTask) {
// For lifeCycle we check DN and for mailObject we check mail
switch ($attributeType) {
case 'fdTasksGranularDN':
$membersDN[] = $subTask['fdTasksGranularDN'][0];
break;
case 'fdTasksGranularMail':
$membersDN[] = $subTask['fdTasksGranularMail'][0];
break;
}
}
// Verify the DN differences and only keep those.
if (!empty($membersDN)) {
$listOfDN = array_diff($listOfDN, $membersDN);
}
// Simple re-index the array.
$listOfDN = array_values($listOfDN);
}
}
foreach ($listOfDN as $dn) {
// Here we create the object taskGranular
$tabObject = objects::create('TasksGranular');
// Create a unique ID based on timestamp (Allowing duplicate subtasks for same members in case of repeat).
$timestamp = microtime(TRUE); // Get the current timestamp with microseconds
$timestamp = (string)$timestamp; // Convert the float to a string, str_replace expect array or string.
$uniqueID = str_replace(".", "_", $timestamp); // Remove . with _ for correct CN
// Array matches come from preg_match function above with rmDn
$subTaskName = $matches[1] . '-SubTask-' . $uniqueID;
// Define the type of the granular task based on the attribute type passed to this method.
$prepData = NULL;
switch ($attributeType) {
case 'fdTasksGranularMail':
$prepData['tasksGranular'] = [
"fdTasksGranularMail" => $dn,
"fdTasksGranularType" => 'Mail Object',
"fdTasksGranularRef" => $attrs['ref'],
"fdTasksGranularMailFrom" => $attrs['from'],
"fdTasksGranularMailBCC" => $attrs['bcc']
];
break;
case 'fdTasksGranularDN' :
$prepData['tasksGranular'] = [
"fdTasksGranularDN" => $dn,
"fdTasksGranularType" => $taskType,
// Verification as 'ref' could potentially not be present depending on the logic of the main task.
"fdTasksGranularRef" => !empty($attrs['ref'][$dn]) ? array_values($attrs['ref'][$dn]) : [],
// Verification if any helper reference must be added to help further backend processing.
211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280
"fdTasksGranularHelper" => !empty($attrs['helper']) ? array_values($attrs['helper']) : [],
];
break;
}
// Common attributes to be filled for object tasksGranular.
$defaultData['tasksGranular'] = [
"cn" => $subTaskName,
"fdTasksGranularMaster" => $this->dn,
"fdTasksGranularSchedule" => $schedule,
];
// Simply merged the common values and the custom ones depending on the attribute type passed.
$values['tasksGranular'] = array_merge($prepData['tasksGranular'], $defaultData['tasksGranular']);
foreach ($values as $tab => $tabvalues) {
if (!isset($tabObject->by_object[$tab])) {
echo "Error tab does not contains attributes values" . PHP_EOL;
}
$error = $tabObject->by_object[$tab]->deserializeValues($tabvalues);
if ($error !== TRUE) {
echo 'Error during deserializing' . $error . PHP_EOL;
}
$tabObject->current = $tab;
$tabObject->update();
$tabObject->loadTabs();
}
$errors = $tabObject->save();
if (!empty($errors)) {
msg_dialog::displayChecks($errors);
}
}
}
}
/**
* @param array $groups
* @return array
*/
public static function extractMembersFromGroups (array $groups): array
{
global $config;
$ldap = $config->get_ldap_link();
$listMemberDN = [];
if (!empty($groups)) {
// Verify if the values received is a member or a group and collect the members DN
foreach ($groups as $group) {
if (strpos($group, "ou=groups") !== FALSE) {
// Position ldap to the dn required (limit search).
$ldap->cd($group);
$filter = '(|(objectClass=groupOfUrls)(objectClass=groupOfNames))';
$attrs = ['member'];
$ldap->search($filter, $attrs);
$info = $ldap->fetch();
// Verify if the group is not empty of members
if (!empty($info['member'])) {
//unset the count from the array
unset($info['member']['count']);
foreach ($info['member'] as $memberDN) {
$listMemberDN[] = $memberDN;
}
// case of member not within a group or dyngroup
}
} else {
281282283284285286287288289290291292293294295296297298
$listMemberDN[] = $group; //Here group is indeed a sole user
}
// Make sure no duplicate can happens, case of same member in an existing group.
$listMemberDN = array_unique($listMemberDN);
}
// Iterate on the DN list to remove any members representing a group (members of that potential groups were extracted).
foreach ($listMemberDN as $key => $value) {
if (strpos($value, 'ou=groups') !== FALSE) {
unset($listMemberDN[$key]);
}
}
}
return $listMemberDN;
}
}