當前位置: 首頁>>代碼示例>>PHP>>正文


PHP CakeRequest::is方法代碼示例

本文整理匯總了PHP中CakeRequest::is方法的典型用法代碼示例。如果您正苦於以下問題:PHP CakeRequest::is方法的具體用法?PHP CakeRequest::is怎麽用?PHP CakeRequest::is使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在CakeRequest的用法示例。


在下文中一共展示了CakeRequest::is方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: getUser

 public function getUser(CakeRequest $request)
 {
     if ($request->is('post') && isset($request->data['password'])) {
         $password = $request->data['password'];
         if ($this->checkPassword($password)) {
             return array('loggedin' => true);
         } else {
             throw new ForbiddenException(__('Wrong Password'));
         }
     }
     return false;
 }
開發者ID:apeunit,項目名稱:Krill,代碼行數:12,代碼來源:SuperSimpleAuthenticate.php

示例2: requestedWith

 /**
  * Determines the content type of the data the client has sent (i.e. in a POST request)
  *
  * @param mixed $type Can be null (or no parameter), a string type name, or an array of types
  * @return mixed If a single type is supplied a boolean will be returned.  If no type is provided
  *   The mapped value of CONTENT_TYPE will be returned. If an array is supplied the first type
  *   in the request content type will be returned.
  */
 public function requestedWith($type = null)
 {
     if (!$this->request->is('post') && !$this->request->is('put')) {
         return null;
     }
     list($contentType) = explode(';', env('CONTENT_TYPE'));
     if ($type == null) {
         return $this->mapType($contentType);
     } elseif (is_array($type)) {
         foreach ($type as $t) {
             if ($this->requestedWith($t)) {
                 return $t;
             }
         }
         return false;
     } elseif (is_string($type)) {
         return $type == $this->mapType($contentType);
     }
 }
開發者ID:gilyaev,項目名稱:framework-bench,代碼行數:27,代碼來源:RequestHandlerComponent.php

示例3: configureApiAccess

 /**
  * Ensures that the current request is validated for Authentication
  *
  * @return void
  */
 protected function configureApiAccess()
 {
     if (isset($this->settings['auth']) && !$this->settings['auth']) {
         return true;
     }
     if ($this->hasError()) {
         return;
     }
     // Do not require authentication if the request isn't considered API
     if (!$this->request->is('api')) {
         return;
     }
     // If its a public action, do not enforce API security checks
     if (in_array($this->controller->action, $this->publicActions)) {
         return;
     }
     // If the user has a isAuthorizedApi method, call it and don't check anything else
     if (method_exists($this->controller, 'isAuthorizedApi')) {
         if (!$this->controller->isAuthorizedApi()) {
             throw new ForbiddenException('Permission denied');
         }
         return;
     }
     // Do not enforce authentication if the request is already authenticated
     if ($this->controller->Auth && $this->controller->Auth->user()) {
         return;
     }
     // Get the access token, if any
     $token = ApiUtility::getRequestToken($this->request);
     // Deny access if no AccessToken is provided
     if (empty($token)) {
         throw new ForbiddenException('Permission denied, missing access token');
     }
     // Deny access if the AccessToken isn't valid
     if (!$this->controller->Auth->login()) {
         throw new ForbiddenException('Permission denied, invalid access token');
     }
 }
開發者ID:nodesagency,項目名稱:Platform-API-plugin,代碼行數:43,代碼來源:ApiComponent.php

示例4: _deleteAction

 /**
  * Generic delete action
  *
  * Triggers the following callbacks
  *	- beforeFind
  *	- recordNotFound
  *	- beforeDelete
  *	- afterDelete
  *
  * @param string $id
  * @return void
  */
 protected function _deleteAction($id = null)
 {
     if (empty($id)) {
         $id = $this->getIdFromRequest();
     }
     $this->_validateId($id);
     if (!$this->_request->is('delete') && !($this->_request->is('post') && false === $this->config('secureDelete'))) {
         $subject = $this->_getSubject(compact('id'));
         $this->_setFlash('invalid_http_request.error');
         return $this->_redirect($subject, $this->_controller->referer(array('action' => 'index')));
     }
     $query = array();
     $query['conditions'] = array($this->_model->escapeField() => $id);
     $findMethod = $this->_getFindMethod(null, 'count');
     $subject = $this->trigger('beforeFind', compact('id', 'query', 'findMethod'));
     $query = $subject->query;
     $count = $this->_model->find($subject->findMethod, $query);
     if (empty($count)) {
         $subject = $this->trigger('recordNotFound', compact('id'));
         $this->_setFlash('find.error');
         return $this->_redirect($subject, $this->_controller->referer(array('action' => 'index')));
     }
     $subject = $this->trigger('beforeDelete', compact('id'));
     if ($subject->stopped) {
         $this->_setFlash('delete.error');
         return $this->_redirect($subject, $this->_controller->referer(array('action' => 'index')));
     }
     if ($this->_model->delete($id)) {
         $this->_setFlash('delete.success');
         $subject = $this->trigger('afterDelete', array('id' => $id, 'success' => true));
     } else {
         $this->_setFlash('delete.error');
         $subject = $this->trigger('afterDelete', array('id' => $id, 'success' => false));
     }
     return $this->_redirect($subject, $this->_controller->referer(array('action' => 'index')));
 }
