本文整理匯總了PHP中Frontend\Core\Engine\Model::get方法的典型用法代碼示例。如果您正苦於以下問題:PHP Model::get方法的具體用法?PHP Model::get怎麽用?PHP Model::get使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Frontend\Core\Engine\Model
的用法示例。
在下文中一共展示了Model::get方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: getCM
/**
* Returns the CampaignMonitor object
*
* @param int $listId The default list id to use.
* @return \CampaignMonitor
*/
public static function getCM($listId = null)
{
// campaignmonitor reference exists
if (!FrontendModel::getContainer()->has('campaignmonitor')) {
// check if the CampaignMonitor class exists
if (!file_exists(PATH_LIBRARY . '/external/campaignmonitor.php')) {
// the class doesn't exist, so throw an exception
throw new FrontendException('The CampaignMonitor wrapper class is not found. Please
locate and place it in /library/external');
}
// require CampaignMonitor class
require_once PATH_LIBRARY . '/external/campaignmonitor.php';
// set login data
$url = FrontendModel::get('fork.settings')->get('Mailmotor', 'cm_url');
$username = FrontendModel::get('fork.settings')->get('Mailmotor', 'cm_username');
$password = FrontendModel::get('fork.settings')->get('Mailmotor', 'cm_password');
// init CampaignMonitor object
$cm = new \CampaignMonitor($url, $username, $password, 5, self::getClientId());
// set CampaignMonitor object reference
FrontendModel::getContainer()->set('campaignmonitor', $cm);
// get the default list ID
$listId = !empty($listId) ? $listId : self::getDefaultListID();
// set the default list ID
$cm->setListId($listId);
}
// return the CampaignMonitor object
return FrontendModel::getContainer()->get('campaignmonitor');
}
示例2: get
/**
* Fetches a certain item
*
* @param string $id
* @return array
*/
public static function get($id)
{
$item = (array) FrontendModel::get('database')->getRecord('SELECT i.*
FROM instagram_users AS i
WHERE i.id = ? AND i.hidden = ?', array((int) $id, 'N'));
// no results?
if (empty($item)) {
return array();
}
return $item;
}
示例3: execute
/**
* Execute the action
*/
public function execute()
{
parent::execute();
// Get POST parameters
$userId = \SpoonFilter::getPostValue('userId', null, '');
// Get count settings
$this->recentCount = FrontendModel::get('fork.settings')->get('Instagram', 'num_recent_items', 10);
// Get the images from the Instagram API
$this->images = FrontendInstagramModel::getRecentMedia($userId, $this->recentCount);
// Output the result
$this->output(self::OK, $this->images);
}
示例4: onFormSubmitted
/**
* @param FormBuilderSubmittedEvent $event
*/
public function onFormSubmitted(FormBuilderSubmittedEvent $event)
{
$form = $event->getForm();
// need to send mail
if ($form['method'] == 'database_email') {
// build our message
$from = FrontendModel::get('fork.settings')->get('Core', 'mailer_from');
$fieldData = $this->getEmailFields($event->getData());
$message = \Common\Mailer\Message::newInstance(sprintf(FL::getMessage('FormBuilderSubject'), $form['name']))->parseHtml(FRONTEND_MODULES_PATH . '/FormBuilder/Layout/Templates/Mails/Form.tpl', array('sentOn' => time(), 'name' => $form['name'], 'fields' => $fieldData), true)->setTo($form['email'])->setFrom(array($from['email'] => $from['name']));
// check if we have a replyTo email set
foreach ($form['fields'] as $field) {
if (array_key_exists('reply_to', $field['settings']) && $field['settings']['reply_to'] === true) {
$email = $fieldData[$field['id']]['value'];
$message->setReplyTo(array($email => $email));
}
}
if ($message->getReplyTo() === null) {
$replyTo = FrontendModel::get('fork.settings')->get('Core', 'mailer_reply_to');
$message->setReplyTo(array($replyTo['email'] => $replyTo['name']));
}
$this->mailer->send($message);
}
}
示例5: __construct
/**
* The constructor will store the instance in the reference, preset some settings and map the custom modifiers.
*/
public function __construct()
{
parent::__construct(func_get_arg(0), func_get_arg(1), func_get_arg(2));
$this->debugMode = Model::getContainer()->getParameter('kernel.debug');
$this->forkSettings = Model::get('fork.settings');
// fork has been installed
if ($this->forkSettings) {
$this->themePath = FRONTEND_PATH . '/Themes/' . $this->forkSettings->get('Core', 'theme', 'default');
$loader = $this->environment->getLoader();
$loader = new \Twig_Loader_Chain(array($loader, new \Twig_Loader_Filesystem($this->getLoadingFolders())));
$this->environment->setLoader($loader);
// connect symphony forms
$formEngine = new TwigRendererEngine($this->getFormTemplates('FormLayout.html.twig'));
$formEngine->setEnvironment($this->environment);
$this->environment->addExtension(new SymfonyFormExtension(new TwigRenderer($formEngine, Model::get('security.csrf.token_manager'))));
}
$this->environment->disableStrictVariables();
// init Form extension
new FormExtension($this->environment);
// start the filters / globals
TwigFilters::getFilters($this->environment, 'Frontend');
$this->startGlobals($this->environment);
}
示例6: __construct
/**
* The default constructor
*
* @param string $title The title off the feed.
* @param string $link The link of the feed.
* @param string $description The description of the feed.
* @param array $items An array with SpoonRSSItems.
*/
public function __construct($title, $link, $description, array $items = array())
{
// decode
$title = \SpoonFilter::htmlspecialcharsDecode($title);
$description = \SpoonFilter::htmlspecialcharsDecode($description);
// call the parent
parent::__construct($title, Model::addURLParameters($link, array('utm_source' => 'feed', 'utm_medium' => 'rss', 'utm_campaign' => CommonUri::getUrl($title))), $description, $items);
$siteTitle = \SpoonFilter::htmlspecialcharsDecode(Model::get('fork.settings')->get('Core', 'site_title_' . LANGUAGE));
// set feed properties
$this->setLanguage(LANGUAGE);
$this->setCopyright(\SpoonDate::getDate('Y') . ' ' . $siteTitle);
$this->setGenerator($siteTitle);
$this->setImage(SITE_URL . FRONTEND_CORE_URL . '/Layout/images/rss_image.png', $title, $link);
// theme was set
if (Model::get('fork.settings')->get('Core', 'theme', null) != null) {
// theme name
$theme = Model::get('fork.settings')->get('Core', 'theme', null);
// theme rss image exists
if (is_file(PATH_WWW . '/src/Frontend/Themes/' . $theme . '/Core/images/rss_image.png')) {
// set rss image
$this->setImage(SITE_URL . '/src/Frontend/Themes/' . $theme . '/Core/images/rss_image.png', $title, $link);
}
}
}
示例7: timeAgo
/**
* Formats a timestamp as a string that indicates the time ago
* syntax: {$var|timeago}
*
* @param string $var A UNIX-timestamp that will be formatted as a time-ago-string.
* @return string
*/
public static function timeAgo($var = null)
{
$var = (int) $var;
// invalid timestamp
if ($var == 0) {
return '';
}
// return
return '<abbr title="' . \SpoonDate::getDate(Model::get('fork.settings')->get('Core', 'date_format_long') . ', ' . Model::get('fork.settings')->get('Core', 'time_format'), $var, FRONTEND_LANGUAGE) . '">' . \SpoonDate::getTimeAgo($var, FRONTEND_LANGUAGE) . '</abbr>';
}
示例8: validateForm
/**
* Validate the form
*
* @return void
*/
private function validateForm()
{
// is the form submitted
if ($this->frm->isSubmitted()) {
// validate required fields
$email = $this->frm->getField('email');
// validate required fields
if ($email->isEmail(FL::err('EmailIsInvalid'))) {
if (FrontendModel::get('mailmotor.member')->isSubscribed($email->getValue())) {
$email->addError(FL::err('AlreadySubscribed'));
}
// we need to add this because the line below.
// $this->frm->getErrors() only checks if form errors are set, not if an element in the form has errors.
} else {
$this->frm->addError(FL::err('AlreadySubscribed'));
}
// no errors?
if ($this->frm->isCorrect()) {
// build
$mergeVars = array();
try {
// subscribe the user to our default group
FrontendModel::get('mailmotor.member')->subscribe($email->getValue(), null, $mergeVars);
// trigger event
FrontendModel::triggerEvent('MailMotor', 'after_subscribe', array('email' => $email->getValue()));
// redirect
$this->redirect(FrontendNavigation::getURLForBlock('MailMotor', 'Subscribe') . '?sent=true#mailMotorSubscribeForm');
} catch (Exception $e) {
// when debugging we need to see the exceptions
if (\SPOON_DEBUG) {
throw $e;
}
// show error
$this->tpl->assign('mailMotorSubscribeHasError', true);
}
// show errors
} else {
$this->tpl->assign('mailMotorSubscribeHasFormError', true);
}
}
}
示例9: getAccessToken
/**
* Get the access token from the settings
*
* @return String Access token
*/
private static function getAccessToken()
{
return FrontendModel::get('fork.settings')->get('Instagram', 'access_token');
}
示例10: getNavigationHTML
/**
* Get navigation HTML
*
* @param string $type The type of navigation the HTML should be build for.
* @param int $parentId The parentID to start of.
* @param int $depth The maximum depth to parse.
* @param array $excludeIds PageIDs to be excluded.
* @param string $template The template that will be used.
* @param int $depthCounter A counter that will hold the current depth.
*
* @return string
* @throws Exception
*/
public static function getNavigationHTML($type = 'page', $parentId = 0, $depth = null, $excludeIds = array(), $template = '/Core/Layout/Templates/Navigation.html.twig', $depthCounter = 1)
{
// get navigation
$navigation = self::getNavigation();
// merge the exclude ids with the previously set exclude ids
$excludeIds = array_merge((array) $excludeIds, self::$excludedPageIds);
// meta-navigation is requested but meta isn't enabled
if ($type == 'meta' && (!Model::get('fork.settings')->get('Pages', 'meta_navigation', true) || !isset($navigation['meta']))) {
return '';
}
// validate
if (!isset($navigation[$type])) {
throw new Exception('This type (' . $type . ') isn\'t a valid navigation type. Possible values are: page, footer, meta.');
}
if (!isset($navigation[$type][$parentId])) {
throw new Exception('The parent (' . $parentId . ') doesn\'t exists.');
}
// special construction to merge home with its immediate children
$mergedHome = false;
while (true) {
// loop elements
foreach ($navigation[$type][$parentId] as $id => $page) {
// home is a special item, it should live on the same depth
if ($page['page_id'] == 1 && !$mergedHome) {
// extra checks otherwise exceptions will wbe triggered.
if (!isset($navigation[$type][$parentId]) || !is_array($navigation[$type][$parentId])) {
$navigation[$type][$parentId] = array();
}
if (!isset($navigation[$type][$page['page_id']]) || !is_array($navigation[$type][$page['page_id']])) {
$navigation[$type][$page['page_id']] = array();
}
// add children
$navigation[$type][$parentId] = array_merge($navigation[$type][$parentId], $navigation[$type][$page['page_id']]);
// mark as merged
$mergedHome = true;
// restart loop
continue 2;
}
// not hidden and not an action
if ($page['hidden'] || $page['tree_type'] == 'direct_action') {
unset($navigation[$type][$parentId][$id]);
continue;
}
// authentication
if (isset($page['data'])) {
// unserialize data
$page['data'] = unserialize($page['data']);
// if auth_required isset and is true
if (isset($page['data']['auth_required']) && $page['data']['auth_required']) {
// is profile logged? unset
if (!FrontendAuthentication::isLoggedIn()) {
unset($navigation[$type][$parentId][$id]);
continue;
}
// check if group auth is set
if (!empty($page['data']['auth_groups'])) {
$inGroup = false;
// loop group and set value true if one is found
foreach ($page['data']['auth_groups'] as $group) {
if (FrontendAuthentication::getProfile()->isInGroup($group)) {
$inGroup = true;
}
}
// unset page if not in any of the groups
if (!$inGroup) {
unset($navigation[$type][$parentId][$id]);
}
}
}
}
// some ids should be excluded
if (in_array($page['page_id'], (array) $excludeIds)) {
unset($navigation[$type][$parentId][$id]);
continue;
}
// if the item is in the selected page it should get an selected class
if (in_array($page['page_id'], self::$selectedPageIds)) {
$navigation[$type][$parentId][$id]['selected'] = true;
} else {
$navigation[$type][$parentId][$id]['selected'] = false;
}
// add nofollow attribute if needed
if ($page['no_follow']) {
$navigation[$type][$parentId][$id]['nofollow'] = true;
} else {
$navigation[$type][$parentId][$id]['nofollow'] = false;
}
//.........這裏部分代碼省略.........
示例11: getTemplateContent
/**
* Returns the content from a given template
*
* @param string $template The template to use.
* @param array $variables The variables to assign.
*
* @return string
*/
private function getTemplateContent($template, $variables = null)
{
// with the strpos we check if it is a frontend template, in that case we use the frontend template to prevent
// errors that the template could not be found. This way we don't have a backwards compatibility break.
if (APPLICATION !== 'Backend' || strpos($template, FRONTEND_CORE_PATH) !== false) {
return Model::get('templating')->render($template, $variables);
}
$tpl = new BackendTemplate(false);
// variables were set
if (!empty($variables)) {
$tpl->assign($variables);
}
// grab the content
return $tpl->getContent($template);
}
示例12: getRedirectLanguages
/**
* Get the redirect languages
*
* @return array
*/
public static function getRedirectLanguages()
{
// validate the cache
if (empty(self::$languages['possible_redirect'])) {
// grab from settings
$redirectLanguages = (array) Model::get('fork.settings')->get('Core', 'redirect_languages');
// store in cache
self::$languages['possible_redirect'] = $redirectLanguages;
}
// return
return self::$languages['possible_redirect'];
}
示例13: search
/**
* Search
* The actual search will be performed by the execSearch() method.
* It will then pass on the results to the specific modules, which are then
* responsible for returning the required data and filtering out unwanted
* results (entries that should not be shown)
* The activation/deactivation of search indices will automatically be
* handled by this function to keep the search index up to date, based on
* the module's returned results
*
* This function can be called with either a string as parameter (simple
* search) or an array (advanced search)
* Simple search: all search index fields will be searched for the given
* term
* Advanced search: only the given fields (keys in the array) will be
* matched to the corresponding values (corresponding values in the array)
*
* @param string $term The search term (simple search) or the fields to
* search for (advanced search - please note that the
* field names may not be consistent throughout
* several modules).
* @param int $limit The number of articles to get.
* @param int $offset The offset.
* @return array
*/
public static function search($term, $limit = 20, $offset = 0)
{
// revalidate searches
if (FrontendModel::get('fork.settings')->get('Search', 'validate_search', true) == true) {
self::validateSearch();
}
// @note: on heavy sites with a lot of inactive search indices better
// use a cronjob (which will automatically set this module setting to N)
// execute the actual search
$searchResults = self::execSearch($term, $limit, $offset);
// get the total amount of results (we'll get back to this later ;) )
$total = count($searchResults);
// none found? return empty :(
if (!$searchResults) {
return array();
}
// prepare to send to modules
$moduleResults = array();
// loop the result set
foreach ($searchResults as $searchResult) {
$moduleResults[$searchResult['module']][] = $searchResult['other_id'];
}
// pass the results to the modules
foreach ($moduleResults as $module => $otherIds) {
// check if this module actually is prepared to handle searches
$class = 'Frontend\\Modules\\' . $module . '\\Engine\\Model';
if (is_callable(array($class, 'search'))) {
// get the required info from our module
$moduleResults[$module] = call_user_func(array($class, 'search'), $otherIds);
} else {
// does not exist, let's get this module out of here
unset($moduleResults[$module]);
}
}
// now place the prepared data back in our original result set, which has our results in correct order
foreach ($searchResults as $i => $result) {
// loop parsed results for this specific module to find the one we want here
foreach ($moduleResults[$result['module']] as $otherId => $moduleResult) {
// that's the one..
if ($otherId == $result['other_id']) {
$searchResults[$i] = array_merge(array('module' => $result['module']), $moduleResult);
continue 2;
}
}
// if we made it here, we obviously did not get this result parsed by the module, so remove it!
unset($searchResults[$i]);
self::statusIndex($result['module'], (array) $result['other_id'], false);
}
// results got removed by the module? oh noes :o have another run,
// because now we've deactivated those responsible for the holes :)
if (count($searchResults) < $total && $total == $limit) {
$searchResults = self::search($term, $limit, $offset);
}
// return results
return $searchResults;
}
示例14: getAvatar
/**
* Get avatar
*
* @param int $id The id for the profile we want to get the avatar from.
* @param string $email The email from the user we can use for gravatar.
* @param string $size The resolution you want to use. Default: 240x240 pixels.
* @return string $avatar The absolute path to the avatar.
*/
public static function getAvatar($id, $email = null, $size = '240x240')
{
// redefine id
$id = (int) $id;
// return avatar from cache
if (isset(self::$avatars[$id])) {
return self::$avatars[$id];
}
// define avatar path
$avatarPath = FRONTEND_FILES_URL . '/Profiles/Avatars/' . $size . '/';
// get user
$user = self::get($id);
// if no email is given
if (!$email) {
// redefine email
$email = $user->getEmail();
}
// define avatar
$avatar = $user->getSetting('avatar');
// no custom avatar defined, get gravatar if allowed
if (empty($avatar) && FrontendModel::get('fork.settings')->get('Profiles', 'allow_gravatar', true)) {
// define hash
$hash = md5(strtolower(trim('d' . $email)));
// define avatar url
$avatar = 'http://www.gravatar.com/avatar/' . $hash;
// when email not exists, it has to show our custom no-avatar image
$avatar .= '?d=' . urlencode(SITE_URL . $avatarPath) . 'no-avatar.gif';
} elseif (empty($avatar)) {
// define avatar as not found
$avatar = SITE_URL . $avatarPath . 'no-avatar.gif';
} else {
// define custom avatar path
$avatar = $avatarPath . $avatar;
}
// set avatar in cache
self::$avatars[$id] = $avatar;
// return avatar image path
return $avatar;
}
示例15: cleanupPlainText
/**
* Formats plain text as HTML, links will be detected, paragraphs will be inserted
* syntax: {{ $string|cleanupPlainText }}.
*
* @param string $string The text to cleanup.
*
* @return string
*/
public static function cleanupPlainText($string)
{
// redefine
$string = (string) $string;
// detect links
$string = \SpoonFilter::replaceURLsWithAnchors($string, FrontendModel::get('fork.settings')->get('Core', 'seo_nofollow_in_comments', false));
// replace newlines
$string = str_replace("\r", '', $string);
$string = preg_replace('/(?<!.)(\\r\\n|\\r|\\n){3,}$/m', '', $string);
// replace br's into p's
$string = '<p>' . str_replace("\n", '</p><p>', $string) . '</p>';
// cleanup
$string = str_replace("\n", '', $string);
$string = str_replace('<p></p>', '', $string);
// return
return $string;
}