示例#1
0
 function removeJavascript($id = 0)
 {
     $page =& NController::singleton('page');
     $page->base_view_dir = ROOT_DIR;
     $page->view_caching = (bool) PAGE_CACHING;
     $page->view_cache_lifetime = JS_CACHE_LIFETIME;
     $view_options = array('action' => 'blank');
     // REMOVE JAVASCRIPT CACHES
     $javascript_caches = array('javascript', 'javascript_secure', 'javascript_qualified', 'admin_javascript', 'admin_edit_javascript');
     foreach ($javascript_caches as $javascript_cache) {
         $page->view_cache_name = $javascript_cache;
         $view =& NView::singleton($page);
         $title = ucfirst(str_replace('_', ' ', $javascript_cache));
         if ($view->isCached($view_options)) {
             $cache_cleared = $view->clearCache($view_options);
             if ($cache_cleared) {
                 NDebug::debug($title . ' cache removed due to page edit on Page ID ' . $id . '.', N_DEBUGTYPE_CACHE);
             } else {
                 NDebug::debug($title . ' cache failed attempted removal due to page edit on Page ID ' . $id . '.', N_DEBUGTYPE_CACHE);
             }
         } else {
             NDebug::debug($title . ' cache failed attempted removal due to page edit on Page ID ' . $id . ' but cache does not exist.', N_DEBUGTYPE_CACHE);
         }
     }
     unset($view);
 }
 function navigation($current_section)
 {
     if (!isset($this->_auth)) {
         return;
     }
     $current_user_level = $this->_auth->getAuthData('user_level');
     // need to loop through other constructors and see
     // if they belong in the navigation tabs
     $navigation = array();
     $navigation[] = array('title' => 'Dashboard', 'controller' => 'dashboard', 'class' => '');
     $navigation[] = array('title' => 'Site Admin', 'controller' => 'site_admin', 'class' => '');
     if ($current_user_level >= N_USER_ADMIN) {
         $navigation[] = array('title' => 'Content', 'controller' => 'content', 'class' => '');
     }
     if (SITE_WORKFLOW) {
         $navigation[] = array('title' => 'Workflow', 'controller' => 'workflow_group', 'class' => '');
     }
     $navigation[] = array('title' => 'Admin', 'controller' => 'admin', 'class' => 'right');
     if ($current_user_level < N_USER_ADMIN) {
         $navigation[] = array('title' => 'User', 'controller' => 'users', 'class' => 'right');
     }
     foreach ($navigation as $k => $nav) {
         $ctrl =& NController::factory($nav['controller']);
         $ctrl->_auth =& $this->_auth;
         if (!$ctrl || !$ctrl->checkUserLevel()) {
             unset($navigation[$k]);
             continue;
         }
         if ($this->name == $ctrl->name || is_a($this, get_class($ctrl))) {
             $navigation[$k]['class'] .= ($navigation[$k]['class'] ? ' ' : '') . 'current';
         }
     }
     return $navigation;
 }
 function delete($parameter)
 {
     if (empty($parameter)) {
         $this->redirectTo(array('dashboard'));
     }
     // load the model layer with info
     $model =& NModel::factory($this->name);
     if (!$model) {
         $this->redirectTo(array('dashboard'));
     }
     if ($model->get($parameter)) {
         // if the content record is flagged with cms_draft=1, then the content has never been published and should be deleted altogether
         $content_model =& NModel::factory($model->asset);
         if ($content_model && $content_model->get($model->asset_id) && $content_model->cms_draft == 1) {
             $content_model->delete();
         }
         unset($content_model);
         if (defined('SITE_AUDIT_TRAIL') && SITE_AUDIT_TRAIL) {
             // audit trail before delete so we don't lose the values
             $audit_trail =& NController::factory('audit_trail');
             $audit_trail->insert(array('asset' => $this->name, 'asset_id' => $model->{$model->primaryKey()}, 'action_taken' => AUDIT_ACTION_DRAFT_DELETE));
             unset($audit_trail);
         }
         $model->delete();
         if (isset($this->params['_referer']) && $this->params['_referer']) {
             header('Location:' . urldecode($this->params['_referer']));
             exit;
         }
         $this->postProcessForm($model->toArray());
         $this->flash->set('notice', 'Draft deleted.');
     }
     $this->redirectTo(array('dashboard'));
 }
 function function_check_asset_template_use($params)
 {
     $asset = $params['asset'];
     $container_id = $params['container_id'];
     $check =& NController::factory('page_content');
     $result = $check->checkAssetContainerUsage($asset, $container_id);
     if ($result > 0) {
         print '&nbsp;(' . $result . ' uses)';
     }
 }
 function function_check_template($params)
 {
     $filename = $params['filename'];
     $template_check =& NController::factory('page_template');
     $result = $template_check->doesPageTemplateExist($filename);
     if (!$result) {
         print '<span class="notfound">&nbsp;File not found&nbsp;</span>';
     }
     unset($template_check);
 }
示例#6
0
 function test_controller_exists()
 {
     $c_exists =& NController::exists('page');
     $this->assertTrue($c_exists, 'Page Controller exists()');
     $c =& NController::singleton('page');
     $this->assertInstanceOf('PageController', $c);
     $c2 =& NController::singleton('page');
     $this->assertSame($c, $c2, "NController::singleton() returns a reference to the same object");
     unset($c2);
     $class_name = $c->getClassName('page');
     $this->assertEquals($class_name, "PageController", "getClassName returns proper name");
 }
 /**
  * Build the site index and apply it to a navigation template
  *
  * All parameters are optional
  * @param $template    template name to render (navigation/{$template}.html)  , default 'top'
  * @param $current_id  page to set as 'current' and it's ancestors as 'open'  , default 0
  * @param $top_id      top of the nav tree, defaults to home page             , default null
  *
  * @author Andy VanEe <*****@*****.**>
  */
 function function_nav($params, &$view)
 {
     $nav_controller = NController::factory('navigation');
     extract($params);
     $template = $template ? $template : 'top';
     $this->current_id = $current_id ? $current_id : 0;
     $top_id = $top_id ? $top_id : null;
     $page = array_shift($this->model->getChildren($top_id));
     $this->children($page);
     $nav_controller->set('top', $page);
     $nav_controller->render($template);
 }
 function viewlist($parameter = null, $layout = true, $model = false)
 {
     $options = array();
     $assigns = array();
     $model = $model ? $model : $this->getDefaultModel();
     $this->page_title = Inflector::humanize($this->name);
     $this->auto_render = false;
     $this->base_dir = APP_DIR;
     $assigns['TITLE'] = Inflector::humanize($this->name);
     if ($model) {
         $this->get_search_field($model, $options);
         $this->get_viewlist_options($model, $options);
         $this->get_sort_options($model, $options);
         $this->set_pagination($model);
         $model->find($options);
         $page_content =& NController::singleton('page_content');
         $page_content_model =& $page_content->getDefaultModel();
         $pk = $model->primaryKey();
         $models = array();
         $headline = $model->getHeadline() ? $model->getHeadline() : 'cms_headline';
         $i = 0;
         while ($model->fetch()) {
             $arr = $model->toArray();
             $arr['_headline'] = isset($arr['cms_headline']) && $arr['cms_headline'] ? $arr['cms_headline'] : $model->makeHeadline();
             $arr['_remove_delete'] = $page_content_model->isWorkflowContent($this->name, $arr[$pk]) ? 1 : 0;
             // Remove delete for models that have specified this.
             $arr['_remove_delete'] = isset($model->remove_delete) && $model->remove_delete == true ? 1 : 0;
             $models[] = $arr;
             unset($arr);
         }
         // Override standard paging limit if chosen in the model file.
         $paging = isset($model->paging) ? $model->paging : $this->paging;
         // If paging is not disabled in the model AND the records are > than the paging size AND not searching.
         if ($paging > 0 && count($models) > $paging && !$options['is_search']) {
             SmartyPaginate::connect($this->name);
             SmartyPaginate::setLimit($paging, $this->name);
             SmartyPaginate::setTotal(count($models), $this->name);
             $view =& NView::singleton($this);
             SmartyPaginate::assign($view, 'paginate', $this->name);
             // TODO: Could be more efficient and only get records it needs to.
             $models = array_slice($models, SmartyPaginate::getCurrentIndex($this->name), SmartyPaginate::getLimit($this->name));
             $this->set('paging', true);
         }
         $this->set(array('rows' => $models, 'asset' => $this->name, 'asset_name' => $this->page_title));
         unset($models);
     }
     $this->render(array('layout' => 'default'));
 }
 function getContent($params, $dynamic)
 {
     $content = '';
     $controller = $params['controller'];
     $action = $params['action'];
     unset($params['controller'], $params['action']);
     include_once 'controller/inflector.php';
     $method = Inflector::camelize($action);
     if ($ctrl =& NController::factory($controller)) {
         if ($dynamic) {
             $content = $this->dynamicPHP($ctrl, $method, NController::getIncludePath($controller), $params);
         } else {
             $content = $ctrl->{$method}($params);
         }
         unset($ctrl);
     }
     return $content;
 }
