統計
| ブランチ: | リビジョン:

pictcode / lib / Cake / Error / exceptions.php @ 26d1f852

履歴 | 表示 | アノテート | ダウンロード (13.823 KB)

1
<?php
2
/**
3
 * Exceptions file. Contains the various exceptions CakePHP will throw until they are
4
 * moved into their permanent location.
5
 *
6
 * CakePHP(tm) : Rapid Development Framework (http://cakephp.org)
7
 * Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
8
 *
9
 * Licensed under The MIT License
10
 * For full copyright and license information, please see the LICENSE.txt
11
 * Redistributions of files must retain the above copyright notice.
12
 *
13
 * @copyright     Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
14
 * @link          http://book.cakephp.org/2.0/en/development/testing.html
15
 * @package       Cake.Error
16
 * @since         CakePHP(tm) v 2.0
17
 * @license       http://www.opensource.org/licenses/mit-license.php MIT License
18
 */
19

    
20
/**
21
 * Base class that all Exceptions extend.
22
 *
23
 * @package       Cake.Error
24
 */
25
class CakeBaseException extends RuntimeException {
26

    
27
/**
28
 * Array of headers to be passed to CakeResponse::header()
29
 *
30
 * @var array
31
 */
32
        protected $_responseHeaders = null;
33

    
34
/**
35
 * Get/set the response header to be used
36
 *
37
 * @param string|array $header An array of header strings or a single header string
38
 *  - an associative array of "header name" => "header value"
39
 *  - an array of string headers is also accepted
40
 * @param string $value The header value.
41
 * @return array
42
 * @see CakeResponse::header()
43
 */
44
        public function responseHeader($header = null, $value = null) {
45
                if ($header) {
46
                        if (is_array($header)) {
47
                                return $this->_responseHeaders = $header;
48
                        }
49
                        $this->_responseHeaders = array($header => $value);
50
                }
51
                return $this->_responseHeaders;
52
        }
53

    
54
}
55

    
56
/**
57
 * Parent class for all of the HTTP related exceptions in CakePHP.
58
 * All HTTP status/error related exceptions should extend this class so
59
 * catch blocks can be specifically typed.
60
 *
61
 * @package       Cake.Error
62
 */
63
if (!class_exists('HttpException', false)) {
64
        class HttpException extends CakeBaseException {
65
        }
66
}
67

    
68
/**
69
 * Represents an HTTP 400 error.
70
 *
71
 * @package       Cake.Error
72
 */
73
class BadRequestException extends HttpException {
74

    
75
/**
76
 * Constructor
77
 *
78
 * @param string $message If no message is given 'Bad Request' will be the message
79
 * @param int $code Status code, defaults to 400
80
 */
81
        public function __construct($message = null, $code = 400) {
82
                if (empty($message)) {
83
                        $message = 'Bad Request';
84
                }
85
                parent::__construct($message, $code);
86
        }
87

    
88
}
89

    
90
/**
91
 * Represents an HTTP 401 error.
92
 *
93
 * @package       Cake.Error
94
 */
95
class UnauthorizedException extends HttpException {
96

    
97
/**
98
 * Constructor
99
 *
100
 * @param string $message If no message is given 'Unauthorized' will be the message
101
 * @param int $code Status code, defaults to 401
102
 */
103
        public function __construct($message = null, $code = 401) {
104
                if (empty($message)) {
105
                        $message = 'Unauthorized';
106
                }
107
                parent::__construct($message, $code);
108
        }
109

    
110
}
111

    
112
/**
113
 * Represents an HTTP 403 error.
114
 *
115
 * @package       Cake.Error
116
 */
117
class ForbiddenException extends HttpException {
118

    
119
/**
120
 * Constructor
121
 *
122
 * @param string $message If no message is given 'Forbidden' will be the message
123
 * @param int $code Status code, defaults to 403
124
 */
125
        public function __construct($message = null, $code = 403) {
126
                if (empty($message)) {
127
                        $message = 'Forbidden';
128
                }
129
                parent::__construct($message, $code);
130
        }
131

    
132
}
133

    
134
/**
135
 * Represents an HTTP 404 error.
136
 *
137
 * @package       Cake.Error
138
 */
