X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=WEB-INF%2Flib%2FttOrgImportHelper.class.php;h=0da0a7eac772392058496bd2a4d2a687a5eb9b34;hb=3fe430d82ad416d1766b9f0cd558e2e1f26900a9;hp=4c57739b3e58779cf73d30dbd087ee1eaddd8c05;hpb=c5742659a15a48bd5ddcba78d648a26cc6c520ee;p=timetracker.git diff --git a/WEB-INF/lib/ttOrgImportHelper.class.php b/WEB-INF/lib/ttOrgImportHelper.class.php index 4c57739b..0da0a7ea 100644 --- a/WEB-INF/lib/ttOrgImportHelper.class.php +++ b/WEB-INF/lib/ttOrgImportHelper.class.php @@ -59,6 +59,7 @@ class ttOrgImportHelper { var $currentGroupLogMap = array(); var $currentGroupCustomFieldMap = array(); var $currentGroupCustomFieldOptionMap = array(); + var $currentGroupFavReportMap = array(); // Constructor. function __construct(&$errors) { @@ -455,6 +456,14 @@ class ttOrgImportHelper { return; } + if ($name == 'FAV_REPORTS') { + // If we get here, we have to recycle $currentGroupFavReportMap. + unset($this->currentGroupFavReportMap); + $this->currentGroupFavReportMap = array(); + // Favorite report map is reconstructed after processing elements in XML. See below. + return; + } + if ($name == 'FAV_REPORT') { $user_list = ''; if (strlen($attrs['USERS']) > 0) { @@ -462,9 +471,11 @@ class ttOrgImportHelper { foreach ($arr as $v) $user_list .= (strlen($user_list) == 0 ? '' : ',').$this->currentGroupUserMap[$v]; } - $fav_report_id = ttFavReportHelper::insertReport(array( + $fav_report_id = $this->insertFavReport(array( 'name' => $attrs['NAME'], 'user_id' => $this->currentGroupUserMap[$attrs['USER_ID']], + 'group_id' => $this->current_group_id, + 'org_id' => $this->org_id, 'client' => $this->currentGroupClientMap[$attrs['CLIENT_ID']], 'option' => $this->currentGroupCustomFieldOptionMap[$attrs['CF_1_OPTION_ID']], 'project' => $this->currentGroupProjectMap[$attrs['PROJECT_ID']], @@ -491,8 +502,29 @@ class ttOrgImportHelper { 'group_by2' => $attrs['GROUP_BY2'], 'group_by3' => $attrs['GROUP_BY3'], 'chtotalsonly' => (int) $attrs['SHOW_TOTALS_ONLY'])); - if (!$fav_report_id) $this->errors->add($i18n->get('error.db')); - return; + if ($fav_report_id) { + // Add a mapping. + $this->currentGroupFavReportMap[$attrs['ID']] = $fav_report_id; + } else $this->errors->add($i18n->get('error.db')); + return; + } + + if ($name == 'NOTIFICATION') { + if (!$this->insertNotification(array( + 'group_id' => $this->current_group_id, + 'org_id' => $this->org_id, + 'cron_spec' => $attrs['CRON_SPEC'], + 'last' => $attrs['LAST'], + 'next' => $attrs['NEXT'], + 'report_id' => $this->currentGroupFavReportMap[$attrs['REPORT_ID']], + 'email' => $attrs['EMAIL'], + 'cc' => $attrs['CC'], + 'subject' => $attrs['SUBJECT'], + 'report_condition' => $attrs['REPORT_CONDITION'], + 'status' => $attrs['STATUS']))) { + $this->errors->add($i18n->get('error.db')); + } + return; } } } @@ -746,4 +778,68 @@ class ttOrgImportHelper { return $last_id; } + + // insertFavReport - inserts a favorite report in database. + private function insertFavReport($fields) { + $mdb2 = getConnection(); + + $group_id = (int) $fields['group_id']; + $org_id = (int) $fields['org_id']; + + $sql = "insert into tt_fav_reports". + " (name, user_id, group_id, org_id, client_id, cf_1_option_id, project_id, task_id,". + " billable, invoice, paid_status, users, period, period_start, period_end,". + " show_client, show_invoice, show_paid, show_ip,". + " show_project, show_start, show_duration, show_cost,". + " show_task, show_end, show_note, show_custom_field_1, show_work_units,". + " group_by1, group_by2, group_by3, show_totals_only)". + " values(". + $mdb2->quote($fields['name']).", ".$fields['user_id'].", $group_id, $org_id, ". + $mdb2->quote($fields['client']).", ".$mdb2->quote($fields['option']).", ". + $mdb2->quote($fields['project']).", ".$mdb2->quote($fields['task']).", ". + $mdb2->quote($fields['billable']).", ".$mdb2->quote($fields['invoice']).", ". + $mdb2->quote($fields['paid_status']).", ". + $mdb2->quote($fields['users']).", ".$mdb2->quote($fields['period']).", ". + $mdb2->quote($fields['from']).", ".$mdb2->quote($fields['to']).", ". + $fields['chclient'].", ".$fields['chinvoice'].", ".$fields['chpaid'].", ".$fields['chip'].", ". + $fields['chproject'].", ".$fields['chstart'].", ".$fields['chduration'].", ".$fields['chcost'].", ". + $fields['chtask'].", ".$fields['chfinish'].", ".$fields['chnote'].", ".$fields['chcf_1'].", ".$fields['chunits'].", ". + $mdb2->quote($fields['group_by1']).", ".$mdb2->quote($fields['group_by2']).", ". + $mdb2->quote($fields['group_by3']).", ".$fields['chtotalsonly'].")"; + $affected = $mdb2->exec($sql); + if (is_a($affected, 'PEAR_Error')) + return false; + + $sql = "select last_insert_id() as last_id"; + $res = $mdb2->query($sql); + if (is_a($res, 'PEAR_Error')) + return false; + + $val = $res->fetchRow(); + return $val['last_id']; + } + + // insertNotification function inserts a new notification into database. + static function insertNotification($fields) + { + $mdb2 = getConnection(); + + $group_id = (int) $fields['group_id']; + $org_id = (int) $fields['org_id']; + $cron_spec = $fields['cron_spec']; + $last = (int) $fields['last']; + $next = (int) $fields['next']; + $report_id = (int) $fields['report_id']; + $email = $fields['email']; + $cc = $fields['cc']; + $subject = $fields['subject']; + $report_condition = $fields['report_condition']; + $status = $fields['status']; + + $sql = "insert into tt_cron". + " (group_id, org_id, cron_spec, last, next, report_id, email, cc, subject, report_condition, status)". + " values ($group_id, $org_id, ".$mdb2->quote($cron_spec).", $last, $next, $report_id, ".$mdb2->quote($email).", ".$mdb2->quote($cc).", ".$mdb2->quote($subject).", ".$mdb2->quote($report_condition).", ".$mdb2->quote($status).")"; + $affected = $mdb2->exec($sql); + return (!is_a($affected, 'PEAR_Error')); + } }