示例#10
0
 function searchFieldListSelect($params)
 {
     $asset = $params['asset'] ? $params['asset'] : null;
     $searched_field = $params['searched_field'] ? $params['searched_field'] : null;
     if (isset($searched_field)) {
         $searched_field = str_replace(" ", "_", strtolower($searched_field));
     }
     $model = NModel::factory($asset);
     $fields = $model->fields();
     // Remove a bunch of fields if you're not an admin - makes it a little bit simpler.
     $auth = new NAuth();
     $current_user_level = $auth->getAuthData('user_level');
     unset($auth);
     // Preload for the search_field default.
     $acon = NController::factory('asset');
     $select = 'Search Field: <select name="search_field">';
     foreach ($fields as $field) {
         if ($current_user_level < N_USER_ADMIN) {
             if (in_array($field, $this->admin_only_fields)) {
                 continue;
             }
         }
         $select .= '<option value="' . $field . '"';
         if (isset($searched_field) && $searched_field == $field) {
             $select .= ' selected="selected"';
         } elseif (isset($model->search_field) && $field == $model->search_field && !$searched_field) {
             $select .= ' selected="selected"';
         } elseif (!isset($model->search_field) && $field == $acon->search_field && !$searched_field) {
             $select .= ' selected="selected"';
         }
         $select .= '>' . ucwords(str_replace('_', ' ', $field)) . '</option>';
     }
     $select .= '</select>';
     unset($model);
     unset($acon);
     print $select;
 }
 /**
  * deleteAll - Delete all old versions of a particular asset.
  * This comprises all files and empty folders as well.
  *
  * @param  int  The id of this particular version.
  * @return void
  **/
 function deleteAll($parameter)
 {
     if (($model =& $this->getDefaultModel()) && $model->get($parameter)) {
         $info = $model->toArray();
         $model->reset();
         // Let's get all the versions for that asset and asset_id.
         $model->asset_id = $info['asset_id'];
         $model->asset = $info['asset'];
         $this->debug("Deleting versions for {$model->asset} : {$model->asset_id}");
         if ($model->find()) {
             while ($model->fetch()) {
                 $arr = $model->toArray();
                 $content = unserialize($arr['version']);
                 $success = $this->fileDelete($content, $info['asset'], $info['asset_id']);
                 $model->delete();
             }
         }
         $this->deleteEmptyFolders($info['asset'], $info['asset_id']);
         if (defined('SITE_AUDIT_TRAIL') && SITE_AUDIT_TRAIL) {
             $audit_trail =& NController::factory('audit_trail');
             $audit_trail->insert(array('asset' => $info['asset'], 'asset_id' => $info['asset_id'], 'action_taken' => AUDIT_ACTION_DELETE_ASSET_VERSIONS));
             unset($audit_trail);
         }
         header('Location:' . $_GET['_referer']);
     }
 }
示例#12
0
 function call($params, &$view)
 {
     $controller = isset($params['controller']) ? $params['controller'] : false;
     $action = isset($params['action']) ? $params['action'] : false;
     if (!$controller || !$action) {
         return;
     }
     unset($params['controller']);
     unset($params['action']);
     include_once 'controller/inflector.php';
     $ctrl =& NController::factory($controller);
     if ($controller) {
         $method = Inflector::camelize($action);
         if (is_callable(array($ctrl, $method))) {
             // pass all currently variables along
             // $ctrl->set($view->get_template_vars());
             return $ctrl->{$method}($params, $view);
         }
     }
     return '';
 }
示例#13
0
 /**
  * deleteSmartyCache - Delete the entire cache when you make a page change.
  * If you're including the navigation in the page as ul/li's - this keeps the
  * navigation always consistent.
  *
  * @return void
  **/
 function deleteSmartyCache()
 {
     // Only delete the entire cache if the NAV_IN_PAGE is true and we're in production.
     if (defined('NAV_IN_PAGE') && NAV_IN_PAGE && ENVIRONMENT == 'production' && !isset($this->smarty_cache_cleared)) {
         NDebug::debug('We are clearing the smarty caches because of a page edit.', N_DEBUGTYPE_INFO);
         $view =& NView::singleton($this);
         $view->clear_all_cache();
         $site_admin = NController::factory('site_admin');
         $site_admin->rmDirFiles(CACHE_DIR . '/smarty_cache');
         $site_admin->rmDirFiles(CACHE_DIR . '/templates_c');
         $this->smarty_cache_cleared = true;
     }
 }
 function postGenerateForm(&$form)
 {
     $form->removeElement('__header__');
     // Set the container in the menu as passed by $parameter
     $container_group =& $form->getElement('page_template_container_id');
     $container_group->setSelected($this->page_template_container_id);
     // Not sure I should do this - but it seems to help with confusion.
     $container_group->freeze();
     // Grab the asset list and create an array for QuickForm.
     $assets =& NController::factory('cms_asset_info');
     $array_of_assets = $assets->AssetList(true);
     foreach ($array_of_assets as $asset) {
         $select_array[$asset['asset']] = $asset['asset_name'];
     }
     // Add the element in place of the current asset form item.
     $form->removeElement('asset');
     $new_select =& $form->addElement('select', 'asset', 'Asset:', $select_array);
     $form->insertElementBefore($form->removeElement('asset', false), 'template_filename');
     // Set the asset if passed by edit.
     if (isset($this->passed_asset)) {
         $new_select->setSelected($this->passed_asset);
     }
     $form->addRule('template_filename', 'We need to have a template filename.', 'required', null, 'client');
     $form->addRule('template_filename', 'Letters, numbers, dashes and underscores - without a suffix, spaces or punctuation.', 'regex', '/^[a-zA-Z0-9_-]+$/', 'client');
 }
 function mediaBrowse()
 {
     $this->set('ckeditorfuncnum', $_GET['CKEditorFuncNum']);
     require_once 'n_quickform.php';
     $this->auto_render = false;
     // Media Element Browser
     $form = new NQuickform();
     $model =& NModel::factory('media_element');
     $modelIndex = array();
     $model->find();
     $media_elements = $model->fetchAll(true);
     foreach ($media_elements as $i) {
         $modelIndex[$i['media_file']] = $i['cms_headline'];
     }
     $form->addElement('select', 'mediaelement', "Media Element", $modelIndex, array("id" => "mediaelement"));
     $form->addElement('button', 'mediaelementsubmit', "Submit", array("onclick" => "javascript: me_callback()"));
     $page_controller =& NController::factory('page');
     $pageTree = $page_controller->getTreeAsSelect('pages', "Pages");
     $form->addElement($pageTree);
     $form->addElement('button', 'pagessubmit', "Submit", array("onclick" => "javascript: pg_callback()"));
     $this->set('title', 'Choose file or page to link to:');
     $this->set('form', $form->toHtml());
     $this->render(array('layout' => 'simple'));
 }
 function siteAdminList($id = null)
 {
     // set view caching to false so as to not cache every item
     $this->view_caching = false;
     $page_ctrl =& NController::singleton('page');
     $model =& $page_ctrl->getDefaultModel();
     $model->reset();
     $pk = $model->primaryKey();
     $html = '';
     $model->parent_id = $id ? (int) $id : 'null';
     if ($model->find()) {
         $this->set('reorder', $id == 0 ? false : true);
         $this->set('parent_id', $id);
         $html .= $this->render(array('action' => 'site_admin_list_start', 'return' => true));
         $i = 0;
         $assigns['_referer'] = urlencode(NServer::env('REQUEST_URI'));
         $pages =& $model->fetchAll();
         foreach ($pages as $page) {
             $page_edit = false;
             $surfedit = false;
             switch ($this->_auth->getAuthData('user_level')) {
                 case N_USER_EDITOR:
                     $surfedit = true;
                     break;
                 case N_USER_ADMIN:
                 case N_USER_ROOT:
                     $page_edit = true;
                     $surfedit = true;
                     break;
             }
             if (SITE_WORKFLOW) {
                 $assigns['workflow'] = '';
                 $workflow =& NController::singleton('workflow');
                 if ($workflow_group_model =& $workflow->getWorkflowGroup($page)) {
                     $user_rights = $workflow->getWorkflowUserRights($page);
                     if ($user_rights & WORKFLOW_RIGHT_EDIT) {
                         $surfedit = true;
                     }
                     $assigns['workflow'] = $workflow_group_model->workflow_title;
                 }
             }
             $assigns['id'] = $page->{$pk};
             $assigns['title'] = $page->title;
             $assigns['active'] = $page->active;
             $assigns['visible'] = $page->visible;
             $assigns['page_edit'] = $page_edit;
             $assigns['surfedit'] = $surfedit;
             $assigns['odd_or_even'] = $i % 2 == 0 ? 'even' : 'odd';
             $this->set($assigns);
             $html .= $this->render(array('action' => 'sitemap_list_item', 'return' => true));
             $i++;
             $html .= $this->siteAdminList($page->{$pk});
         }
         unset($pages);
         $html .= $this->render(array('action' => 'site_admin_list_end', 'return' => true));
     }
     unset($model, $page_ctrl);
     return $html;
 }
 function delete($parameter)
 {
     $model =& $this->getDefaultModel();
     if ($model->get($parameter)) {
         if (($page_content_model =& $model->getLink('page_content_id', 'page_content')) && $page_content_model->cms_workflow == 1) {
             $page_content_model->delete();
         }
     }
     $model->reset();
     if (defined('SITE_AUDIT_TRAIL') && SITE_AUDIT_TRAIL) {
         // audit trail
         $audit_trail =& NController::factory('audit_trail');
         $audit_trail->insert(array('asset' => $model->asset, 'asset_id' => $model->asset_id, 'action_taken' => AUDIT_ACTION_WORKFLOW_DELETE, 'workflow_id' => $model->{$model->primaryKey()}, 'workflow_group_id' => $model->workflow_group_id, 'page_id' => $model->page_id, 'page_content_id' => $model->page_content_id));
         unset($audit_trail);
     }
     parent::delete($parameter);
 }
 function renderContent($params)
 {
     $page_id = $params['page_id'] ? $params['page_id'] : 0;
     $container_id = $params['container_id'] ? $params['container_id'] : 0;
     if ($page_id and $container_id) {
         $page =& NController::factory('page');
         echo $page->getContainerContent($page_id, $container_id);
     }
 }
