public $__table = 'Person'; // table name
public $id; // int(11) not_null primary_key auto_increment
+ public $email; // string(128) not_null
+
+ public $company_id; // int(11)
public $office_id; // int(11)
public $name; // string(128) not_null
+ public $firstname; // string(128) not_null
+ public $lastname; // string(128) not_null
public $phone; // string(32) not_null
public $fax; // string(32) not_null
- public $email; // string(128) not_null
- public $company_id; // int(11)
+
public $role; // string(32) not_null
- public $active; // int(11) not_null
public $remarks; // blob(65535) not_null blob
public $passwd; // string(64) not_null
public $owner_id; // int(11) not_null
public $lang; // string(8)
public $no_reset_sent; // int(11)
public $action_type; // string(32)
- public $project_id; // int(11)
+ public $project_id; // int(11)
+
+
+ public $active; // int(11) not_null
public $deleted_by; // int(11) not_null
public $deleted_dt; // datetime(19) binary
+
+ public $name_facebook; // VARCHAR(128) NULL;
+ public $url_blog; // VARCHAR(256) NULL ;
+ public $url_twitter; // VARCHAR(256) NULL ;
+ public $url_linkedin; // VARCHAR(256) NULL ;
+
+ public $phone_mobile; // varchar(32) NOT NULL DEFAULT '';
+ public $phone_direct; // varchar(32) NOT NULL DEFAULT '';
/* the code above is auto generated do not remove the tag below */
###END_AUTOCODE
+
+ function owner()
+ {
+ $p = DB_DataObject::Factory('Person');
+ $p->get($this->owner_id);
+ return $p;
+ }
+
/**
*
- * @param {String} $templateFile (mail/XXXXXXX.txt) exclude the mail and .txt bit.
- * @param {Array|Object} $args data to send out..
- * @return {Array|PEAR_Error} array of $recipents, $header, $body
+ *
+ *
+ *
+ * FIXME !!!! -- USE Pman_Core_Mailer !!!!!
+ *
+ *
+ *
+ *
*/
function buildMail($templateFile, $args)
{
(isset($ff->HTTP_HOST) ? $ff->HTTP_HOST : 'localhost');
/* use the regex compiler, as it doesnt parse <tags */
- require_once 'HTML/Template/Flexy.php';
- $template = new HTML_Template_Flexy( array(
+
+ $tops = array(
'compiler' => 'Flexy',
'nonHTML' => true,
'filters' => array('SimpleTags','Mail'),
// 'debug'=>1,
- ));
+ );
+
-
-
+ if (!empty($args['templateDir'])) {
+ $tops['templateDir'] = $args['templateDir'];
+ }
+
+
+
+ require_once 'HTML/Template/Flexy.php';
+ $template = new HTML_Template_Flexy( $tops );
$template->compile("mail/$templateFile.txt");
/* use variables from this object to ouput data. */
$mailtext = $template->bufferedOutputObject($content);
+
+ $htmlbody = false;
+ // if a html file with the same name exists, use that as the body
+ // I've no idea where this code went, it was here before..
+ if (false !== $template->resolvePath ( "mail/$templateFile.html" )) {
+ $tops['nonHTML'] = false;
+ $template = new HTML_Template_Flexy( $tops );
+ $template->compile("mail/$templateFile.html");
+ $htmlbody = $template->bufferedOutputObject($content);
+
+ }
+
+
+
//echo "<PRE>";print_R($mailtext);
//print_R($mailtext);exit;
/* With the output try and send an email, using a few tricks in Mail_MimeDecode. */
$decoder = new Mail_mimeDecode($mailtext);
$parts = $decoder->getSendArray();
+
if (PEAR::isError($parts)) {
return $parts;
//echo "PROBLEM: {$parts->message}";
}
$headers['Date'] = date('r');
+ if ($htmlbody !== false) {
+ require_once 'Mail/mime.php';
+ $mime = new Mail_mime(array('eol' => "\n"));
+ $mime->setTXTBody($body);
+ $mime->setHTMLBody($htmlbody);
+ // I think there might be code in mediaoutreach toEmail somewhere
+ // h embeds images here..
+ $body = $mime->get();
+ $headers = $mime->headers($headers);
+
+ }
+
+
+
return array(
'recipients' => $recipents,
'headers' => $headers,
@session_start();
+
if (!empty($_SESSION[__CLASS__][$sesPrefix .'-auth'])) {
// in session...
$a = unserialize($_SESSION[__CLASS__][$sesPrefix .'-auth']);
return true;
}
+ // http basic auth..
+ $u = DB_DataObject::factory('Person');
+
+ if (!empty($_SERVER['PHP_AUTH_USER'])
+ &&
+ !empty($_SERVER['PHP_AUTH_PW'])
+ &&
+ $u->get('email', $_SERVER['PHP_AUTH_USER'])
+ &&
+ $u->checkPassword($_SERVER['PHP_AUTH_PW'])
+ ) {
+ $_SESSION[__CLASS__][$sesPrefix .'-auth'] = serialize($u);
+ return true;
+ }
+
+ if (!empty( $_SESSION[__CLASS__][$sesPrefix .'-empty'] )) {
+ return false;
+ }
// not in session or not matched...
$u = DB_DataObject::factory('Person');
$u->whereAdd(' LENGTH(passwd) > 0');
$n = $u->count();
+ $_SESSION[__CLASS__][$sesPrefix .'-empty'] = $n;
$error = PEAR::getStaticProperty('DB_DataObject','lastError');
if ($error) {
die($error->toString()); // not really a good thing to do...
$db = $this->getDatabaseConnection();
$sesPrefix = get_class($this) .'-'.$db->dsn['database'] ;
+
+
if (!empty($_SESSION[__CLASS__][$sesPrefix .'-auth'])) {
$a = unserialize($_SESSION[__CLASS__][$sesPrefix .'-auth']);
}
- $u = DB_DataObject::factory('Person');
- $u->whereAdd(' LENGTH(passwd) > 0');
- if (!$u->count()){
+ if (empty( $_SESSION[__CLASS__][$sesPrefix .'-empty'] )) {
+ $u = DB_DataObject::factory('Person');
+ $u->whereAdd(' LENGTH(passwd) > 0');
+ $_SESSION[__CLASS__][$sesPrefix .'-empty'] = $u->count();
+ }
+
+
+ if (empty( $_SESSION[__CLASS__][$sesPrefix .'-empty'] )) {
+
+ // fake person - open system..
+ //$ce = DB_DataObject::factory('core_enum');
+ //$ce->initEnums();
+
+
$u = DB_DataObject::factory('Person');
$u->id = -1;
return $u;
$this->isAuth(); // force session start..
$this->verifyAuth();
$db = $this->getDatabaseConnection();
+
+
+ // open up iptables at login..
+ $dbname = $this->database();
+ touch( '/tmp/run_pman_admin_iptables-'.$dbname);
+
// refresh admin group if we are logged in as one..
//DB_DataObject::debugLevel(1);
$g = DB_DataObject::factory('Groups');
$g->type = 0;
$g->get('name', 'Administrators');
- $gm = DB_DataObject::Factory('Group_Members');
+ $gm = DB_DataObject::Factory('group_members');
if (in_array($g->id,$gm->listGroupMembership($this))) {
// refresh admin groups.
- $gr = DB_DataObject::Factory('Group_Rights');
+ $gr = DB_DataObject::Factory('group_rights');
$gr->applyDefs($g, 0);
}
}
+ function generatePassword() // genearte a password (add set 'rawPasswd' to it's value)
+ {
+ require_once 'Text/Password.php';
+ $this->rawPasswd = strtr(ucfirst(Text_Password::create(5)).ucfirst(Text_Password::create(5)), array(
+ "a"=>"4", "e"=>"3", "i"=>"1", "o"=>"0", "s"=>"5", "t"=>"7"));
+ $this->setPassword($this->rawPasswd);
+ return $this->rawPasswd;
+ }
+
function company()
{
$x = DB_DataObject::factory('Companies');
+ $x->autoJoin();
$x->get($this->company_id);
return $x;
}
}
function active()
- {
+ {
return $this->active;
}
function authUserName($n) // set username prior to acheck user exists query.
// perms + groups.
$aur['perms'] = $this->getPerms();
- $g = DB_DataObject::Factory('Group_Members');
+ $g = DB_DataObject::Factory('group_members');
$aur['groups'] = $g->listGroupMembership($this, 'name');
$aur['passwd'] = '';
// ------ INIITIALIZE IF NO GROUPS ARE SET UP.
- $g = DB_DataObject::Factory('Group_Rights');
+ $g = DB_DataObject::Factory('group_rights');
if (!$g->count()) {
$g->genDefault();
}
return $g->adminRights(); // system is not set up - so they get full rights.
}
//DB_DataObject::debugLevel(1);
- $g = DB_DataObject::Factory('Group_Members');
+ $g = DB_DataObject::Factory('group_members');
$g->whereAdd('group_id is NOT NULL AND user_id IS NOT NULL');
if (!$g->count()) {
// add the current user to the admin group..
$g = DB_DataObject::Factory('Groups');
if ($g->get('name', 'Administrators')) {
- $gm = DB_DataObject::Factory('Group_Members');
+ $gm = DB_DataObject::Factory('group_members');
$gm->group_id = $g->id;
$gm->user_id = $this->id;
$gm->insert();
}
// ------ STANDARD PERMISSION HANDLING.
-
- $g = DB_DataObject::Factory('Group_Members');
+ $isOwner = $this->company()->comptype == 'OWNER';
+ $g = DB_DataObject::Factory('group_members');
$grps = $g->listGroupMembership($this);
//var_dump($grps);
$isAdmin = $g->inAdmin;
//echo '<PRE>'; print_r($grps);var_dump($isAdmin);
// the load all the perms for those groups, and add them all together..
// then load all those
- $g = DB_DataObject::Factory('Group_Rights');
- $ret = $g->listPermsFromGroupIds($grps, $isAdmin);
+ $g = DB_DataObject::Factory('group_rights');
+ $ret = $g->listPermsFromGroupIds($grps, $isAdmin, $isOwner);
//echo '<PRE>';print_r($ret);
return $ret;
function groups($what=false)
{
- $g = DB_DataObject::Factory('Group_Members');
+ $g = DB_DataObject::Factory('group_members');
$grps = $g->listGroupMembership($this);
$g = DB_DataObject::Factory('Groups');
$g->whereAddIn('id', $grps, 'int');
}
+
+
function hasPerm($name, $lvl)
{
static $pcache = array();
$this->active = 1;
}
$tn_p = $this->tableName();
- $tn_gm = DB_DataObject::Factory('Group_Members')->tableName();
+ $tn_gm = DB_DataObject::Factory('group_members')->tableName();
$tn_g = DB_DataObject::Factory('Groups')->tableName();
///---------------- Group views --------
if ( $q['query']['not_in_directory'] > -1) {
$tn_pd = DB_DataObject::Factory('ProjectDirectory')->tableName();
// can list current - so that it does not break!!!
- $x->whereAdd("$tn_p.id NOT IN
+ $this->whereAdd("$tn_p.id NOT IN
( SELECT distinct person_id FROM $tn_pd WHERE
project_id = " . $q['query']['not_in_directory'] . " AND
company_id = " . $this->company_id . ')');
// can list current - so that it does not break!!!
$this->whereAdd("$tn_p.id IN
( SELECT distinct person_id FROM $tn_pd WHERE
- role = '". $x->escape($q['query']['role']) ."'
+ role = '". $this->escape($q['query']['role']) ."'
)");
}
}
-
if (!empty($q['query']['search'])) {
$s = $this->escape($q['query']['search']);
$this->whereAdd("
$tn_p.name LIKE '%$s%' OR
$tn_p.email LIKE '%$s%' OR
$tn_p.role LIKE '%$s%' OR
+ $tn_p.phone LIKE '%$s%' OR
$tn_p.remarks LIKE '%$s%'
");
}
function onInsert($req, $roo)
{
-
- if ($roo->authUser->id < 0) {
+
+ $p = DB_DataObject::factory('person');
+ if ($roo->authUser->id < 0 && $p->count() == 1) {
+ // this seems a bit risky...
+
$g = DB_DataObject::factory('Groups');
+ $g->initGroups();
+
$g->type = 0;
$g->get('name', 'Administrators');
- $p = DB_DataObject::factory('Group_Members');
+ $p = DB_DataObject::factory('group_members');
$p->group_id = $g->id;
$p->user_id = $this->id;
if (!$p->count()) {
}
}
+
+ function importFromArray($roo, $persons, $prefix)
+ {
+ foreach($persons as $person){
+ $p = DB_DataObject::factory('person');
+ if($p->get('name', $person['name'])){
+ continue;
+ }
+ $p->setFrom($person);
+
+ $companies = DB_DataObject::factory('companies');
+ if(!$companies->get('comptype', 'OWNER')){
+ $roo->jerr("Missing OWNER companies!");
+ }
+ $p->company_id = $companies->pid();
+ // strip the 'spaces etc.. make lowercase..
+ $name = strtolower(str_replace(' ', '', $person['name']));
+ $p->setPassword("$prefix$name");
+ $p->insert();
+ // set up groups
+ // if $person->groups is set.. then
+ // add this person to that group eg. groups : [ 'Administrator' ]
+ if(!empty($person['groups'])){
+ $groups = DB_DataObject::factory('groups');
+ if(!$groups->get('name', $person['groups'])){
+ $roo->jerr("Missing groups : {$person['groups']}");
+ }
+ $gm = DB_DataObject::factory('group_members');
+ $gm->change($p, $groups, true);
+ }
+
+ $p->onInsert(array(), $roo);
+ }
+ }
}