139
class NotFoundException extends HttpException {
140

    
141
/**
142
 * Constructor
143
 *
144
 * @param string $message If no message is given 'Not Found' will be the message
145
 * @param int $code Status code, defaults to 404
146
 */
147
        public function __construct($message = null, $code = 404) {
148
                if (empty($message)) {
149
                        $message = 'Not Found';
150
                }
151
                parent::__construct($message, $code);
152
        }
153

    
154
}
155

    
156
/**
157
 * Represents an HTTP 405 error.
158
 *
159
 * @package       Cake.Error
160
 */
161
class MethodNotAllowedException extends HttpException {
162

    
163
/**
164
 * Constructor
165
 *
166
 * @param string $message If no message is given 'Method Not Allowed' will be the message
167
 * @param int $code Status code, defaults to 405
168
 */
169
        public function __construct($message = null, $code = 405) {
170
                if (empty($message)) {
171
                        $message = 'Method Not Allowed';
172
                }
173
                parent::__construct($message, $code);
174
        }
175

    
176
}
177

    
178
/**
179
 * Represents an HTTP 500 error.
180
 *
181
 * @package       Cake.Error
182
 */
183
class InternalErrorException extends HttpException {
184

    
185
/**
186
 * Constructor
187
 *
188
 * @param string $message If no message is given 'Internal Server Error' will be the message
189
 * @param int $code Status code, defaults to 500
190
 */
191
        public function __construct($message = null, $code = 500) {
192
                if (empty($message)) {
193
                        $message = 'Internal Server Error';
194
                }
195
                parent::__construct($message, $code);
196
        }
197

    
198
}
199

    
200
/**
201
 * CakeException is used a base class for CakePHP's internal exceptions.
202
 * In general framework errors are interpreted as 500 code errors.
203
 *
204
 * @package       Cake.Error
205
 */
206
class CakeException extends CakeBaseException {
207

    
208
/**
209
 * Array of attributes that are passed in from the constructor, and
210
 * made available in the view when a development error is displayed.
211
 *
212
 * @var array
213
 */
214
        protected $_attributes = array();
215

    
216
/**
217
 * Template string that has attributes sprintf()'ed into it.
218
 *
219
 * @var string
220
 */
221
        protected $_messageTemplate = '';
222

    
223
/**
224
 * Constructor.
225
 *
226
 * Allows you to create exceptions that are treated as framework errors and disabled
227
 * when debug = 0.
228
 *
229
 * @param string|array $message Either the string of the error message, or an array of attributes
230
 *   that are made available in the view, and sprintf()'d into CakeException::$_messageTemplate
231
 * @param int $code The code of the error, is also the HTTP status code for the error.
232
 */
233
        public function __construct($message, $code = 500) {
234
                if (is_array($message)) {
235
                        $this->_attributes = $message;
236
                        $message = __d('cake_dev', $this->_messageTemplate, $message);
237
                }
238
                parent::__construct($message, $code);
239
        }
240

    
241
/**
242
 * Get the passed in attributes
243
 *
244
 * @return array
245
 */
246
        public function getAttributes() {
247
                return $this->_attributes;
248
        }
249

    
250
}
251

    
252
/**
253
 * Missing Controller exception - used when a controller
254
 * cannot be found.
255
 *
256
 * @package       Cake.Error
257
 */
258
class MissingControllerException extends CakeException {
259

    
260
        protected $_messageTemplate = 'Controller class %s could not be found.';
261

    
262
//@codingStandardsIgnoreStart
263
        public function __construct($message, $code = 404) {
264
                parent::__construct($message, $code);
265
        }
266
//@codingStandardsIgnoreEnd
267

    
268
}
269

    
270
/**
271
 * Missing Action exception - used when a controller action
272
 * cannot be found.
273
 *
274
 * @package       Cake.Error
275
 */
276
class MissingActionException extends CakeException {
277

    
278
        protected $_messageTemplate = 'Action %s::%s() could not be found.';
279

    
280
//@codingStandardsIgnoreStart
281
        public function __construct($message, $code = 404) {
282
                parent::__construct($message, $code);
283
        }
284
//@codingStandardsIgnoreEnd
285

    
286
}
287

    
288
/**
289
 * Private Action exception - used when a controller action
290
 * starts with a  `_`.
291
 *
292
 * @package       Cake.Error
293
 */