示例#19
0
 function postProcessForm(&$values)
 {
     $model =& $this->getDefaultModel();
     $pk = $model->primaryKey();
     // fix the paths for navigation
     // if (on insert or if changed path on update)
     $this->fixPaths($model->{$pk});
     // move all the old content to the current template
     // into matching template containers
     if (isset($values['mv_content'])) {
         $page_content =& NController::singleton('page_content');
         $page_content->changeTemplate($model->{$pk}, $model->page_template_id);
     }
     // delete general caches
     include_once 'n_cache.php';
     NCache::removeMenu();
     NCache::removeTreeAsSelect();
     NCache::removeJavascript($model->{$pk});
     // REMOVE PAGE CACHE
     $this->deletePageCache($model->{$pk});
     // REMOVE PARENT PAGE CACHE (for child links, etc);
     if ($this->action == 'create') {
         // load a new one
         $new_model =& NModel::factory($this->name);
         $parent_id = $new_model->getParent($model->{$pk});
         unset($new_model);
     } else {
         // user the existing model to find the parent
         $parent_id = $model->getParent($model->{$pk});
     }
     $this->deletePageCache($parent_id);
     // remove the site admin cache
     $site_admin =& NController::singleton('site_admin');
     $site_admin->deleteCache();
     unset($site_admin);
     if ($this->action == 'delete') {
         $this->flash->set('notice', 'Your page has been deleted.');
     } else {
         $this->flash->set('notice', 'Your page has been saved.');
     }
     parent::postProcessForm($values);
 }
示例#20
0
 /**
  * resetPassword - Reset the users' password and email it to them.
  *
  * @param	string	An email address.
  * @return 	boolean
  * @todo 	Audit trail this method.
  **/
 function resetPassword($email)
 {
     // Make sure to clear out the model - after searching a few times already.
     $this->reset();
     $this->email = $email;
     if ($this->find()) {
         while ($this->fetch()) {
             $password = $this->_createPassword();
             $this->password = md5($password);
             $this->save();
             $users = NController::factory('users');
             $users->passwordEmail($this->toArray(), $password);
             return true;
         }
     } else {
         return false;
     }
 }