開發者ID:nodesagency,項目名稱:Platform-Crud-Plugin,代碼行數:48,代碼來源:CrudComponent.php

示例5: _secureRequired

 /**
  * Check if access requires secure connection
  *
  * @param Controller $controller Instantiating controller
  * @return bool True if secure connection required
  */
 protected function _secureRequired(Controller $controller)
 {
     if (is_array($this->requireSecure) && !empty($this->requireSecure)) {
         $requireSecure = $this->requireSecure;
         if (in_array($this->_action, $requireSecure) || $this->requireSecure === array('*')) {
             if (!$this->request->is('ssl')) {
                 if (!$this->blackHole($controller, 'secure')) {
                     return false;
                 }
             }
         }
     }
     return true;
 }
開發者ID:noibilism,項目名稱:nst_portal,代碼行數:20,代碼來源:SecurityComponent.php

示例6: testIsRequested

 /**
  * Test is('requested') and isRequested()
  *
  * @return void
  */
 public function testIsRequested()
 {
     $request = new CakeRequest('/posts/index');
     $request->addParams(array('controller' => 'posts', 'action' => 'index', 'plugin' => null, 'requested' => 1));
     $this->assertTrue($request->is('requested'));
     $this->assertTrue($request->isRequested());
     $request = new CakeRequest('/posts/index');
     $request->addParams(array('controller' => 'posts', 'action' => 'index', 'plugin' => null));
     $this->assertFalse($request->is('requested'));
     $this->assertFalse($request->isRequested());
 }
開發者ID:xMyThoLoGyx,項目名稱:centremedicaletp3,代碼行數:16,代碼來源:CakeRequestTest.php

示例7: _scaffoldDelete

/**
 * Performs a delete on given scaffolded Model.
 *
 * @param CakeRequest $request Request for scaffolding
 * @return mixed Success on delete, error if delete fails
 * @throws MethodNotAllowedException When HTTP method is not a DELETE
 * @throws NotFoundException When id being deleted does not exist.
 */
	protected function _scaffoldDelete(CakeRequest $request) {
		if ($this->controller->beforeScaffold('delete')) {
			if (!$request->is('post')) {
				throw new MethodNotAllowedException();
			}
			$id = false;
			if (isset($request->params['pass'][0])) {
				$id = $request->params['pass'][0];
			}
			$this->ScaffoldModel->id = $id;
			if (!$this->ScaffoldModel->exists()) {
				throw new NotFoundException(__d('cake', 'Invalid %s', Inflector::humanize($this->modelClass)));
			}
			if ($this->ScaffoldModel->delete()) {
				$message = __d('cake', 'The %1$s with id: %2$s has been deleted.', Inflector::humanize($this->modelClass), $id);
				return $this->_sendMessage($message);
			} else {
				$message = __d('cake',
					'There was an error deleting the %1$s with id: %2$s',
					Inflector::humanize($this->modelClass),
					$id
				);
				return $this->_sendMessage($message);
			}
		} elseif ($this->controller->scaffoldError('delete') === false) {
			return $this->_scaffoldError();
		}
	}
開發者ID:hungnt88,項目名稱:5stars-1,代碼行數:36,代碼來源:Scaffold.php

示例8: isLoginDataAvailable

 public function isLoginDataAvailable(CakeRequest $request)
 {
     return $request->is('post');
 }
開發者ID:asadaqain,項目名稱:Guide-on-the-Side,代碼行數:4,代碼來源:LocalAuthenticate.php

