Blame view

sources/lib/public/appframework/controller.php 4.15 KB
03e52840d   Kload   Init
1
  <?php
03e52840d   Kload   Init
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
  /**
   * ownCloud - App Framework
   *
   * @author Bernhard Posselt
   * @copyright 2012 Bernhard Posselt nukeawhale@gmail.com
   *
   * This library is free software; you can redistribute it and/or
   * modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
   * License as published by the Free Software Foundation; either
   * version 3 of the License, or any later version.
   *
   * This library is distributed in the hope that it will be useful,
   * but WITHOUT ANY WARRANTY; without even the implied warranty of
   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   * GNU AFFERO GENERAL PUBLIC LICENSE for more details.
   *
   * You should have received a copy of the GNU Affero General Public
   * License along with this library.  If not, see <http://www.gnu.org/licenses/>.
   *
   */
31b7f2792   Kload   Upgrade to ownclo...
22
23
24
25
26
27
  /**
   * Public interface of ownCloud for apps to use.
   * AppFramework\Controller class
   */
  
  namespace OCP\AppFramework;
03e52840d   Kload   Init
28

31b7f2792   Kload   Upgrade to ownclo...
29
30
31
  use OCP\AppFramework\Http\TemplateResponse;
  use OCP\AppFramework\IAppContainer;
  use OCP\IRequest;
03e52840d   Kload   Init
32

03e52840d   Kload   Init
33
34
  
  /**
31b7f2792   Kload   Upgrade to ownclo...
35
   * Base class to inherit your controllers from
03e52840d   Kload   Init
36
   */
31b7f2792   Kload   Upgrade to ownclo...
37
38
39
40
41
42
43
  abstract class Controller {
  
  	/**
  	 * app container for dependency injection
  	 * @var \OCP\AppFramework\IAppContainer
  	 */
  	protected $app;
03e52840d   Kload   Init
44
45
  
  	/**
31b7f2792   Kload   Upgrade to ownclo...
46
47
  	 * current request
  	 * @var \OCP\IRequest
03e52840d   Kload   Init
48
49
  	 */
  	protected $request;
31b7f2792   Kload   Upgrade to ownclo...
50
51
52
53
54
55
56
57
  	/**
  	 * constructor of the controller
  	 * @param IAppContainer $app interface to the app
  	 * @param IRequest $request an instance of the request
  	 */
  	public function __construct(IAppContainer $app, IRequest $request){
  		$this->app = $app;
  		$this->request = $request;
03e52840d   Kload   Init
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
  	}
  
  
  	/**
  	 * Lets you access post and get parameters by the index
  	 * @param string $key the key which you want to access in the URL Parameter
  	 *                     placeholder, $_POST or $_GET array.
  	 *                     The priority how they're returned is the following:
  	 *                     1. URL parameters
  	 *                     2. POST parameters
  	 *                     3. GET parameters
  	 * @param mixed $default If the key is not found, this value will be returned
  	 * @return mixed the content of the array
  	 */
  	public function params($key, $default=null){
31b7f2792   Kload   Upgrade to ownclo...
73
  		return $this->request->getParam($key, $default);
03e52840d   Kload   Init
74
  	}
31b7f2792   Kload   Upgrade to ownclo...
75

03e52840d   Kload   Init
76
77
78
79
80
81
  	/**
  	 * Returns all params that were received, be it from the request
  	 * (as GET or POST) or throuh the URL by the route
  	 * @return array the array with all parameters
  	 */
  	public function getParams() {
31b7f2792   Kload   Upgrade to ownclo...
82
  		return $this->request->getParams();
03e52840d   Kload   Init
83
  	}
31b7f2792   Kload   Upgrade to ownclo...
84

03e52840d   Kload   Init
85
86
87
88
89
  	/**
  	 * Returns the method of the request
  	 * @return string the method of the request (POST, GET, etc)
  	 */
  	public function method() {
31b7f2792   Kload   Upgrade to ownclo...
90
  		return $this->request->getMethod();
03e52840d   Kload   Init
91
  	}
31b7f2792   Kload   Upgrade to ownclo...
92

03e52840d   Kload   Init
93
94
95
96
97
98
  	/**
  	 * Shortcut for accessing an uploaded file through the $_FILES array
  	 * @param string $key the key that will be taken from the $_FILES array
  	 * @return array the file in the $_FILES element
  	 */
  	public function getUploadedFile($key) {
31b7f2792   Kload   Upgrade to ownclo...
99
  		return $this->request->getUploadedFile($key);
03e52840d   Kload   Init
100
  	}
31b7f2792   Kload   Upgrade to ownclo...
101

03e52840d   Kload   Init
102
103
104
105
106
107
  	/**
  	 * Shortcut for getting env variables
  	 * @param string $key the key that will be taken from the $_ENV array
  	 * @return array the value in the $_ENV element
  	 */
  	public function env($key) {
31b7f2792   Kload   Upgrade to ownclo...
108
  		return $this->request->getEnv($key);
03e52840d   Kload   Init
109
  	}
03e52840d   Kload   Init
110
111
112
113
114
115
116
  
  	/**
  	 * Shortcut for getting cookie variables
  	 * @param string $key the key that will be taken from the $_COOKIE array
  	 * @return array the value in the $_COOKIE element
  	 */
  	public function cookie($key) {
31b7f2792   Kload   Upgrade to ownclo...
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
  		return $this->request->getCookie($key);
  	}
  
  
  	/**
  	 * Shortcut for rendering a template
  	 * @param string $templateName the name of the template
  	 * @param array $params the template parameters in key => value structure
  	 * @param string $renderAs user renders a full page, blank only your template
  	 *                          admin an entry in the admin settings
  	 * @param array $headers set additional headers in name/value pairs
  	 * @return \OCP\AppFramework\Http\TemplateResponse containing the page
  	 */
  	public function render($templateName, array $params=array(),
  							$renderAs='user', array $headers=array()){
  		$response = new TemplateResponse($this->app->getAppName(), $templateName);
  		$response->setParams($params);
  		$response->renderAs($renderAs);
  
  		foreach($headers as $name => $value){
  			$response->addHeader($name, $value);
  		}
  
  		return $response;
03e52840d   Kload   Init
141
  	}
31b7f2792   Kload   Upgrade to ownclo...
142

03e52840d   Kload   Init
143
  }