示例#21
0
 function processForm($values)
 {
     $this->controller->preProcessForm($values);
     $model =& $this->model;
     $pk = $model->primaryKey();
     if (!$pk) {
         // TODO: raise error - can't store data if there's no primary key
         return false;
     }
     $table = $model->table();
     $fields = $model->fields();
     $action = 'update';
     if (!isset($model->{$pk}) || !strlen($model->{$pk})) {
         $action = 'insert';
     }
     // setup for file uploads
     $cms_files = array();
     $files = array();
     if (isset($_FILES) && is_array($_FILES)) {
         $form =& $this->form;
         foreach ($_FILES as $field => $value) {
             $el =& $form->getElement($field);
             if ($el->getType() == 'file' || $el->getType() == 'cms_file') {
                 $values[$field] = null;
                 if ($el->getType() == 'cms_file') {
                     $cms_files[$field] =& $el;
                 }
                 if (isset($_FILES[$field]['tmp_name']) && is_uploaded_file($_FILES[$field]['tmp_name'])) {
                     $files[$field] = array('type' => $el->getType(), 'upload_dir' => isset($el->_options['upload_dir']) ? $el->_options['upload_dir'] : UPLOAD_DIR, 'value' => $value);
                 } else {
                     $values[$field] = isset($this->_do->{$field}) ? $this->_do->{$field} : '';
                 }
             }
         }
     }
     foreach ($cms_files as $field => $el) {
         if (isset($values[$field . '__remove']) && $values[$field . '__remove']) {
             $values[$field] = '';
             if (isset($files[$field])) {
                 unset($files[$field]);
                 // so it doesn't get processed and uploaded after the fact
             }
         } else {
             if (isset($values[$field . '__current']) && $values[$field . '__current']) {
                 $values[$field] = $values[$field . '__current'];
             }
         }
     }
     // pull in any boolean fields that weren't passed and should therefore be 0
     foreach ($table as $field => $def) {
         if ($def & N_DAO_BOOL && !preg_match('/^cms_/', $field)) {
             // if the field is being ignored, then leave the value as what it is
             if (in_array($field, $model->form_ignore_fields)) {
                 continue;
             }
             $values[$field] = isset($values[$field]) ? 1 : 0;
         }
     }
     // deal with general values
     foreach ($values as $field => $val) {
         if (!in_array($field, $fields)) {
             continue;
         }
         $def = $table[$field];
         switch (true) {
             case ($def & N_DAO_DATE || $def & N_DAO_TIME) && is_array($val):
                 $val = NDate::arrayToDate($val);
                 if (!($def & N_DAO_NOTNULL)) {
                     if ($def & N_DAO_DATE || $def & N_DAO_TIME) {
                         if (!NDate::validDateTime($val)) {
                             $val = 'null';
                         }
                     }
                 }
                 break;
         }
         $model->{$field} = $val;
     }
     // set the autoheadline if it exists and wasn't set manually
     if (in_array('cms_headline', $fields) && !$values['cms_headline'] && $model->getHeadline()) {
         $model->cms_headline = $model->makeHeadline('-');
     }
     if ($action == 'update') {
         $this->processFiles($values, $files);
         foreach ($files as $field => $val) {
             if (!in_array($field, $fields)) {
                 continue;
             }
             $model->{$field} = $values[$field];
         }
         $page_content_id = $this->controller->getParam('page_content_id') ? $this->controller->getParam('page_content_id') : false;
         if ($page_content_id) {
             $page_content =& NController::singleton('page_content');
             $page_content_model =& $page_content->getDefaultModel();
             $page_content_model->get($page_content_id);
         }
         // set up timed contnt values if they are there
         if (isset($values['timed_start'])) {
             $values['timed_start'] = NDate::arrayToDate($values['timed_start']);
             if (!NDate::validDateTime($values['timed_start'])) {
                 $values['timed_start'] = 'null';
             }
         }
         if (isset($values['timed_end'])) {
             $values['timed_end'] = NDate::arrayToDate($values['timed_end']);
             if (!NDate::validDateTime($values['timed_end'])) {
                 $values['timed_end'] = 'null';
             }
         }
         // check for workflow
         if (SITE_WORKFLOW && isset($values['__submit_workflow__'])) {
             $page_content =& NController::factory('page_content');
             if (!$page_content_id) {
                 // then find the page we're attached to
                 $page_content_model =& $page_content->getDefaultModel();
                 $page_content_model->content_asset = $this->controller->name;
                 $page_content_model->content_asset_id = $model->{$pk};
                 if ($page_content_model->find(null, true)) {
                     $page_content_id = $page_content_model->{$page_content_model->primaryKey()};
                 }
             }
             if ($page_content_id) {
                 $page_model = $page_content_model->getLink('page_id', 'page');
                 $page_id = $page_model->{$page_model->primaryKey()};
                 // remove the draft and update the content
                 // delete the draft record
                 $this->controller->deleteDraft();
                 // Pull a fresh copy of the asset model and set the draft to 0
                 // so we don't update with the new content yet
                 $asset_model =& NModel::factory($this->controller->name);
                 $asset_model->get($model->{$pk});
                 $asset_model->cms_draft = 0;
                 $asset_model->update();
             }
             unset($page_content);
             // save the workflow
             $workflow =& NController::factory('workflow');
             $workflow_group_model = $workflow->getWorkflowGroup($page_model);
             // set values for saveWorkflow()
             $workflow_values = array();
             $workflow_values['page_content_id'] = $page_content_model->{$page_content_model->primaryKey()};
             $workflow_values['workflow_group_id'] = $workflow_group_model->{$workflow_group_model->primaryKey()};
             // add timed content
             $workflow_values['timed_start'] = $values['timed_start'];
             $workflow_values['timed_end'] = $values['timed_end'];
             // unset the timed content values so they don't get pushed into page_content
             unset($values['timed_start'], $values['timed_end']);
             $ret = $workflow->saveWorkflow($workflow_values, WORKFLOW_ACTION_EDIT, $this->controller);
         } else {
             if ($page_content_id) {
                 $page_content_model->timed_start = $values['timed_start'];
                 $page_content_model->timed_end = $values['timed_end'];
                 $page_content_model->col_xs = $values['col_xs'];
                 $page_content_model->col_sm = $values['col_sm'];
                 $page_content_model->col_md = $values['col_md'];
                 $page_content_model->col_lg = $values['col_lg'];
                 $page_content_model->row_xs = $values['row_xs'];
                 $page_content_model->row_sm = $values['row_sm'];
                 $page_content_model->row_md = $values['row_md'];
                 $page_content_model->row_lg = $values['row_lg'];
                 $page_content_model->offset_col_xs = $values['offset_col_xs'];
                 $page_content_model->offset_col_sm = $values['offset_col_sm'];
                 $page_content_model->offset_col_md = $values['offset_col_md'];
                 $page_content_model->offset_col_lg = $values['offset_col_lg'];
                 $page_content_model->offset_row_xs = $values['offset_row_xs'];
                 $page_content_model->offset_row_sm = $values['offset_row_sm'];
                 $page_content_model->offset_row_md = $values['offset_row_md'];
                 $page_content_model->offset_row_lg = $values['offset_row_lg'];
                 $page_content_model->pull_xs = $values['pull_xs'];
                 $page_content_model->pull_sm = $values['pull_sm'];
                 $page_content_model->pull_md = $values['pull_md'];
                 $page_content_model->pull_lg = $values['pull_lg'];
                 $page_content_model->gutter_xs = $values['gutter_xs'];
                 $page_content_model->gutter_sm = $values['gutter_sm'];
                 $page_content_model->gutter_md = $values['gutter_md'];
                 $page_content_model->gutter_lg = $values['gutter_lg'];
                 $page_content_model->update();
             }
         }
         // check for drafts
         if (SITE_DRAFTS) {
             if (isset($table['cms_draft']) && isset($values['__submit_draft__'])) {
                 $ret = $this->controller->saveDraft();
                 // update the headline immediately if it exists
                 if (isset($table['cms_headline'])) {
                     $tmp_model =& NModel::factory($this->controller->name);
                     if ($tmp_model && $tmp_model->get($values[$pk])) {
                         $tmp_model->cms_headline = $values['cms_headline'];
                         $tmp_model->update();
                     }
                     unset($tmp_model);
                 }
             }
         }
         if (isset($values['__submit__'])) {
             if ($this->controller->versioning == true) {
                 if (!isset($values['__skip_versioning__'])) {
                     $this->controller->debug('Inserting new version for ' . $model->tableName() . ': ' . $model->{$pk}, 'VERSION');
                     $version_id = $this->controller->insertVersion();
                 }
             }
             // if it's being saved normally (no draft), make sure it's not marked as a draft
             $model->cms_draft = 0;
             $ret = $model->update();
             if (defined('SITE_AUDIT_TRAIL') && SITE_AUDIT_TRAIL && isset($this->controller->_auth)) {
                 // audit trail
                 $audit_trail =& NController::factory('audit_trail');
                 $audit_trail_values = array();
                 $audit_trail_values['asset'] = $this->controller->name;
                 $audit_trail_values['asset_id'] = $model->{$pk};
                 $audit_trail_values['action_taken'] = AUDIT_ACTION_UPDATE;
                 if (isset($page_content_id)) {
                     $audit_trail_values['page_content_id'] = $page_content_id;
                 }
                 if (isset($page_id)) {
                     $audit_trail_values['page_id'] = $page_id;
                 }
                 $audit_trail->insert($audit_trail_values);
                 unset($audit_trail);
             }
             if (SITE_DRAFTS) {
                 // delete any draft records
                 $this->controller->deleteDraft();
             }
             // remove all linked page caches
             $page =& NController::factory('page');
             $page_content_model =& NModel::factory('page_content');
             $page_content_model->content_asset = $this->controller->name;
             $page_content_model->content_asset_id = $values[$pk];
             if ($page_content_model->find()) {
                 while ($page_content_model->fetch()) {
                     $page->deletePageCache($page_content_model->page_id);
                 }
             }
             unset($page);
             unset($page_content_model);
         }
     } else {
         $draft = false;
         if (SITE_DRAFTS && isset($table['cms_draft']) && isset($values['__submit_draft__'])) {
             $model->cms_draft = 1;
         }
         $id = $model->insert();
         $this->processFiles($values, $files);
         foreach ($files as $field => $val) {
             if (!in_array($field, $fields)) {
                 continue;
             }
             $model->{$field} = $values[$field];
         }
         if (SITE_DRAFTS && isset($table['cms_draft']) && isset($values['__submit_draft__'])) {
             // set draft to true after the draft is saved
             $draft = $this->controller->saveDraft();
         }
         $model->update();
         if (defined('SITE_AUDIT_TRAIL') && SITE_AUDIT_TRAIL && isset($this->controller->_auth)) {
             // audit trail
             $audit_trail =& NController::factory('audit_trail');
             $audit_trail_values = array();
             $audit_trail_values['asset'] = $this->controller->name;
             $audit_trail_values['asset_id'] = $model->{$pk};
             $audit_trail_values['action_taken'] = AUDIT_ACTION_INSERT;
             if (isset($page_content_id)) {
                 $audit_trail_values['page_content_id'] = $page_content_id;
             }
             if (isset($page_id)) {
                 $audit_trail_values['page_id'] = $page_id;
             }
             $audit_trail->insert($audit_trail_values);
             unset($audit_trail);
         }
         $ret = $id;
     }
     if ($ret) {
         $this->controller->postProcessForm($values);
     }
     if (isset($values['_referer'])) {
         header('Location:' . urldecode($values['_referer']));
         exit;
     }
     return $ret;
 }
示例#22
0
 /**
  * Checks to see if a controller exists
  *
  * @param string $controller - should be an underscored word
  * @return string
  */
 static function exists($controller)
 {
     if (!$controller) {
         return false;
     }
     $path = NController::getIncludePath($controller);
     if (!$path) {
         return false;
     }
     include_once $path;
     $class = NController::getClassName($controller);
     return class_exists($class);
 }
 /**
  * getAuditInfo - gets additional audit trail information by looking up foreign keys.
  *
  * @param	string	Name of a particular model.
  * @param	int		Id of a record in that particular model.
  * @return 	array 	Information related to $model_name and $id.
  **/
 function getAuditInfo($model_name, $id)
 {
     // checks for deleted and non-deleted records using special field
     $info = false;
     $fctrl =& NController::singleton($model_name);
     if ($fctrl && ($fmodel =& $fctrl->getDefaultModel())) {
         $fmodel->reset();
         if (!$fmodel->get($id)) {
             $fmodel->reset();
             $fields = $fmodel->fields();
             if (in_array('cms_deleted', $fields)) {
                 $fmodel->cms_deleted = 1;
             }
             $fmodel->get($id);
         }
         $info = $fmodel->{$fmodel->primaryKey()} ? $fmodel->toArray() : false;
         if ($info && (!isset($info['_headline']) || !$info['_headline'])) {
             $info['_headline'] = $fmodel->makeHeadline();
         }
         unset($fmodel);
     }
     return $info;
 }