示例9: cors

 /**
  * Setup access for origin and methods on cross origin requests
  *
  * This method allow multiple ways to setup the domains, see the examples
  *
  * ### Full URI
  * e.g `cors($request, 'http://www.cakephp.org');`
  *
  * ### URI with wildcard
  * e.g `cors($request, 'http://*.cakephp.org');`
  *
  * ### Ignoring the requested protocol
  * e.g `cors($request, 'www.cakephp.org');`
  *
  * ### Any URI
  * e.g `cors($request, '*');`
  *
  * ### Whitelist of URIs
  * e.g `cors($request, array('http://www.cakephp.org', '*.google.com', 'https://myproject.github.io'));`
  *
  * @param CakeRequest $request Request object
  * @param string|array $allowedDomains List of allowed domains, see method description for more details
  * @param string|array $allowedMethods List of HTTP verbs allowed
  * @param string|array $allowedHeaders List of HTTP headers allowed
  * @return void
  */
 public function cors(CakeRequest $request, $allowedDomains, $allowedMethods = array(), $allowedHeaders = array())
 {
     $origin = $request->header('Origin');
     if (!$origin) {
         return;
     }
     $allowedDomains = $this->_normalizeCorsDomains((array) $allowedDomains, $request->is('ssl'));
     foreach ($allowedDomains as $domain) {
         if (!preg_match($domain['preg'], $origin)) {
             continue;
         }
         $this->header('Access-Control-Allow-Origin', $domain['original'] === '*' ? '*' : $origin);
         $allowedMethods && $this->header('Access-Control-Allow-Methods', implode(', ', (array) $allowedMethods));
         $allowedHeaders && $this->header('Access-Control-Allow-Headers', implode(', ', (array) $allowedHeaders));
         break;
     }
 }
開發者ID:xplico,項目名稱:CapAnalysis,代碼行數:43,代碼來源:CakeResponse.php

示例10: testAddDetector

 /**
  * test adding detectors and having them work.
  *
  * @return void
  */
 function testAddDetector()
 {
     $request = new CakeRequest('some/path');
     $request->addDetector('compare', array('env' => 'TEST_VAR', 'value' => 'something'));
     $_SERVER['TEST_VAR'] = 'something';
     $this->assertTrue($request->is('compare'), 'Value match failed.');
     $_SERVER['TEST_VAR'] = 'wrong';
     $this->assertFalse($request->is('compare'), 'Value mis-match failed.');
     $request->addDetector('banana', array('env' => 'TEST_VAR', 'pattern' => '/^ban.*$/'));
     $_SERVER['TEST_VAR'] = 'banana';
     $this->assertTrue($request->isBanana());
     $_SERVER['TEST_VAR'] = 'wrong value';
     $this->assertFalse($request->isBanana());
     $request->addDetector('mobile', array('options' => array('Imagination')));
     $_SERVER['HTTP_USER_AGENT'] = 'Imagination land';
     $this->assertTrue($request->isMobile());
     $_SERVER['HTTP_USER_AGENT'] = 'iPhone 3.0';
     $this->assertTrue($request->isMobile());
     $request->addDetector('callme', array('env' => 'TEST_VAR', 'callback' => array($this, '_detectCallback')));
     $request->return = true;
     $this->assertTrue($request->isCallMe());
     $request->return = false;
     $this->assertFalse($request->isCallMe());
 }
開發者ID:robotarmy,項目名稱:Phog,代碼行數:29,代碼來源:cake_request.test.php

示例11: authorize

 /**
  * check request request authorization
  *
  */
 public function authorize($user, CakeRequest $request)
 {
     // Admin role is allowed to perform all actions, bypassing ACL
     if ($this->_isAdmin($user)) {
         return true;
     }
     $allowed = false;
     $Acl = $this->_Collection->load('Acl');
     list($plugin, $userModel) = pluginSplit($this->settings['userModel']);
     $path = '/:plugin/:controller/:action';
     if ($request->is('api')) {
         $path = '/:prefix' . $path;
     }
     $action = $this->action($request, $path);
     $cacheName = 'permissions_' . strval($user['id']);
     if (($permissions = Cache::read($cacheName, 'permissions')) === false) {
         $permissions = array();
         Cache::write($cacheName, $permissions, 'permissions');
     }
     if (!isset($permissions[$action])) {
         $User = ClassRegistry::init($this->settings['userModel']);
         $User->id = $user['id'];
         $allowed = $Acl->check($User, $action);
         $permissions[$action] = $allowed;
         Cache::write($cacheName, $permissions, 'permissions');
         $hit = false;
     } else {
         $allowed = $permissions[$action];
         $hit = true;
     }
     if (Configure::read('debug')) {
         $status = $allowed ? ' allowed.' : ' denied.';
         $cached = $hit ? ' (cache hit)' : ' (cache miss)';
         CakeLog::write(LOG_ERR, $user['username'] . ' - ' . $action . $status . $cached);
     }
     if (!$allowed) {
         return false;
     }
     if (!Configure::read('Access Control.rowLevel')) {
         return $allowed;
     }
     // bail out when controller's primary model does not want row level acl
     $controller = $this->controller();
     $model = $controller->modelClass;
     $Model = $controller->{$model};
     if ($Model && !$Model->Behaviors->attached('RowLevelAcl')) {
         return $allowed;
     }
     $primaryKey = $Model->primaryKey;
     $ids = array();
     if ($request->is('get') && !empty($request->params['pass'][0])) {
         // collect id from actions such as: Nodes/admin_edit/1
         $ids[] = $request->params['pass'][0];
     } elseif (($request->is('post') || $request->is('put')) && isset($request->data[$model]['action'])) {
         // collect ids from 'bulk' processing action such as: Nodes/admin_process
         foreach ($request->data[$model] as $id => $flag) {
             if (isset($flag[$primaryKey]) && $flag[$primaryKey] == 1) {
                 $ids[] = $id;
             }
         }
     }
     foreach ($ids as $id) {
         if (is_numeric($id)) {
             try {
                 $allowed = $this->_authorizeByContent($user, $request, $id);
             } catch (CakeException $e) {
                 $allowed = false;
             }
         } else {
             continue;
         }
         if (!$allowed) {
             break;
         }
     }
     return $allowed;
 }
