mirror of
https://git.code.sf.net/p/seeddms/code
synced 2024-11-26 15:32:13 +00:00
206 lines
5.4 KiB
PHP
206 lines
5.4 KiB
PHP
<?php
|
||
/***************************************************************
|
||
* Copyright notice
|
||
*
|
||
* (c) 2013 Uwe Steinmann <uwe@steinmann.cx>
|
||
* All rights reserved
|
||
*
|
||
* This script is part of the SeedDMS project. The SeedDMS project 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.
|
||
*
|
||
* The GNU General Public License can be found at
|
||
* http://www.gnu.org/copyleft/gpl.html.
|
||
*
|
||
* This script 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.
|
||
*
|
||
* This copyright notice MUST APPEAR in all copies of the script!
|
||
***************************************************************/
|
||
|
||
|
||
/**
|
||
* Example extension
|
||
*
|
||
* @author Uwe Steinmann <uwe@steinmann.cx>
|
||
* @package SeedDMS
|
||
* @subpackage example
|
||
*/
|
||
class SeedDMS_ExtExample extends SeedDMS_ExtBase {
|
||
|
||
/**
|
||
* Initialization
|
||
*
|
||
* Use this method to do some initialization like setting up the hooks
|
||
* You have access to the following global variables:
|
||
* $GLOBALS['settings'] : current global configuration
|
||
* $GLOBALS['settings']->_extensions['example'] : configuration of this extension
|
||
* $GLOBALS['LANG'] : the language array with translations for all languages
|
||
* $GLOBALS['SEEDDMS_HOOKS'] : all hooks added so far
|
||
*/
|
||
function init() { /* {{{ */
|
||
$GLOBALS['SEEDDMS_HOOKS']['initDMS'][] = new SeedDMS_ExtExample_InitDMS;
|
||
$GLOBALS['SEEDDMS_HOOKS']['view']['addDocument'][] = new SeedDMS_ExtExample_AddDocument;
|
||
$GLOBALS['SEEDDMS_HOOKS']['view']['viewFolder'][] = new SeedDMS_ExtExample_ViewFolder;
|
||
$GLOBALS['SEEDDMS_SCHEDULER']['tasks']['example']['example'] = new SeedDMS_ExtExample_Task;
|
||
} /* }}} */
|
||
|
||
function main() { /* {{{ */
|
||
} /* }}} */
|
||
}
|
||
|
||
class SeedDMS_ExtExample_HomeController { /* {{{ */
|
||
|
||
protected $dms;
|
||
|
||
protected $settings;
|
||
|
||
public function __construct($dms, $settings) {
|
||
$this->dms = $dms;
|
||
$this->settings = $settings;
|
||
}
|
||
|
||
public function home($request, $response, $args) {
|
||
$response->getBody()->write('Output of route /ext/example/home'.get_class($this->dms));
|
||
return $response;
|
||
}
|
||
|
||
public function echos($request, $response, $args) {
|
||
$response->getBody()->write('Output of route /ext/example/echo');
|
||
return $response;
|
||
}
|
||
} /* }}} */
|
||
|
||
/**
|
||
* Class containing methods for hooks when the dms is initialized
|
||
*
|
||
* @author Uwe Steinmann <uwe@steinmann.cx>
|
||
* @package SeedDMS
|
||
* @subpackage example
|
||
*/
|
||
class SeedDMS_ExtExample_InitDMS { /* {{{ */
|
||
|
||
/**
|
||
* Hook after initializing the application
|
||
*
|
||
* This method sets the callback 'onAttributeValidate' in SeedDMS_Core
|
||
*/
|
||
public function addRoute($arr) { /* {{{ */
|
||
$dms = $arr['dms'];
|
||
$settings = $arr['settings'];
|
||
$app = $arr['app'];
|
||
|
||
$container = $app->getContainer();
|
||
$container['HomeController'] = function($c) use ($dms, $settings) {
|
||
// $view = $c->get("view"); // retrieve the 'view' from the container
|
||
return new SeedDMS_ExtExample_HomeController($dms, $settings);
|
||
};
|
||
|
||
$app->get('/ext/example/home', 'HomeController:home');
|
||
|
||
$app->get('/ext/example/echos',
|
||
function ($request, $response) use ($app) {
|
||
echo "Output of route /ext/example/echo";
|
||
}
|
||
);
|
||
return null;
|
||
} /* }}} */
|
||
|
||
} /* }}} */
|
||
|
||
/**
|
||
* Class containing methods for hooks when a document is added
|
||
*
|
||
* @author Uwe Steinmann <uwe@steinmann.cx>
|
||
* @package SeedDMS
|
||
* @subpackage example
|
||
*/
|
||
class SeedDMS_ExtExample_AddDocument {
|
||
|
||
/**
|
||
* Hook before adding a new document
|
||
*/
|
||
function preAddDocument($view) { /* {{{ */
|
||
} /* }}} */
|
||
|
||
/**
|
||
* Hook after successfully adding a new document
|
||
*/
|
||
function postAddDocument($view) { /* {{{ */
|
||
} /* }}} */
|
||
}
|
||
|
||
/**
|
||
* Class containing methods for hooks when a folder view is ѕhown
|
||
*
|
||
* @author Uwe Steinmann <uwe@steinmann.cx>
|
||
* @package SeedDMS
|
||
* @subpackage example
|
||
*/
|
||
class SeedDMS_ExtExample_ViewFolder {
|
||
|
||
/**
|
||
* Hook when showing a folder
|
||
*
|
||
* The returned string will be output after the object menu and before
|
||
* the actual content on the page
|
||
*
|
||
* @param object $view the current view object
|
||
* @return string content to be output
|
||
*/
|
||
function preContent($view) { /* {{{ */
|
||
return $view->infoMsg("Content created by viewFolder::preContent hook.");
|
||
} /* }}} */
|
||
|
||
/**
|
||
* Hook when showing a folder
|
||
*
|
||
* The returned string will be output at the end of the content area
|
||
*
|
||
* @param object $view the current view object
|
||
* @return string content to be output
|
||
*/
|
||
function postContent($view) { /* {{{ */
|
||
return $view->infoMsg("Content created by viewFolder::postContent hook");
|
||
} /* }}} */
|
||
|
||
}
|
||
|
||
/**
|
||
* Class containing methods for running a scheduled task
|
||
*
|
||
* @author Uwe Steinmann <uwe@steinmann.cx>
|
||
* @package SeedDMS
|
||
* @subpackage example
|
||
*/
|
||
class SeedDMS_ExtExample_Task extends SeedDMS_SchedulerTaskBase {
|
||
|
||
/**
|
||
* Run the task
|
||
*
|
||
* @param $task task to be executed
|
||
* @param $dms dms
|
||
* @return boolean true if task was executed succesfully, otherwise false
|
||
*/
|
||
public function execute($task, $dms) {
|
||
$taskparams = $task->getParameter();
|
||
return true;
|
||
}
|
||
|
||
public function getDescription() {
|
||
return 'Description';
|
||
}
|
||
|
||
public function getAdditionalParams() {
|
||
return array(array(
|
||
'name'=>'email',
|
||
'type'=>'string',
|
||
'description'=> '',
|
||
));
|
||
}
|
||
}
|