示例#24
0
 /**
  * Instantiates and invokes the controller if it's available.
  *
  * @access private
  * @param string $controller
  * @param string $action				the action to be performed
  * @param string $parameter
  * @return null
  *
  */
 function _invoke($controller, $action, $parameter = null)
 {
     if (!$this->app_dir) {
         $controller = 'page';
     }
     if (!NController::exists($controller)) {
         $this->error($controller, $action);
     }
     $ctrl =& NController::factory($controller);
     if (!$action && method_exists($ctrl, 'index')) {
         $action = 'index';
     }
     if (!$this->app_dir && !in_array($action, $ctrl->public_actions)) {
         $action = 'index';
     }
     $method = Inflector::camelize($action);
     $ctrl->action = $action;
     if ($ctrl->login_required === true || is_array($ctrl->login_required) && (in_array($action, $ctrl->login_required) || in_array($method, $ctrl->login_required))) {
         include_once 'n_auth.php';
         $ctrl->_auth = new NAuth();
     }
     if (!$ctrl->checkUserLevel()) {
         header('Location:/' . APP_DIR . '/');
         exit;
     }
     // do the method
     if (!$this->app_dir && $controller == 'page') {
         $model =& $ctrl->getDefaultModel();
         // /_page8 redirection support (BC fix)
         if (preg_match('|^/_page(\\d+)|', $this->url, $matches)) {
             $parameter = $matches[1];
             if ($page_info = $model->getInfo($parameter)) {
                 header('Location:' . $ctrl->getHref($page_info) . ($this->params ? '?' . $this->paramsToString() : ''));
                 exit;
             }
         }
         if ($action != 'menus') {
             $parameter = $ctrl->models['page']->URLToID($this->url);
         }
     }
     if (method_exists($ctrl, $method)) {
         $ctrl->{$method}($parameter);
         if ($ctrl->auto_render) {
             $ctrl->render();
         }
     } else {
         $this->error($ctrl, $method);
     }
     unset($ctrl);
 }
 function export($model_name)
 {
     if (isset($model_name)) {
         $model = NModel::factory($model_name);
         // Foreign Key Lookup Support
         if (isset($model->excel_export)) {
             $model_foreign_keys = $model->excel_export;
             // Default standard foreign keys get added and merged here.
             $foreign_keys = array_merge($this->default_foreign_keys, $model_foreign_keys);
         } else {
             $foreign_keys = $this->default_foreign_keys;
         }
         // Field Inclusion and Exclusion Support
         if (isset($model->excel_exclude_fields)) {
             $model_excel_inclusions = $model->excel_exclude_fields;
             $field_exclusions = array_merge($this->default_field_exclusions, $model_excel_inclusions);
         } else {
             $field_exclusions = $this->default_field_exclusions;
         }
         // If $_GET['search'] is set, only export those items.
         $search = isset($_GET['search']) ? $_GET['search'] : null;
         $search_field = isset($_GET['search_field']) ? $_GET['search_field'] : null;
         if (isset($search) && $search != null) {
             if (!$search_field && $search_field != null) {
                 $acon = NController::factory('asset');
                 $search_field = isset($model->search_field) ? $model->search_field : $acon->search_field;
                 unset($acon);
             }
         }
         $options = $search ? array('conditions' => "{$search_field} LIKE '%{$search}%'") : array();
         // Can set options in the model about items exported to the Excel.
         // Only export items that meet a certain criteria - not everything in the list.
         // For example: $this->viewlist_options = array('conditions'=>"cms_modified_by_user = '******'");
         if (isset($model->viewlist_options)) {
             foreach ($model->viewlist_options as $key => $val) {
                 if (isset($options[$key])) {
                     $options[$key] .= ' AND ' . $val;
                 } else {
                     $options[$key] = "{$val}";
                 }
             }
         }
         if ($model->find($options)) {
             $fields = $model->fields();
             // Add additional custom fields here from the model file.
             if (isset($model->excel_extra_fields)) {
                 foreach ($model->excel_extra_fields as $key => $value) {
                     $fields[] = $key;
                 }
             }
             require_once 'Spreadsheet/Excel/Writer.php';
             // Creating a workbook
             $workbook = new Spreadsheet_Excel_Writer();
             $worksheet =& $workbook->addWorksheet(ucwords(str_replace('_', ' ', $model_name)));
             $worksheet->setColumn(2, 4, 20);
             $worksheet->setColumn(7, 7, 15);
             $worksheet->setColumn(10, 28, 20);
             // Make the title line look a little different
             $title =& $workbook->addFormat();
             $title->setBold();
             $title->setAlign('center');
             $title->setBottom(2);
             // Let's add the field names to the title line.
             // Leave out a few.
             $x = 0;
             $worksheet->setRow(0, 18.75);
             foreach ($fields as $field) {
                 $exclude_this = array_key_exists($field, $field_exclusions);
                 if ($exclude_this && $field_exclusions[$field] == true) {
                     // do nothing
                 } else {
                     $worksheet->write(0, $x, ucwords(str_replace('_', ' ', $field)), $title);
                     $x++;
                 }
             }
             // Now here comes the data.
             $y = 1;
             while ($model->fetch()) {
                 $item = $model->toArray();
                 // For reference while we're working with things.
                 $original_item = array();
                 $original_item = $item;
                 $x = 0;
                 $worksheet->setRow($y, 18.75);
                 foreach ($fields as $field) {
                     $exclude_this = array_key_exists($field, $field_exclusions);
                     if ($exclude_this && $field_exclusions[$field] == true) {
                         // do nothing
                     } else {
                         // Look for foreign keys and replace if assigned.
                         foreach ($foreign_keys as $foreign_key => $foreign_key_value) {
                             if ($field == $foreign_key) {
                                 $fk_model_name = $foreign_key_value[0];
                                 $fk_model_headline = $foreign_key_value[1];
                                 $fk_model = NModel::factory($fk_model_name);
                                 if ($fk_model && $fk_model->get($item[$field])) {
                                     $item[$field] = $fk_model->{$fk_model_headline};
                                 }
                                 unset($fk_model);
                             }
                         }
                         //Look for bitmask fields and replace with string value instead of numeric total
                         if (is_array($model->bitmask_fields) && count($model->bitmask_fields)) {
                             $bitmask_keys = array_keys($model->bitmask_fields);
                             if (in_array($field, $bitmask_keys)) {
                                 $bitmask_total = $item[$field];
                                 $value_str = '';
                                 $i = 0;
                                 foreach ($model->bitmask_fields[$field] as $bit => $val) {
                                     if ($bit & $bitmask_total) {
                                         if ($i > 0) {
                                             $value_str .= ', ';
                                         }
                                         $value_str .= $val;
                                         $i++;
                                     }
                                 }
                                 $item[$field] = $value_str;
                             }
                         }
                         // Any extra fields get dealt with here.
                         if (isset($model->excel_extra_fields)) {
                             foreach ($model->excel_extra_fields as $key => $value) {
                                 if ($field == $key) {
                                     $extra_name = $value[0];
                                     $extra_attribute = $value[1];
                                     $extra_key = $value[2];
                                     $extra_info = NModel::factory($extra_name);
                                     if (method_exists($extra_info, $extra_attribute)) {
                                         $item[$field] = $extra_info->{$extra_attribute}($original_item["{$extra_key}"]);
                                     } else {
                                         $extra_info->get($original_item["{$extra_key}"]);
                                         $item[$field] = $extra_info->{$extra_attribute};
                                     }
                                     unset($extra_info);
                                 }
                             }
                         }
                         // If it's an uploaded file, put the address in the conf.php before it so that it
                         // turns into a link in Excel.
                         if (eregi(UPLOAD_DIR, $item[$field])) {
                             $item[$field] = PUBLIC_SITE . ereg_replace("^/", "", $item[$field]);
                         }
                         $worksheet->write($y, $x, $this->convert_characters($item[$field]));
                         $x++;
                     }
                 }
                 $y++;
                 unset($original_item);
                 unset($item);
             }
             // sending HTTP headers
             $xls_filename = $model_name . '_entries.xls';
             $workbook->send($xls_filename);
             $workbook->close();
         }
     }
 }
 function viewlist($parameter = null)
 {
     $this->auto_render = false;
     $wusers_ctrl =& NController::singleton('workflow_users');
     include_once 'controller/form.php';
     $this->base_dir = APP_DIR;
     $model =& $this->loadModel($this->name);
     $pk = $model->primaryKey();
     if ($model) {
         if ($parameter) {
             $model->{$model->primaryKey()} = $parameter;
         }
         $model->find();
         $rows = $model->fetchAll(true);
         $wusers_model =& $wusers_ctrl->loadModel($wusers_ctrl->name);
         $workflows = '';
         // put the _headline variable in for the viewlist template
         foreach ($rows as $key => $workflow_group) {
             $cform = new ControllerForm($wusers_ctrl, $wusers_model);
             $form =& $cform->getForm('add_person_form_' . $workflow_group[$pk]);
             $form->removeElement('workflow_group_id');
             $form->setDefaults(array('workflow_group_id' => $workflow_group[$pk]));
             $form->addElement('hidden', 'workflow_group_id', $workflow_group[$pk]);
             $form->addElement('hidden', '_referer', urlencode($_SERVER['REQUEST_URI']));
             $cform->makeRemoteForm(array('url' => array('controller' => 'workflow_users', 'action' => 'add_user'), 'loading' => 'workflowManager.addUserLoading(request, ' . $workflow_group[$pk] . ')', 'complete' => 'workflowManager.onAddUser(request, ' . $workflow_group[$pk] . ')'));
             if ($form->validate()) {
                 $fields = $wusers_model->fields();
                 if (in_array('cms_created', $fields)) {
                     $wusers_model->cms_created = $model->now();
                 }
                 if (in_array('cms_modified', $fields)) {
                     $wusers_model->cms_modified = $model->now();
                 }
                 // set the user id if it's applicable and available
                 if (in_array('cms_modified_by_user', $fields)) {
                     $wusers_model->cms_modified_by_user = isset($this->_auth) && is_object($this->_auth) ? $this->_auth->currentUserID() : 0;
                 }
                 $success = $form->process(array($cform, 'processForm'));
             }
             $headline = $model->getHeadline();
             if (!empty($headline)) {
                 if (is_array($headline)) {
                     $workflow_group['_headline'] = '';
                     foreach ($headline as $row) {
                         $workflow_group['_headline'] .= $workflow_group['_headline'] ? ' - ' : '';
                         $workflow_group['_headline'] .= $workflow_group[$row];
                     }
                 } else {
                     $workflow_group['_headline'] = $workflow_group[$headline];
                 }
             } else {
                 $workflow_group['_headline'] = $workflow_group['cms_headline'];
             }
             $workflow_group['_users'] = array();
             $wusers_model->reset();
             $wusers_model->workflow_group_id = $workflow_group[$pk];
             if ($wusers_model->find()) {
                 while ($wusers_model->fetch()) {
                     $user_model =& $wusers_model->getLink('user_id', 'cms_auth');
                     if ($user_model) {
                         $user = $wusers_model->toArray();
                         $user['real_name'] = $user_model->real_name;
                         $workflow_group['_users'][] = $user;
                     }
                 }
             }
             $workflow_group['asset'] = $this->name;
             $workflow_group['add_user_form'] = $form->toHTML();
             $this->set($workflow_group);
             $workflows .= $this->render(array('action' => 'workflow_group', 'return' => true));
             unset($form);
             unset($cform);
         }
         $this->set(array('asset' => $this->name, 'workflows' => $workflows));
         $main_content = $this->render(array('return' => true));
         $sidebar_content = $this->render(array('action' => 'workflow_description', 'return' => true));
     }
     $this->renderLayout('default', $main_content, $sidebar_content);
 }