開發者ID:saydulk,項目名稱:croogo,代碼行數:81,代碼來源:AclCachedAuthorize.php

示例12: isDelete

 /**
  * Returns true if the current call a DELETE request
  *
  * @return boolean True if call is a DELETE
  * @deprecated Use $this->request->is('delete'); from your controller.
  */
 public function isDelete()
 {
     return $this->request->is('delete');
 }
開發者ID:Marcin11,項目名稱:_mojePanstwo-Portal,代碼行數:10,代碼來源:RequestHandlerComponent.php

示例13: _secureRequired

 /**
  * Check if access requires secure connection
  *
  * @param object $controller Instantiating controller
  * @return bool true if secure connection required
  */
 protected function _secureRequired($controller)
 {
     if (is_array($this->requireSecure) && !empty($this->requireSecure)) {
         $requireSecure = array_map('strtolower', $this->requireSecure);
         if (in_array($this->_action, $requireSecure) || $this->requireSecure == array('*')) {
             if (!$this->request->is('ssl')) {
                 if (!$this->blackHole($controller, 'secure')) {
                     return null;
                 }
             }
         }
     }
     return true;
 }
開發者ID:no2key,項目名稱:Web-Framework-Benchmark,代碼行數:20,代碼來源:security.php

示例14: authenticate

 /**
  * Authenticate a user based on the request information
  *
  * @see BaseAuthenticate::authenticate()
  */
 public function authenticate(CakeRequest $request, CakeResponse $response)
 {
     if (!empty($request->data) || $request->is('post')) {
         return false;
     }
     return $this->getUser($request);
 }
開發者ID:dlpc,項目名稱:CakeWX,代碼行數:12,代碼來源:CookieAuthenticate.php

示例15: addAjaxMethodDetectorsTo

 /**
  * add 4 standard request method detectors for ajax calls
  * add 4 standard request method detectors for nonajax calls
  *
  * @param $request CakeRequest. This will be passed by reference
  * @return CakeRequest. Just in case caller did not know that the CakeRequest object was passed by reference
  */
 public function addAjaxMethodDetectorsTo(CakeRequest $request)
 {
     // the 4 method detectors for ajax calls
     $request->addDetector('ajax_get', array('callback' => function ($request) {
         return $request->is('ajax') && $request->is('get');
     }));
     $request->addDetector('ajax_post', array('callback' => function ($request) {
         return $request->is('ajax') && $request->is('post');
     }));
     $request->addDetector('ajax_put', array('callback' => function ($request) {
         return $request->is('ajax') && $request->is('put');
     }));
     $request->addDetector('ajax_delete', array('callback' => function ($request) {
         return $request->is('ajax') && $request->is('delete');
     }));
     // the 4 method detectors for NON-ajax calls
     $request->addDetector('nonajax_get', array('callback' => function ($request) {
         return !$request->is('ajax') && $request->is('get');
     }));
     $request->addDetector('nonajax_post', array('callback' => function ($request) {
         return !$request->is('ajax') && $request->is('post');
     }));
     $request->addDetector('nonajax_put', array('callback' => function ($request) {
         return !$request->is('ajax') && $request->is('put');
     }));
     $request->addDetector('nonajax_delete', array('callback' => function ($request) {
         return !$request->is('ajax') && $request->is('delete');
     }));
     return $request;
 }
開發者ID:simkimsia,項目名稱:utility-components,代碼行數:37,代碼來源:RequestExtrasHandlerComponent.php


注:本文中的CakeRequest::is方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。