294
class PrivateActionException extends CakeException {
295

    
296
        protected $_messageTemplate = 'Private Action %s::%s() is not directly accessible.';
297

    
298
//@codingStandardsIgnoreStart
299
        public function __construct($message, $code = 404, Exception $previous = null) {
300
                parent::__construct($message, $code, $previous);
301
        }
302
//@codingStandardsIgnoreEnd
303

    
304
}
305

    
306
/**
307
 * Used when a component cannot be found.
308
 *
309
 * @package       Cake.Error
310
 */
311
class MissingComponentException extends CakeException {
312

    
313
        protected $_messageTemplate = 'Component class %s could not be found.';
314

    
315
}
316

    
317
/**
318
 * Used when a behavior cannot be found.
319
 *
320
 * @package       Cake.Error
321
 */
322
class MissingBehaviorException extends CakeException {
323

    
324
        protected $_messageTemplate = 'Behavior class %s could not be found.';
325

    
326
}
327

    
328
/**
329
 * Used when a view file cannot be found.
330
 *
331
 * @package       Cake.Error
332
 */
333
class MissingViewException extends CakeException {
334

    
335
        protected $_messageTemplate = 'View file "%s" is missing.';
336

    
337
}
338

    
339
/**
340
 * Used when a layout file cannot be found.
341
 *
342
 * @package       Cake.Error
343
 */
344
class MissingLayoutException extends CakeException {
345

    
346
        protected $_messageTemplate = 'Layout file "%s" is missing.';
347

    
348
}
349

    
350
/**
351
 * Used when a helper cannot be found.
352
 *
353
 * @package       Cake.Error
354
 */
355
class MissingHelperException extends CakeException {
356

    
357
        protected $_messageTemplate = 'Helper class %s could not be found.';
358

    
359
}
360

    
361
/**
362
 * Runtime Exceptions for ConnectionManager
363
 *
364
 * @package       Cake.Error
365
 */
366
class MissingDatabaseException extends CakeException {
367

    
368
        protected $_messageTemplate = 'Database connection "%s" could not be found.';
369

    
370
}
371

    
372
/**
373
 * Used when no connections can be found.
374
 *
375
 * @package       Cake.Error
376
 */
377
class MissingConnectionException extends CakeException {
378

    
379
        protected $_messageTemplate = 'Database connection "%s" is missing, or could not be created.';
380

    
381
/**
382
 * Constructor
383
 *
384
 * @param string|array $message The error message.
385
 * @param int $code The error code.
386
 */
387
        public function __construct($message, $code = 500) {
388
                if (is_array($message)) {
389
                        $message += array('enabled' => true);
390
                }
391
                parent::__construct($message, $code);
392
        }
393

    
394
}
395

    
396
/**
397
 * Used when a Task cannot be found.
398
 *
399
 * @package       Cake.Error
400
 */
401
class MissingTaskException extends CakeException {
402

    
403
        protected $_messageTemplate = 'Task class %s could not be found.';
404

    
405
}
406

    
407
/**
408
 * Used when a shell method cannot be found.
409
 *
410
 * @package       Cake.Error
411
 */
412
class MissingShellMethodException extends CakeException {
413

    
414
        protected $_messageTemplate = "Unknown command %1\$s %2\$s.\nFor usage try `cake %1\$s --help`";
415

    
416
}
417

    
418
/**
419
 * Used when a shell cannot be found.
420
 *
421
 * @package       Cake.Error
422
 */
423
class MissingShellException extends CakeException {
424

    
425
        protected $_messageTemplate = 'Shell class %s could not be found.';
426

    
427
}
428

    
429
/**
430
 * Exception class to be thrown when a datasource configuration is not found
431
 *
432
 * @package       Cake.Error
433
 */
434
class MissingDatasourceConfigException extends CakeException {
435

    
436
        protected $_messageTemplate = 'The datasource configuration "%s" was not found in database.php';
437

    
438
}
439

    
440
/**
441
 * Used when a datasource cannot be found.
442
 *
443
 * @package       Cake.Error
444
 */
445
class MissingDatasourceException extends CakeException {
446

    
447
        protected $_messageTemplate = 'Datasource class %s could not be found. %s';
448

    
449
}
450

    
451
/**
452
 * Exception class to be thrown when a database table is not found in the datasource
453
 *
454
 * @package       Cake.Error
455
 */
456
class MissingTableException extends CakeException {
457

    
458
        protected $_messageTemplate = 'Table %s for model %s was not found in datasource %s.';
459

    
460
}
461

    
462
/**
463
 * Exception raised when a Model could not be found.
464
 *
465
 * @package       Cake.Error
466
 */