示例#27
0
 /**
  * auditTrail - Create an RSS feed of audit trail records.
  *		Shows $this->records many records.
  *
  * @return void
  **/
 function auditTrail()
 {
     if (defined('RSS_AUDIT_TRAIL') && RSS_AUDIT_TRAIL) {
         $this->auto_render = false;
         $count = 0;
         $token = $this->getToken();
         // It's got to be 32 characters - this keeps people from trying token=
         if ($length = strlen($token) < 32) {
             die;
         }
         if ($allowed = $this->checkToken($token)) {
             // Grab the last 50 results
             $audit_trail = NModel::factory('cms_audit_trail');
             $options['order_by'] = 'cms_created DESC';
             if ($audit_trail->find($options)) {
                 while ($audit_trail->fetch()) {
                     $audit_trail_controller = NController::factory('audit_trail');
                     $record = $audit_trail_controller->humanizeAuditTrailRecord($audit_trail);
                     //varDump($record);
                     $records[] = $record;
                     $count++;
                     if ($count >= $this->records) {
                         break;
                     }
                 }
             }
             $this->set('records', $records);
             $this->render(array('action' => 'audit_trail'));
         } else {
             print "Unauthorized access";
         }
     }
 }
 function export($model_name)
 {
     if (isset($model_name)) {
         $model = NModel::factory($model_name);
         // Foreign Key Lookup Support
         if (isset($model->excel_export)) {
             $model_foreign_keys = $model->excel_export;
             // Default standard foreign keys get added and merged here.
             $foreign_keys = array_merge($this->default_foreign_keys, $model_foreign_keys);
         } else {
             $foreign_keys = $this->default_foreign_keys;
         }
         // Field Inclusion and Exclusion Support
         if (isset($model->excel_exclude_fields)) {
             $model_excel_inclusions = $model->excel_exclude_fields;
             $field_exclusions = array_merge($this->default_field_exclusions, $model_excel_inclusions);
         } else {
             $field_exclusions = $this->default_field_exclusions;
         }
         // If $_GET['search'] is set, only export those items.
         $search = isset($_GET['search']) ? $_GET['search'] : null;
         $search_field = isset($_GET['search_field']) ? $_GET['search_field'] : null;
         if (isset($search) && $search != null) {
             if (!$search_field && $search_field != null) {
                 $acon = NController::factory('asset');
                 $search_field = isset($model->search_field) ? $model->search_field : $acon->search_field;
                 unset($acon);
             }
         }
         $options = $search ? array('conditions' => "{$search_field} LIKE '%{$search}%'") : array();
         // Can set options in the model about items exported to the Excel.
         // Only export items that meet a certain criteria - not everything in the list.
         // For example: $this->viewlist_options = array('conditions'=>"cms_modified_by_user = '******'");
         if (isset($model->viewlist_options)) {
             foreach ($model->viewlist_options as $key => $val) {
                 if (isset($options[$key])) {
                     $options[$key] .= ' AND ' . $val;
                 } else {
                     $options[$key] = "{$val}";
                 }
             }
         }
         if ($model->find($options)) {
             $fields = $model->fields();
             // Add additional custom fields here from the model file.
             if (isset($model->excel_extra_fields)) {
                 foreach ($model->excel_extra_fields as $key => $value) {
                     $fields[] = $key;
                 }
             }
             // Creating a workbook
             $filename = $_SERVER['DOCUMENT_ROOT'] . UPLOAD_DIR . '/' . rand(1, 1000) . '-file.csv';
             $fp = fopen($filename, 'w');
             // Creating a workbook and sending it directly out to a browser.
             //$fp = fopen('php://output', 'w');
             // Let's add the field names to the title line.
             // Leave out a few.
             $x = 0;
             foreach ($fields as $field) {
                 $exclude_this = array_key_exists($field, $field_exclusions);
                 if ($exclude_this && $field_exclusions[$field] == true) {
                     // do nothing
                 } else {
                     $good_fields[] = $field;
                 }
             }
             //$field_string = implode(',', $good_fields);
             fputcsv($fp, $good_fields);
             // Now here comes the data.
             $y = 1;
             while ($model->fetch()) {
                 $data_fields = array();
                 $item = $model->toArray();
                 // For reference while we're working with things.
                 $original_item = array();
                 $original_item = $item;
                 $x = 0;
                 foreach ($fields as $field) {
                     $exclude_this = array_key_exists($field, $field_exclusions);
                     if ($exclude_this && $field_exclusions[$field] == true) {
                         // do nothing
                     } else {
                         // Look for foreign keys and replace if assigned.
                         foreach ($foreign_keys as $foreign_key => $foreign_key_value) {
                             if ($field == $foreign_key) {
                                 $fk_model_name = $foreign_key_value[0];
                                 $fk_model_headline = $foreign_key_value[1];
                                 $fk_model = NModel::factory($fk_model_name);
                                 if ($fk_model && $fk_model->get($item[$field])) {
                                     $item[$field] = $fk_model->{$fk_model_headline};
                                 }
                                 unset($fk_model);
                             }
                         }
                         //Look for bitmask fields and replace with string value instead of numeric total
                         if (is_array($model->bitmask_fields) && count($model->bitmask_fields)) {
                             $bitmask_keys = array_keys($model->bitmask_fields);
                             if (in_array($field, $bitmask_keys)) {
                                 $bitmask_total = $item[$field];
                                 $value_str = '';
                                 $i = 0;
                                 foreach ($model->bitmask_fields[$field] as $bit => $val) {
                                     if ($bit & $bitmask_total) {
                                         if ($i > 0) {
                                             $value_str .= ', ';
                                         }
                                         $value_str .= $val;
                                         $i++;
                                     }
                                 }
                                 $item[$field] = $value_str;
                             }
                         }
                         // Any extra fields get dealt with here.
                         if (isset($model->excel_extra_fields)) {
                             foreach ($model->excel_extra_fields as $key => $value) {
                                 if ($field == $key) {
                                     $extra_name = $value[0];
                                     $extra_attribute = $value[1];
                                     $extra_key = $value[2];
                                     $extra_info = NModel::factory($extra_name);
                                     if (method_exists($extra_info, $extra_attribute)) {
                                         $item[$field] = $extra_info->{$extra_attribute}($original_item["{$extra_key}"]);
                                     } else {
                                         $extra_info->get($original_item["{$extra_key}"]);
                                         $item[$field] = $extra_info->{$extra_attribute};
                                     }
                                     unset($extra_info);
                                 }
                             }
                         }
                         // If it's an uploaded file, put the address in the conf.php before it so that it
                         // turns into a link in Excel.
                         if (eregi(UPLOAD_DIR, $item[$field])) {
                             $item[$field] = PUBLIC_SITE . ereg_replace("^/", "", $item[$field]);
                         }
                         $fixed_item = $this->convert_characters($item[$field]);
                         $data_fields[] = $fixed_item;
                     }
                 }
                 //$data_string = implode(',', $data_fields);
                 fputcsv($fp, $data_fields);
                 unset($original_item);
                 unset($item);
                 unset($data_fields);
             }
             // Close the file.
             fclose($fp);
             $download = new NDownload();
             $download->serveFile($filename);
             unlink($filename);
         }
     }
 }
 function reorder()
 {
     $id = isset($this->params['id']) ? (int) $this->params['id'] : false;
     if (!$id) {
         return;
     }
     $before = isset($this->params['before']) ? (int) $this->params['before'] : false;
     if (($model =& $this->getDefaultModel()) && $model->get($id)) {
         $pk = $model->primaryKey();
         $page_content_model =& NModel::factory($this->name);
         $page_content_model->page_id = $model->page_id;
         $page_contents = array();
         if ($page_content_model->find()) {
             $before_found = false;
             $item = null;
             while ($page_content_model->fetch()) {
                 if ($page_content_model->{$pk} == $id) {
                     // pull the "id" record out of the array
                     $item = clone $page_content_model;
                 } else {
                     $page_contents[] = clone $page_content_model;
                 }
             }
             if (!$before) {
                 // if there is no before, then the item goes last
                 $page_contents[] = $item;
             } else {
                 // loop through until you find "before" and then splice the "id" in front of it
                 foreach ($page_contents as $key => $page_content) {
                     if ($page_content->{$pk} == $before) {
                         array_splice($page_contents, $key, 1, array($item, $page_content));
                         break;
                     }
                 }
             }
             $i = 0;
             foreach ($page_contents as $key => $page_content) {
                 $page_content->content_order = $i;
                 $page_content->save(false, false);
                 // second false prevents converting time to UTC (unnecessary for a reorder)
                 $i++;
             }
         }
         $page =& NController::singleton('page');
         $page->deletePageCache($model->page_id);
         unset($page);
         unset($page_contents);
         unset($page_content_model);
         unset($model);
     }
 }
 function index($parameter)
 {
     $this->auto_render = false;
     $sidebar_content = $this->render(array('action' => 'description', 'return' => true));
     if (SITE_DRAFTS) {
         $draft_model =& NModel::factory('cms_drafts');
         if ($draft_model) {
             $draft_model->cms_modified_by_user = $this->_auth->currentUserId();
             if ($draft_model->find()) {
                 while ($draft_model->fetch()) {
                     $asset_ctrl =& NController::factory($draft_model->asset);
                     $asset_model =& $draft_model->getLink('asset_id', $draft_model->asset);
                     if ($asset_model) {
                         $this->set(array('draft' => $draft_model->toArray(), 'asset_name' => $asset_ctrl->page_title ? $asset_ctrl->page_title : Inflector::humanize($asset_ctrl->name), 'asset' => $draft_model->asset));
                         $this->set($asset_model->toArray());
                         $this->setAppend('drafts', $this->render(array('action' => 'draft_record', 'return' => true)));
                     }
                     unset($asset_ctrl);
                     unset($asset_model);
                 }
             } else {
                 $this->set('drafts', $this->render(array('action' => 'no_drafts', 'return' => true)));
             }
         }
     }
     // load all workflow output into this variable to be assigned later
     $workflow_html = '';
     if (SITE_WORKFLOW) {
         $sidebar_content .= $this->render(array('action' => 'workflow_description', 'return' => true));
         $user_id = $this->_auth->currentUserId();
         // If user is an admin, and has any unsubmitted workflow in groups they don't belong to, display them first
         if ($this->_auth->getAuthData('user_level') >= N_USER_ADMIN) {
             $workflow =& NController::factory('workflow');
             $workflow_model =& NModel::factory('workflow');
             $workflow_model_pk = $workflow_model->primaryKey();
             $workflow_model->cms_modified_by_user = $user_id;
             $workflow_model->submitted = 0;
             if ($workflow_model->find(array('order_by' => 'page_id'))) {
                 $admin_workflow_html = '';
                 $this->set('workflow_section', 'Unsubmitted Admin Workflows');
                 $workflow_html .= $this->render(array('action' => 'workflow_section', 'return' => true));
                 $page_id = 0;
                 $page_count = 0;
                 $page_workflows = array();
                 while ($workflow_model->fetch()) {
                     $workflow_users_model =& NModel::factory('workflow_users');
                     $workflow_users_model->workflow_group_id = $workflow_model->workflow_group_id;
                     $workflow_users_model->user_id = $workflow_model->cms_modified_by_user;
                     if ($workflow_users_model->find()) {
                         unset($workflow_users_model);
                         continue;
                     }
                     unset($workflow_users_model);
                     $unsubmitted[] = $workflow_model->{$workflow_model_pk};
                     $page_content_model =& NModel::factory('page_content');
                     $page_content_model->get($workflow_model->page_content_id);
                     $page_model =& $page_content_model->getLink('page_id', 'page');
                     $asset_controller =& NController::factory($workflow_model->asset);
                     $asset_model =& $asset_controller->getDefaultModel();
                     $asset_model->get($workflow_model->asset_id);
                     $this->convertDateTimesToClient($asset_model);
                     $action = $workflow->actionToString($workflow_model->action);
                     $cascade_delete = $page_content_model->cms_workflow ? true : false;
                     // set the page title for the following pages
                     $this->set('page_title', '');
                     if ($workflow_model->page_id == $page_id) {
                         $page_count++;
                     } else {
                         $this->set('page_title', $page_model->title);
                         $admin_workflow_html .= $this->workflowPageSubmit($page_workflows);
                         $page_id = $workflow_model->page_id;
                         $page_count = 0;
                         $page_workflows = array();
                     }
                     $page_workflows[] = $workflow_model->{$workflow_model_pk};
                     $user =& $workflow_model->getLink('cms_modified_by_user', 'cms_auth');
                     $this->set(array('process' => 'submit', 'cascade_delete' => $cascade_delete, 'approved' => $workflow_model->approved, 'action' => $action, 'workflow' => $workflow_model->toArray(), 'page' => $page_model->toArray(), 'asset' => $asset_controller, 'row' => $asset_model->toArray(), 'user' => $user ? $user->toArray() : false));
                     $admin_workflow_html .= $this->render(array('action' => 'workflow_record', 'return' => true));
                 }
                 $admin_workflow_html .= $this->workflowPageSubmit($page_workflows);
                 if ($admin_workflow_html) {
                     $this->set(array('workflow_title' => 'Admin Workflows'));
                     $workflow_html .= $this->render(array('action' => 'workflow', 'return' => true)) . $admin_workflow_html;
                     unset($admin_workflow_html);
                 }
             }
             unset($workflow_model);
             unset($workflow);
         }
         $workflow_users =& $this->loadModel('workflow_users');
         $workflow_users->user_id = $user_id;
         if ($workflow_users->find()) {
             while ($workflow_users->fetch()) {
                 // instantiate workflow group object
                 $workflow_group =& $workflow_users->getLink('workflow_group_id', 'workflow_group');
                 // render current workflow group
                 $this->set($workflow_group->toArray());
                 $workflow_html .= $this->render(array('action' => 'workflow', 'return' => true));
                 // instantiate workflow objects
                 $workflow =& NController::factory('workflow');
                 $workflow_model =& $workflow->getDefaultModel();
                 $workflow_model_pk = $workflow_model->primaryKey();
                 // find unsubmitted workflows that belong to this user
                 $workflow_model->submitted = 0;
                 $workflow_model->completed = 0;
                 $workflow_model->workflow_group_id = $workflow_group->{$workflow_group->primaryKey()};
                 $workflow_model->cms_modified_by_user = $user_id;
                 $unsubmitted = array();
                 if ($workflow_model->find(array('order_by' => 'page_id, asset, asset_id, id'))) {
                     $this->set('workflow_section', 'Unsubmitted Workflows');
                     $workflow_html .= $this->render(array('action' => 'workflow_section', 'return' => true));
                     $page_id = 0;
                     $page_count = 0;
                     $page_workflows = array();
                     while ($workflow_model->fetch()) {
                         $unsubmitted[] = $workflow_model->{$workflow_model_pk};
                         $page_content_model =& $workflow_model->getLink('page_content_id', 'page_content');
                         if (!$page_content_model) {
                             continue;
                         }
                         $page_model =& $page_content_model->getLink('page_id', 'page');
                         $asset_controller =& NController::factory($workflow_model->asset);
                         $asset_model =& $asset_controller->getDefaultModel();
                         $asset_model->get($workflow_model->asset_id);
                         $this->convertDateTimesToClient($asset_model);
                         $action = $workflow->actionToString($workflow_model->action);
                         // set the page title for the following pages
                         $this->set('page_title', '');
                         if ($workflow_model->page_id == $page_id) {
                             $page_count++;
                         } else {
                             $this->set('page_title', $page_model->title);
                             $workflow_html .= $this->workflowPageSubmit($page_workflows);
                             $page_id = $workflow_model->page_id;
                             $page_count = 0;
                             $page_workflows = array();
                         }
                         $page_workflows[] = $workflow_model->{$workflow_model_pk};
                         $user =& $workflow_model->getLink('cms_modified_by_user', 'cms_auth');
                         $this->convertDateTimesToClient($workflow_model);
                         $this->set(array('process' => 'submit', 'list_only' => false, 'approved' => $workflow_model->approved, 'action' => $action, 'workflow' => $workflow_model->toArray(), 'page' => $page_model->toArray(), 'asset' => $asset_controller, 'row' => $asset_model->toArray(), 'user' => $user ? $user->toArray() : false));
                         $workflow_html .= $this->render(array('action' => 'workflow_record', 'return' => true));
                     }
                     $workflow_html .= $this->workflowPageSubmit($page_workflows);
                 }
                 // find in process workflows, resetting the model object first
                 $workflow_model->reset();
                 $workflow_model->workflow_group_id = $workflow_group->{$workflow_group->primaryKey()};
                 $workflow_model->completed = 0;
                 $conditions = '';
                 foreach ($unsubmitted as $id) {
                     $conditions .= ($conditions ? ' AND ' : '') . "{$workflow_model_pk}!={$id}";
                 }
                 $this->set('workflow_section', 'Workflows in Process');
                 $workflow_html .= $this->render(array('action' => 'workflow_section', 'return' => true));
                 $workflow_html_content = '';
                 if ($workflow_model->find(array('conditions' => $conditions, 'order_by' => 'page_id, asset, asset_id, id'))) {
                     $workflow_models = array();
                     while ($workflow_model->fetch()) {
                         $workflow_models[] = clone $workflow_model;
                     }
                     $i = 0;
                     $current_asset = '';
                     foreach ($workflow_models as $w_model) {
                         if ($w_model->submitted == 0) {
                             continue;
                         }
                         if ($current_asset != $w_model->asset . $w_model->asset_id) {
                             $current_asset = $w_model->asset . $w_model->asset_id;
                             if (!($page_content_model =& $w_model->getLink('page_content_id', 'page_content'))) {
                                 continue;
                             }
                             if (!($page_model =& $page_content_model->getLink('page_id', 'page'))) {
                                 continue;
                             }
                             $user_def = $workflow->getWorkflowUser($w_model->workflow_group_id);
                             if ($user_def) {
                                 $user_role = $user_def->role;
                                 $user_id = $user_def->user_id;
                             }
                             $user_rights = $workflow->getWorkflowUserRights($page_model);
                             $i = 0;
                         }
                         $asset_controller =& NController::factory($w_model->asset);
                         $asset_model =& $asset_controller->getDefaultModel();
                         $asset_model->get($w_model->asset_id);
                         $this->convertDateTimesToClient($asset_model);
                         $action = $workflow->actionToString($w_model->action);
                         $all_workflow_users = $workflow->getWorkflowUsers($workflow_model->workflow_group_id);
                         if (count($all_workflow_users) < 2) {
                             $i++;
                         }
                         if ($i == 0) {
                             if ($user_rights == WORKFLOW_RIGHT_EDIT) {
                                 $process = 'In Process - ' . ($w_model->approved ? 'Approved' : 'Unapproved');
                             } else {
                                 if ($user_rights & WORKFLOW_RIGHT_EDIT) {
                                     // this is someone with editing rights and more. Could be the same user that submitted it.
                                     $process = $w_model->approved ? 'In Process - Approved' : 'editapprove';
                                 } else {
                                     // This is someone up the line. Let them know something's coming, but they don't need to know what yet.
                                     if ($w_model->approved) {
                                         $process = 'Approved';
                                     } else {
                                         $process = 'A workflow has been started. You will be notified if/when you need to take action.';
                                     }
                                 }
                             }
                         } else {
                             if ($i == 1) {
                                 if ($user_rights == WORKFLOW_RIGHT_EDIT) {
                                     $process = 'In Process - ' . ($w_model->approved ? 'Approved' : 'Unapproved');
                                 } else {
                                     if ($user_rights & WORKFLOW_RIGHT_APPROVE && $user_rights & WORKFLOW_RIGHT_PUBLISH) {
                                         // this is someone with Approval rights. Could be the same user that submitted it
                                         $process = 'approve';
                                     } else {
                                         $process = 'In Process - ' . ($w_model->approved ? 'Approved' : 'Unapproved');
                                     }
                                 }
                             }
                         }
                         $user =& $w_model->getLink('cms_modified_by_user', 'cms_auth');
                         $this->convertDateTimesToClient($w_model);
                         $this->set(array('process' => $process, 'list_only' => false, 'approved' => $w_model->approved, 'action' => $action, 'workflow' => $w_model->toArray(), 'page' => $page_model->toArray(), 'asset' => $asset_controller, 'row' => $asset_model->toArray(), 'user' => $user ? $user->toArray() : false));
                         $workflow_html_content .= $this->render(array('action' => 'workflow_record', 'return' => true));
                         $i++;
                     }
                 }
                 $workflow_html .= $workflow_html_content ? $workflow_html_content : $this->render(array('action' => 'workflow_norecords', 'return' => true));
                 // find completed workflows, resetting the model object first
                 $workflow_model->reset();
                 $workflow_model->workflow_group_id = $workflow_group->{$workflow_group->primaryKey()};
                 $workflow_model->completed = 1;
                 $workflow_model->parent_workflow = 0;
                 // bad timg - shouldn't do this here
                 $workflow_html .= '<div style="background:#EEE;border:1px solid #AAA;padding:4px;">' . "\n";
                 $this->set('workflow_section', 'Completed Workflows');
                 $workflow_html .= $this->render(array('action' => 'workflow_section', 'return' => true));
                 if ($workflow_model->find(array('conditions' => $conditions, 'order_by' => 'cms_created DESC', 'limit' => 5))) {
                     $workflow_models = array();
                     while ($workflow_model->fetch()) {
                         $page_model =& NModel::factory('page');
                         $page_model->{$page_model->primaryKey()} = $workflow_model->page_id;
                         // if the page is not deleted, this works
                         if (!$page_model->find(null, true)) {
                             // otherwise, specify a deleted page and try again
                             $page_model->reset();
                             $page_model->{$page_model->primaryKey()} = $workflow_model->page_id;
                             $page_model->cms_deleted = 1;
                             $page_model->find(null, true);
                         }
                         $page_values = $page_model ? $page_model->toArray() : false;
                         $asset_controller =& NController::factory($workflow_model->asset);
                         $asset_model =& $asset_controller->getDefaultModel();
                         if (!$asset_model->get($workflow_model->asset_id)) {
                             $asset_model->reset();
                             $asset_model->cms_deleted = 1;
                             $asset_model->get($workflow_model->asset_id);
                         }
                         $this->convertDateTimesToClient($asset_model);
                         $action = $workflow->actionToString($workflow_model->action);
                         $user =& $workflow_model->getLink('cms_modified_by_user', 'cms_auth');
                         $this->convertDateTimesToClient($workflow_model);
                         $values = array('process' => null, 'list_only' => true, 'approved' => $workflow_model->approved, 'action' => $action, 'workflow' => $workflow_model->toArray(), 'asset' => $asset_controller, 'row' => $asset_model->toArray(), 'page' => $page_values, 'user' => $user ? $user->toArray() : false);
                         $this->set($values);
                         $workflow_html .= $this->render(array('action' => 'workflow_record', 'return' => true));
                     }
                 }
                 $workflow_html .= '</div>' . "\n";
             }
         } else {
             $workflow_html .= $this->render(array('action' => 'no_workflows', 'return' => true));
         }
         $this->set('workflow', $workflow_html);
     }
     $this->set('SIDEBAR_CONTENT', $sidebar_content);
     $this->setAppend('SIDEBAR_CONTENT', $this->render(array('action' => 'nterchange_training', 'return' => true)));
     $this->setAppend('SIDEBAR_CONTENT', $this->render(array('action' => 'dashboard_client_sidebar_content', 'return' => true)));
     $this->render(array('layout' => 'default'));
 }