"Varchar(255)", "Tagline" => "Varchar(255)", "Theme" => "Varchar(255)", "CanViewType" => "Enum('Anyone, LoggedInUsers, OnlyTheseUsers', 'Anyone')", "CanEditType" => "Enum('LoggedInUsers, OnlyTheseUsers', 'LoggedInUsers')", "CanCreateTopLevelType" => "Enum('LoggedInUsers, OnlyTheseUsers', 'LoggedInUsers')", ); static $many_many = array( "ViewerGroups" => "Group", "EditorGroups" => "Group", "CreateTopLevelGroups" => "Group" ); protected static $disabled_themes = array(); public static function disable_theme($theme) { self::$disabled_themes[$theme] = $theme; } /** * Get the fields that are sent to the CMS. In * your decorators: updateCMSFields(&$fields) * * @return Fieldset */ function getCMSFields() { $fields = new FieldSet( new TabSet("Root", new Tab('Main', $titleField = new TextField("Title", _t('SiteConfig.SITETITLE', "Site title")), $taglineField = new TextField("Tagline", _t('SiteConfig.SITETAGLINE', "Site Tagline/Slogan")), new DropdownField("Theme", _t('SiteConfig.THEME', 'Theme'), $this->getAvailableThemes(), '', null, _t('SiteConfig.DEFAULTTHEME', '(Use default theme)')) ), new Tab('Access', new HeaderField('WhoCanViewHeader', _t('SiteConfig.VIEWHEADER', "Who can view pages on this site?"), 2) ) ) ); $this->extend('updateCMSFields', $fields); return $fields; } /** * Get all available themes that haven't been marked as disabled. * @param string $baseDir Optional alternative theme base directory for testing * @return array of theme directory names */ public function getAvailableThemes($baseDir = null) { $themes = ManifestBuilder::get_themes($baseDir); foreach(self::$disabled_themes as $theme) { if(isset($themes[$theme])) unset($themes[$theme]); } return $themes; } /** * Get the actions that are sent to the CMS. In * your decorators: updateEditFormActions(&$actions) * * @return Fieldset */ function getCMSActions() { if (Permission::check('ADMIN') || Permission::check('EDIT_SITECONFIG')) { $actions = new FieldSet( new FormAction('save_siteconfig', _t('CMSMain.SAVE','Save')) ); } else { $actions = new FieldSet(); } $this->extend('updateCMSActions', $actions); return $actions; } /** * Get the current sites SiteConfig, and creates a new one * through {@link make_site_config()} if none is found. * * @param string $locale * @return SiteConfig */ static function current_site_config($locale = null) { if(Object::has_extension('SiteConfig',"Translatable")){ $locale = isset($locale) ? $locale : Translatable::get_current_locale(); $siteConfig = Translatable::get_one_by_locale('SiteConfig', $locale); } else { $siteConfig = DataObject::get_one('SiteConfig'); } if (!$siteConfig) $siteConfig = self::make_site_config($locale); return $siteConfig; } /** * Setup a default SiteConfig record if none exists */ function requireDefaultRecords() { parent::requireDefaultRecords(); $siteConfig = DataObject::get_one('SiteConfig'); if(!$siteConfig) { self::make_site_config(); DB::alteration_message("Added default site config","created"); } } /** * Create SiteConfig with defaults from language file. * if Translatable is enabled on SiteConfig, see if one already exist * and use those values for the translated defaults. * * @param string $locale * @return SiteConfig */ static function make_site_config($locale = null) { if(!$locale) $locale = Translatable::get_current_locale(); $siteConfig = new SiteConfig(); $siteConfig->Title = _t('SiteConfig.SITENAMEDEFAULT',"Your Site Name"); $siteConfig->Tagline = _t('SiteConfig.TAGLINEDEFAULT',"your tagline here"); if($siteConfig->hasExtension('Translatable')){ $defaultConfig = DataObject::get_one('SiteConfig'); if($defaultConfig){ $siteConfig->Title = $defaultConfig->Title; $siteConfig->Tagline = $defaultConfig->Tagline; } // TODO Copy view/edit group settings // set the correct Locale $siteConfig->Locale = $locale; } $siteConfig->write(); return $siteConfig; } /** * Can a user view pages on this site? This method is only * called if a page is set to Inherit, but there is nothing * to inherit from. * * @param mixed $member * @return boolean */ public function canView($member = null) { if(!$member) $member = Member::currentUserID(); if($member && is_numeric($member)) $member = DataObject::get_by_id('Member', $member); if (!$this->CanViewType || $this->CanViewType == 'Anyone') return true; // check for any logged-in users if($this->CanViewType == 'LoggedInUsers' && $member) return true; // check for specific groups if($this->CanViewType == 'OnlyTheseUsers' && $member && $member->inGroups($this->ViewerGroups())) return true; return false; } /** * Can a user edit pages on this site? This method is only * called if a page is set to Inherit, but there is nothing * to inherit from. * * @param mixed $member * @return boolean */ public function canEdit($member = null) { if(!$member) $member = Member::currentUserID(); if($member && is_numeric($member)) $member = DataObject::get_by_id('Member', $member); // check for any logged-in users if(!$this->CanEditType || $this->CanEditType == 'LoggedInUsers' && $member) return true; // check for specific groups if($this->CanEditType == 'OnlyTheseUsers' && $member && $member->inGroups($this->EditorGroups())) return true; return false; } function providePermissions() { return array( 'EDIT_SITECONFIG' => array( 'name' => _t('SiteConfig.EDIT_PERMISSION', 'Manage site configuration'), 'category' => _t('Permissions.PERMISSIONS_CATEGORY', 'Roles and access permissions'), 'help' => _t('SiteConfig.EDIT_PERMISSION_HELP', 'Ability to edit global access settings/top-level page permissions.'), 'sort' => 400 ) ); } /** * Can a user create pages in the root of this site? * * @param mixed $member * @return boolean */ public function canCreateTopLevel($member = null) { if(!$member || !(is_a($member, 'Member')) || is_numeric($member)) { $member = Member::currentUserID(); } if (Permission::check('ADMIN')) return true; // check for any logged-in users if($this->CanCreateTopLevelType == 'LoggedInUsers' && $member) return true; // check for specific groups if($member && is_numeric($member)) $member = DataObject::get_by_id('Member', $member); if($this->CanCreateTopLevelType == 'OnlyTheseUsers' && $member && $member->inGroups($this->CreateTopLevelGroups())) return true; return false; } }