467
class MissingModelException extends CakeException {
468

    
469
        protected $_messageTemplate = 'Model %s could not be found.';
470

    
471
}
472

    
473
/**
474
 * Exception raised when a test loader could not be found
475
 *
476
 * @package       Cake.Error
477
 */
478
class MissingTestLoaderException extends CakeException {
479

    
480
        protected $_messageTemplate = 'Test loader %s could not be found.';
481

    
482
}
483

    
484
/**
485
 * Exception raised when a plugin could not be found
486
 *
487
 * @package       Cake.Error
488
 */
489
class MissingPluginException extends CakeException {
490

    
491
        protected $_messageTemplate = 'Plugin %s could not be found.';
492

    
493
}
494

    
495
/**
496
 * Exception raised when a Dispatcher filter could not be found
497
 *
498
 * @package       Cake.Error
499
 */
500
class MissingDispatcherFilterException extends CakeException {
501

    
502
        protected $_messageTemplate = 'Dispatcher filter %s could not be found.';
503

    
504
}
505

    
506
/**
507
 * Exception class for AclComponent and Interface implementations.
508
 *
509
 * @package       Cake.Error
510
 */
511
class AclException extends CakeException {
512
}
513

    
514
/**
515
 * Exception class for Cache. This exception will be thrown from Cache when it
516
 * encounters an error.
517
 *
518
 * @package       Cake.Error
519
 */
520
class CacheException extends CakeException {
521
}
522

    
523
/**
524
 * Exception class for Router. This exception will be thrown from Router when it
525
 * encounters an error.
526
 *
527
 * @package       Cake.Error
528
 */
529
class RouterException extends CakeException {
530
}
531

    
532
/**
533
 * Exception class for CakeLog. This exception will be thrown from CakeLog when it
534
 * encounters an error.
535
 *
536
 * @package       Cake.Error
537
 */
538
class CakeLogException extends CakeException {
539
}
540

    
541
/**
542
 * Exception class for CakeSession. This exception will be thrown from CakeSession when it
543
 * encounters an error.
544
 *
545
 * @package       Cake.Error
546
 */
547
class CakeSessionException extends CakeException {
548
}
549

    
550
/**
551
 * Exception class for Configure. This exception will be thrown from Configure when it
552
 * encounters an error.
553
 *
554
 * @package       Cake.Error
555
 */
556
class ConfigureException extends CakeException {
557
}
558

    
559
/**
560
 * Exception class for Socket. This exception will be thrown from CakeSocket, CakeEmail, HttpSocket
561
 * SmtpTransport, MailTransport and HttpResponse when it encounters an error.
562
 *
563
 * @package       Cake.Error
564
 */
565
class SocketException extends CakeException {
566
}
567

    
568
/**
569
 * Exception class for Xml. This exception will be thrown from Xml when it
570
 * encounters an error.
571
 *
572
 * @package       Cake.Error
573
 */
574
class XmlException extends CakeException {
575
}
576

    
577
/**
578
 * Exception class for Console libraries. This exception will be thrown from Console library
579
 * classes when they encounter an error.
580
 *
581
 * @package       Cake.Error
582
 */
583
class ConsoleException extends CakeException {
584
}
585

    
586
/**
587
 * Represents a fatal error
588
 *
589
 * @package       Cake.Error
590
 */
591
class FatalErrorException extends CakeException {
592

    
593
/**
594
 * Constructor
595
 *
596
 * @param string $message The error message.
597
 * @param int $code The error code.
598
 * @param string $file The file the error occurred in.
599
 * @param int $line The line the error occurred on.
600
 */
601
        public function __construct($message, $code = 500, $file = null, $line = null) {
602
                parent::__construct($message, $code);
603
                if ($file) {
604
                        $this->file = $file;
605
                }
606
                if ($line) {
607
                        $this->line = $line;
608
                }
609
        }
610

    
611
}
612

    
613
/**
614
 * Not Implemented Exception - used when an API method is not implemented
615
 *
616
 * @package       Cake.Error
617
 */
618
class NotImplementedException extends CakeException {
619

    
620
        protected $_messageTemplate = '%s is not implemented.';
621

    
622
//@codingStandardsIgnoreStart
623
        public function __construct($message, $code = 501) {
624
                parent::__construct($message, $code);
625
        }
626
//@codingStandardsIgnoreEnd
627

    
628
}