Merge remote-tracking branch 'upstream/4.5' into 4.5-master-2015-01-12-16-09-32
[civicrm-core.git] / CRM / Core / Exception.php
CommitLineData
6a488035
TO
1<?php
2
3/*
4 +--------------------------------------------------------------------+
39de6fd5 5 | CiviCRM version 4.6 |
6a488035 6 +--------------------------------------------------------------------+
06b69b18 7 | Copyright CiviCRM LLC (c) 2004-2014 |
6a488035
TO
8 +--------------------------------------------------------------------+
9 | This file is a part of CiviCRM. |
10 | |
11 | CiviCRM is free software; you can copy, modify, and distribute it |
12 | under the terms of the GNU Affero General Public License |
13 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
14 | |
15 | CiviCRM is distributed in the hope that it will be useful, but |
16 | WITHOUT ANY WARRANTY; without even the implied warranty of |
17 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
18 | See the GNU Affero General Public License for more details. |
19 | |
20 | You should have received a copy of the GNU Affero General Public |
21 | License and the CiviCRM Licensing Exception along |
22 | with this program; if not, contact CiviCRM LLC |
23 | at info[AT]civicrm[DOT]org. If you have questions about the |
24 | GNU Affero General Public License or the licensing of CiviCRM, |
25 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
26 +--------------------------------------------------------------------+
27*/
28
29/**
30 * Base class for exceptions generated by CiviCRM.
dcc4f6a7 31 * This Exception returns more information than the default one. We are using it from the
32 * form layer to allow redirects to occur without having redirects in the BAO
6a0b768e
TO
33 * @param string $message
34 * The human friendly error message.
35 * @param string $error_code
36 * A computer friendly error code. By convention, no space (but underscore allowed).
16b10e64 37 * ex: mandatory_missing, duplicate, invalid_format
6a0b768e
TO
38 * @param array $data
39 * Extra params to return. eg an extra array of ids. It is not mandatory, but can help the computer using the api. Keep in mind the api consumer isn't to be trusted. eg. the database password is NOT a good extra data.
6a488035
TO
40 */
41class CRM_Core_Exception extends PEAR_Exception {
dcc4f6a7 42 private $errorData = array();
a0ee3941
EM
43
44 /**
45 * @param $message
46 * @param int $error_code
47 * @param array $errorData
48 * @param null $previous
49 */
2aa397bc 50 public function __construct($message, $error_code = 0, $errorData = array(), $previous = NULL) {
dcc4f6a7 51 parent::__construct(ts($message));
52 $this->errorData = $errorData + array('error_code' => $error_code);
53 }
54
a0ee3941 55 /**
4f1f1f2a 56 * custom string representation of object
a0ee3941
EM
57 * @return string
58 */
dcc4f6a7 59 public function __toString() {
60 return __CLASS__ . ": [{$this->errorData['error_code']}: {$this->message}\n";
61 }
62
63 public function getErrorCode() {
64 return $this->errorData['error_code'];
65 }
b5c2afd0
EM
66
67 /**
68 * Return specific error information that can be used for more detailed
69 * error messages or translation.
70 *
71 * This method may be overridden in child exception classes in order
72 * to add functionality not present in PEAR_Exception and is a placeholder
73 * to define API
74 *
75 * The returned array must be an associative array of parameter => value like so:
76 * <pre>
77 * array('name' => $name, 'context' => array(...))
78 * </pre>
79 * @return array
80 */
dcc4f6a7 81 public function getErrorData() {
82 return $this->errorData;
83 }
6a488035 84}