line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
package CAS::Messaging; |
2
|
|
|
|
|
|
|
|
3
|
|
|
|
|
|
|
=head1 NAME |
4
|
|
|
|
|
|
|
|
5
|
|
|
|
|
|
|
CAS::Messaging - Base class for class message & error handling. Not intended |
6
|
|
|
|
|
|
|
for external use. |
7
|
|
|
|
|
|
|
|
8
|
|
|
|
|
|
|
=head1 SYNOPSIS |
9
|
|
|
|
|
|
|
|
10
|
|
|
|
|
|
|
use CAS::Constants; |
11
|
|
|
|
|
|
|
|
12
|
|
|
|
|
|
|
=head1 DESCRIPTION |
13
|
|
|
|
|
|
|
|
14
|
|
|
|
|
|
|
Exports the following constants into callers namespace: |
15
|
|
|
|
|
|
|
CONTINUE => 100 |
16
|
|
|
|
|
|
|
OK => 200 |
17
|
|
|
|
|
|
|
CREATED => 201 |
18
|
|
|
|
|
|
|
ACCEPTED => 202 |
19
|
|
|
|
|
|
|
NOT_MODIFIED => 304 |
20
|
|
|
|
|
|
|
BAD_REQUEST => 400 |
21
|
|
|
|
|
|
|
UNAUTHORIZED => 401 |
22
|
|
|
|
|
|
|
AUTH_REQUIRED => 401 |
23
|
|
|
|
|
|
|
FORBIDDEN => 403 |
24
|
|
|
|
|
|
|
NOT_FOUND => 404 |
25
|
|
|
|
|
|
|
METHOD_NOT_ALLOWED => 405 |
26
|
|
|
|
|
|
|
NOT_ACCEPTABLE => 406 |
27
|
|
|
|
|
|
|
REQUEST_TIME_OUT => 408 |
28
|
|
|
|
|
|
|
TIME_EXPIRED => 408 |
29
|
|
|
|
|
|
|
CONFLICT => 409 |
30
|
|
|
|
|
|
|
GONE => 410 |
31
|
|
|
|
|
|
|
ERROR => 500 |
32
|
|
|
|
|
|
|
INTERNAL_SERVER_ERROR => 500 |
33
|
|
|
|
|
|
|
NOT_IMPLEMENTED => 501 |
34
|
|
|
|
|
|
|
|
35
|
|
|
|
|
|
|
Definitions of response codes: |
36
|
|
|
|
|
|
|
|
37
|
|
|
|
|
|
|
=over 4 |
38
|
|
|
|
|
|
|
|
39
|
|
|
|
|
|
|
=item B |
40
|
|
|
|
|
|
|
|
41
|
|
|
|
|
|
|
The client may continue with its request. Generally only used inside |
42
|
|
|
|
|
|
|
methods where multiple steps may be required. |
43
|
|
|
|
|
|
|
|
44
|
|
|
|
|
|
|
=item B |
45
|
|
|
|
|
|
|
|
46
|
|
|
|
|
|
|
The request has succeeded. Accept for certain special circumstances where |
47
|
|
|
|
|
|
|
another code is defined as expected, this is the code that should be set |
48
|
|
|
|
|
|
|
when any method completes its task sucessfully (as far as we know). |
49
|
|
|
|
|
|
|
|
50
|
|
|
|
|
|
|
=item B |
51
|
|
|
|
|
|
|
|
52
|
|
|
|
|
|
|
The is the code set when a new object was succesfully created. |
53
|
|
|
|
|
|
|
|
54
|
|
|
|
|
|
|
=item B |
55
|
|
|
|
|
|
|
|
56
|
|
|
|
|
|
|
Indicates the request has been accepted for processing, but the processing has |
57
|
|
|
|
|
|
|
not been completed. |
58
|
|
|
|
|
|
|
|
59
|
|
|
|
|
|
|
=item B |
60
|
|
|
|
|
|
|
|
61
|
|
|
|
|
|
|
A request was made to save or change something that resulted in no actual |
62
|
|
|
|
|
|
|
change, but no system error occured. Such as when setting an attribute to a |
63
|
|
|
|
|
|
|
value that is not allowed. |
64
|
|
|
|
|
|
|
|
65
|
|
|
|
|
|
|
=item B |
66
|
|
|
|
|
|
|
|
67
|
|
|
|
|
|
|
The request could not be understood by the server due to malformed syntax or |
68
|
|
|
|
|
|
|
missing required arguments. |
69
|
|
|
|
|
|
|
|
70
|
|
|
|
|
|
|
=item B |
71
|
|
|
|
|
|
|
|
72
|
|
|
|
|
|
|
The request requires user authentication. |
73
|
|
|
|
|
|
|
|
74
|
|
|
|
|
|
|
=item B |
75
|
|
|
|
|
|
|
|
76
|
|
|
|
|
|
|
As L. |
77
|
|
|
|
|
|
|
|
78
|
|
|
|
|
|
|
=item B |
79
|
|
|
|
|
|
|
|
80
|
|
|
|
|
|
|
The server understood the request, but is refusing to fulfill it because the |
81
|
|
|
|
|
|
|
user or requesting client lacks the required authorization. |
82
|
|
|
|
|
|
|
|
83
|
|
|
|
|
|
|
=item B |
84
|
|
|
|
|
|
|
|
85
|
|
|
|
|
|
|
The server understood the request, but the requested resource (such as a user |
86
|
|
|
|
|
|
|
or client) was not found. |
87
|
|
|
|
|
|
|
|
88
|
|
|
|
|
|
|
=item B |
89
|
|
|
|
|
|
|
|
90
|
|
|
|
|
|
|
The requested method is not allowed in the current context or by the |
91
|
|
|
|
|
|
|
calling object. |
92
|
|
|
|
|
|
|
|
93
|
|
|
|
|
|
|
=item B |
94
|
|
|
|
|
|
|
|
95
|
|
|
|
|
|
|
The client did not produce a request within the time that the server was |
96
|
|
|
|
|
|
|
prepared to wait. Or, in the more common context of the user, their log-in |
97
|
|
|
|
|
|
|
period has timed out and they need to re-authenticate. |
98
|
|
|
|
|
|
|
|
99
|
|
|
|
|
|
|
=item B |
100
|
|
|
|
|
|
|
|
101
|
|
|
|
|
|
|
As L. |
102
|
|
|
|
|
|
|
|
103
|
|
|
|
|
|
|
=item B |
104
|
|
|
|
|
|
|
|
105
|
|
|
|
|
|
|
The request could not be completed due to a conflict with the current state of |
106
|
|
|
|
|
|
|
the resource. |
107
|
|
|
|
|
|
|
|
108
|
|
|
|
|
|
|
=item B |
109
|
|
|
|
|
|
|
|
110
|
|
|
|
|
|
|
The server encountered some condition which prevented it from |
111
|
|
|
|
|
|
|
fulfilling the request. Serious internal problems, such as malformed SQL |
112
|
|
|
|
|
|
|
statements will also die. This condition is more commonly set when a request |
113
|
|
|
|
|
|
|
appeared valid but was impossible to complete, such as a well formed new |
114
|
|
|
|
|
|
|
user request, but where the username was already taken. All methods initially |
115
|
|
|
|
|
|
|
set the response code to ERROR and then change it when appropriate. |
116
|
|
|
|
|
|
|
|
117
|
|
|
|
|
|
|
=item B |
118
|
|
|
|
|
|
|
|
119
|
|
|
|
|
|
|
As L. |
120
|
|
|
|
|
|
|
|
121
|
|
|
|
|
|
|
=item B |
122
|
|
|
|
|
|
|
|
123
|
|
|
|
|
|
|
The server does not support the functionality required to fulfill the request. |
124
|
|
|
|
|
|
|
|
125
|
|
|
|
|
|
|
=back |
126
|
|
|
|
|
|
|
|
127
|
|
|
|
|
|
|
These values are drawn from Apache's response codes, since this system is |
128
|
|
|
|
|
|
|
intended to be generally accessed via an Apache server. While error text |
129
|
|
|
|
|
|
|
will be stored in B, the RESPONSE_CODE can be checked to see the |
130
|
|
|
|
|
|
|
reason for failure. |
131
|
|
|
|
|
|
|
|
132
|
|
|
|
|
|
|
=cut |
133
|
|
|
|
|
|
|
|
134
|
6
|
|
|
6
|
|
24554
|
use strict; |
|
6
|
|
|
|
|
13
|
|
|
6
|
|
|
|
|
278
|
|
135
|
6
|
|
|
6
|
|
37
|
use Scalar::Util qw(blessed); |
|
6
|
|
|
|
|
22
|
|
|
6
|
|
|
|
|
424
|
|
136
|
6
|
|
|
6
|
|
35
|
use Carp qw(cluck confess croak carp); |
|
6
|
|
|
|
|
27
|
|
|
6
|
|
|
|
|
430
|
|
137
|
6
|
|
|
6
|
|
37
|
use base qw(Exporter); |
|
6
|
|
|
|
|
11
|
|
|
6
|
|
|
|
|
1370
|
|
138
|
|
|
|
|
|
|
|
139
|
|
|
|
|
|
|
our $VERSION = '0.08'; |
140
|
|
|
|
|
|
|
our $AUTOLOAD = ''; |
141
|
|
|
|
|
|
|
|
142
|
|
|
|
|
|
|
our %codes = ( |
143
|
|
|
|
|
|
|
CONTINUE => 100, |
144
|
|
|
|
|
|
|
OK => 200, |
145
|
|
|
|
|
|
|
CREATED => 201, |
146
|
|
|
|
|
|
|
ACCEPTED => 202, |
147
|
|
|
|
|
|
|
NOT_MODIFIED => 304, |
148
|
|
|
|
|
|
|
BAD_REQUEST => 400, |
149
|
|
|
|
|
|
|
UNAUTHORIZED => 401, |
150
|
|
|
|
|
|
|
AUTH_REQUIRED => 401, |
151
|
|
|
|
|
|
|
FORBIDDEN => 403, |
152
|
|
|
|
|
|
|
NOT_FOUND => 404, |
153
|
|
|
|
|
|
|
METHOD_NOT_ALLOWED => 405, |
154
|
|
|
|
|
|
|
NOT_ACCEPTABLE => 406, |
155
|
|
|
|
|
|
|
REQUEST_TIME_OUT => 408, |
156
|
|
|
|
|
|
|
TIME_EXPIRED => 408, |
157
|
|
|
|
|
|
|
CONFLICT => 409, |
158
|
|
|
|
|
|
|
GONE => 410, |
159
|
|
|
|
|
|
|
ERROR => 500, |
160
|
|
|
|
|
|
|
INTERNAL_SERVER_ERROR => 500, |
161
|
|
|
|
|
|
|
NOT_IMPLEMENTED => 501, |
162
|
|
|
|
|
|
|
); |
163
|
6
|
|
|
6
|
|
42
|
use constant \%codes; |
|
6
|
|
|
|
|
11
|
|
|
6
|
|
|
|
|
497
|
|
164
|
|
|
|
|
|
|
use constant { |
165
|
6
|
|
|
|
|
9397
|
CONTINUE => 100, |
166
|
|
|
|
|
|
|
OK => 200, |
167
|
|
|
|
|
|
|
CREATED => 201, |
168
|
|
|
|
|
|
|
ACCEPTED => 202, |
169
|
|
|
|
|
|
|
NOT_MODIFIED => 304, |
170
|
|
|
|
|
|
|
BAD_REQUEST => 400, |
171
|
|
|
|
|
|
|
UNAUTHORIZED => 401, |
172
|
|
|
|
|
|
|
AUTH_REQUIRED => 401, |
173
|
|
|
|
|
|
|
FORBIDDEN => 403, |
174
|
|
|
|
|
|
|
NOT_FOUND => 404, |
175
|
|
|
|
|
|
|
METHOD_NOT_ALLOWED => 405, |
176
|
|
|
|
|
|
|
NOT_ACCEPTABLE => 406, |
177
|
|
|
|
|
|
|
REQUEST_TIME_OUT => 408, |
178
|
|
|
|
|
|
|
TIME_EXPIRED => 408, |
179
|
|
|
|
|
|
|
CONFLICT => 409, |
180
|
|
|
|
|
|
|
GONE => 410, |
181
|
|
|
|
|
|
|
ERROR => 500, |
182
|
|
|
|
|
|
|
INTERNAL_SERVER_ERROR => 500, |
183
|
|
|
|
|
|
|
NOT_IMPLEMENTED => 501, |
184
|
6
|
|
|
6
|
|
35
|
}; |
|
6
|
|
|
|
|
12
|
|
185
|
|
|
|
|
|
|
|
186
|
|
|
|
|
|
|
our $Errmsg = ''; |
187
|
|
|
|
|
|
|
our @EXPORT = (keys %codes,qw($Errmsg)); |
188
|
|
|
|
|
|
|
|
189
|
|
|
|
|
|
|
# we need to be able to get the string by value sometimes |
190
|
|
|
|
|
|
|
# it doesn't matter here if an alias gets lost |
191
|
|
|
|
|
|
|
our %code_name_by_val = reverse %codes; |
192
|
|
|
|
|
|
|
|
193
|
|
|
|
|
|
|
# set the result information in self |
194
|
|
|
|
|
|
|
sub _set_result { |
195
|
0
|
|
|
0
|
|
|
my $self = shift; |
196
|
0
|
0
|
|
|
|
|
$self->error("Not a method call") unless blessed($self); |
197
|
0
|
|
0
|
|
|
|
my $debug = $self->{debug} || 0; |
198
|
|
|
|
|
|
|
|
199
|
0
|
|
0
|
|
|
|
my $code = shift || ERROR; # no code == bad ;) |
200
|
0
|
0
|
|
|
|
|
$self->error("Unknown result code $code") unless $code_name_by_val{$code}; |
201
|
0
|
|
|
|
|
|
$self->{response_code} = $code; |
202
|
|
|
|
|
|
|
|
203
|
0
|
|
|
|
|
|
my @call = caller; |
204
|
0
|
|
|
|
|
|
my $msg = shift; |
205
|
0
|
0
|
|
|
|
|
unless ($msg) { |
206
|
0
|
|
|
|
|
|
$msg = 'No message provided by ' . $call[0]; |
207
|
|
|
|
|
|
|
} # no message, blame caller |
208
|
|
|
|
|
|
|
|
209
|
0
|
0
|
|
|
|
|
if ($debug) { |
210
|
0
|
|
|
|
|
|
$msg = "($call[0]:" . "[$call[2]]) $msg"; |
211
|
|
|
|
|
|
|
} # if debugging make sure we know where from |
212
|
|
|
|
|
|
|
|
213
|
0
|
|
|
|
|
|
push(@{$self->{messages}}, $msg); |
|
0
|
|
|
|
|
|
|
214
|
|
|
|
|
|
|
|
215
|
|
|
|
|
|
|
# If debugging is at 2 or more, we're generating very noisy output as well |
216
|
0
|
0
|
|
|
|
|
$self->gripe("_set_result ($code): $msg") if $self->{debug} >= 2; |
217
|
|
|
|
|
|
|
} # _set_result |
218
|
|
|
|
|
|
|
|
219
|
|
|
|
|
|
|
|
220
|
|
|
|
|
|
|
sub _clear_result { |
221
|
0
|
|
|
0
|
|
|
my $self = shift; |
222
|
0
|
0
|
|
|
|
|
$self->error("Not a method call") unless blessed($self); |
223
|
|
|
|
|
|
|
|
224
|
|
|
|
|
|
|
# we set the code to error as any call to _clear_result should be |
225
|
|
|
|
|
|
|
# internal, and anything happening before a different result is set that |
226
|
|
|
|
|
|
|
# stops processing is almost certainly an error |
227
|
0
|
|
|
|
|
|
$self->{response_code} = ERROR; |
228
|
0
|
|
|
|
|
|
$self->{messages} = []; |
229
|
|
|
|
|
|
|
} # _sclear_result |
230
|
|
|
|
|
|
|
|
231
|
|
|
|
|
|
|
|
232
|
|
|
|
|
|
|
# Checks to see if the provided code matches the current response_code |
233
|
|
|
|
|
|
|
# accept either value or text |
234
|
|
|
|
|
|
|
sub response_is { |
235
|
0
|
|
|
0
|
0
|
|
my $self = shift; |
236
|
0
|
0
|
|
|
|
|
$self->error("Not a method call") unless blessed($self); |
237
|
0
|
|
0
|
|
|
|
my $code = shift || $self->error("No response code specified"); |
238
|
|
|
|
|
|
|
|
239
|
0
|
0
|
|
|
|
|
if ($codes{$code}) { $code = $codes{$code} } |
|
0
|
|
|
|
|
|
|
240
|
|
|
|
|
|
|
|
241
|
0
|
0
|
|
|
|
|
$self->error("Unknown code $code") unless exists $code_name_by_val{$code}; |
242
|
|
|
|
|
|
|
|
243
|
0
|
0
|
|
|
|
|
return 1 if $self->{response_code} == $code; |
244
|
0
|
|
|
|
|
|
return undef; |
245
|
|
|
|
|
|
|
} # response_is |
246
|
|
|
|
|
|
|
|
247
|
|
|
|
|
|
|
# returns the text version of the code, useful mostly in error reporting |
248
|
|
|
|
|
|
|
sub response_code { |
249
|
0
|
|
|
0
|
0
|
|
my $self = shift; |
250
|
0
|
0
|
|
|
|
|
$self->error("Not a method call") unless blessed($self); |
251
|
|
|
|
|
|
|
|
252
|
|
|
|
|
|
|
# return the key string for the current code |
253
|
0
|
|
|
|
|
|
return $code_name_by_val{$self->{response_code}}; |
254
|
|
|
|
|
|
|
} # response_code |
255
|
|
|
|
|
|
|
|
256
|
|
|
|
|
|
|
# get the numerical value from the code name |
257
|
|
|
|
|
|
|
sub code_value { |
258
|
0
|
|
|
0
|
0
|
|
my $self = shift; |
259
|
0
|
0
|
|
|
|
|
$self->error("Not a method call") unless blessed($self); |
260
|
|
|
|
|
|
|
|
261
|
0
|
|
|
|
|
|
my $name = shift; |
262
|
0
|
0
|
|
|
|
|
$self->gripe("Unknown code $name") unless exists $codes{$name}; |
263
|
0
|
0
|
|
|
|
|
return $codes{$name} if exists $codes{$name}; |
264
|
0
|
|
|
|
|
|
return undef; |
265
|
|
|
|
|
|
|
} # response_code |
266
|
|
|
|
|
|
|
|
267
|
|
|
|
|
|
|
|
268
|
|
|
|
|
|
|
=head2 messages |
269
|
|
|
|
|
|
|
|
270
|
|
|
|
|
|
|
Messages return any processing messages. While sometimes useful information |
271
|
|
|
|
|
|
|
can be found here for debugging, generally the only reason to call this method |
272
|
|
|
|
|
|
|
is to see what happened that caused an error or other invalid response. |
273
|
|
|
|
|
|
|
|
274
|
|
|
|
|
|
|
unless ($user->validate_Password($HR_params)) { |
275
|
|
|
|
|
|
|
die "Password not validated: $user->messages"; |
276
|
|
|
|
|
|
|
} # unless valid password provided |
277
|
|
|
|
|
|
|
|
278
|
|
|
|
|
|
|
Note that in scalar context messages will return a scalar of all messages |
279
|
|
|
|
|
|
|
generated seperated with '; '. In list context it returns a list of the |
280
|
|
|
|
|
|
|
messages allowing the caller to format for other display, such as HTML. As |
281
|
|
|
|
|
|
|
such, the results of the die above would be very different if written as: |
282
|
|
|
|
|
|
|
die "Password not validated: ", $user->messages; |
283
|
|
|
|
|
|
|
|
284
|
|
|
|
|
|
|
When the last method call worked as expected, then the last message in the list |
285
|
|
|
|
|
|
|
should be the message generated when the result_code was set. |
286
|
|
|
|
|
|
|
|
287
|
|
|
|
|
|
|
=cut |
288
|
|
|
|
|
|
|
sub messages { |
289
|
0
|
|
|
0
|
1
|
|
my $self = shift; |
290
|
0
|
|
|
|
|
|
my $class = blessed($self); |
291
|
0
|
0
|
|
|
|
|
$self->error("Not a method call") unless $class; |
292
|
|
|
|
|
|
|
|
293
|
0
|
|
|
|
|
|
return wantarray ? @{$self->{messages}} |
|
0
|
|
|
|
|
|
|
294
|
0
|
0
|
|
|
|
|
: join('; ', $class, @{$self->{messages}}); |
295
|
|
|
|
|
|
|
} # messages |
296
|
|
|
|
|
|
|
|
297
|
|
|
|
|
|
|
|
298
|
|
|
|
|
|
|
=head2 errstr |
299
|
|
|
|
|
|
|
|
300
|
|
|
|
|
|
|
Presumes that there was an error, and that the last message generated most |
301
|
|
|
|
|
|
|
directly relates to the cause of the error and returns only that message. Be |
302
|
|
|
|
|
|
|
warned however that this might always be correct, or enough information. |
303
|
|
|
|
|
|
|
Generally the whole message list is prefered. |
304
|
|
|
|
|
|
|
|
305
|
|
|
|
|
|
|
=cut |
306
|
|
|
|
|
|
|
sub errstr { |
307
|
0
|
|
|
0
|
1
|
|
my $self = shift; |
308
|
0
|
0
|
|
|
|
|
$self->error("Not a method call") unless blessed($self); |
309
|
|
|
|
|
|
|
|
310
|
0
|
|
|
|
|
|
return $self->{messages}[-1]; |
311
|
|
|
|
|
|
|
} # errstr |
312
|
|
|
|
|
|
|
|
313
|
|
|
|
|
|
|
|
314
|
|
|
|
|
|
|
=head2 error |
315
|
|
|
|
|
|
|
|
316
|
|
|
|
|
|
|
Throw a fatal exeption. Returns a stack trace (confess) if called when |
317
|
|
|
|
|
|
|
DEBUG is true. L actually does all the work, error just tells |
318
|
|
|
|
|
|
|
gripe to die. |
319
|
|
|
|
|
|
|
|
320
|
|
|
|
|
|
|
=cut |
321
|
|
|
|
|
|
|
sub error { |
322
|
0
|
|
|
0
|
1
|
|
my $self = shift; |
323
|
0
|
0
|
|
|
|
|
confess("Not a method call") unless blessed($self); |
324
|
|
|
|
|
|
|
|
325
|
0
|
|
|
|
|
|
$self->gripe(@_,1); # @_ should only contain the message |
326
|
|
|
|
|
|
|
} # error |
327
|
|
|
|
|
|
|
|
328
|
|
|
|
|
|
|
=head2 gripe |
329
|
|
|
|
|
|
|
|
330
|
|
|
|
|
|
|
Generate debug sensitive warnings and exceptions. gripe also writes warnings |
331
|
|
|
|
|
|
|
to a scratch pad in the calling object so that warning_notes method can |
332
|
|
|
|
|
|
|
return all warnings generated. This behavior mirrors that of |
333
|
|
|
|
|
|
|
L for objects rather than CGI's. |
334
|
|
|
|
|
|
|
|
335
|
|
|
|
|
|
|
Suggested debug level usage (as level goes up messages from earlier levels |
336
|
|
|
|
|
|
|
should continue to be sent): |
337
|
|
|
|
|
|
|
|
338
|
|
|
|
|
|
|
0: Production. Perls warnings should _not_ be turned on and no debug |
339
|
|
|
|
|
|
|
messages should be generated. |
340
|
|
|
|
|
|
|
|
341
|
|
|
|
|
|
|
1: Basic development level. Perls warnings are turned on. Basic debug |
342
|
|
|
|
|
|
|
messages should be generated. L dies with stack trace (confess) and |
343
|
|
|
|
|
|
|
outputs all stored messages. |
344
|
|
|
|
|
|
|
|
345
|
|
|
|
|
|
|
2: Shotgun debugging. Code should now be generating debug messages when |
346
|
|
|
|
|
|
|
entering and/or exiting important blocks so that program flow can be |
347
|
|
|
|
|
|
|
observed. |
348
|
|
|
|
|
|
|
|
349
|
|
|
|
|
|
|
3: Turns on Perls diagnostics. At this level messages should be generated for |
350
|
|
|
|
|
|
|
every pass through loops. This would also be the appropriate level to dump |
351
|
|
|
|
|
|
|
data structures at critical points. Gripe now includes stack trace with every |
352
|
|
|
|
|
|
|
invocation. It is realistic to expect hundreds of lines of output at _least_ at |
353
|
|
|
|
|
|
|
this level. This would be the most verbose debug level. |
354
|
|
|
|
|
|
|
|
355
|
|
|
|
|
|
|
4: Autodie - gripe will now throw a fatal exception with confess.* |
356
|
|
|
|
|
|
|
|
357
|
|
|
|
|
|
|
* Currently this happens the first time called. However it realy should only |
358
|
|
|
|
|
|
|
die the first time a message intended to be sent only at debug levels >= 1. |
359
|
|
|
|
|
|
|
|
360
|
|
|
|
|
|
|
=cut |
361
|
|
|
|
|
|
|
sub gripe { |
362
|
0
|
|
|
0
|
1
|
|
my $self = shift; |
363
|
0
|
|
|
|
|
|
my $class = blessed($self); |
364
|
0
|
0
|
|
|
|
|
croak("Not a method call") unless $class; |
365
|
0
|
|
0
|
|
|
|
my $msg = shift || confess("Class $class threw warning without message"); |
366
|
0
|
|
0
|
|
|
|
my $die = shift || 0; |
367
|
|
|
|
|
|
|
|
368
|
0
|
|
|
|
|
|
my @call = caller; |
369
|
0
|
0
|
|
|
|
|
@call = caller(1) if $die; |
370
|
|
|
|
|
|
|
|
371
|
|
|
|
|
|
|
# determine debug level, & set to die if told to be extremely verbose |
372
|
0
|
|
0
|
|
|
|
my $debug = $self->{debug} || 0; |
373
|
0
|
0
|
|
|
|
|
$die = 1 if $debug > 3; |
374
|
|
|
|
|
|
|
|
375
|
|
|
|
|
|
|
# just to be paranoid, we'll unlock tables on fatal error |
376
|
|
|
|
|
|
|
# tables left locked can block future operations and would require |
377
|
|
|
|
|
|
|
# root to unlock by hand |
378
|
0
|
0
|
0
|
|
|
|
if ($die && ref $self->{dbh} && $self->{dbh}->ping) { |
|
|
|
0
|
|
|
|
|
379
|
0
|
|
|
|
|
|
$self->{dbh}->do("UNLOCK TABLES"); |
380
|
|
|
|
|
|
|
} # if dieing and DBH |
381
|
|
|
|
|
|
|
|
382
|
0
|
0
|
|
|
|
|
if ($debug) { |
383
|
0
|
|
|
|
|
|
$msg = "($call[0]" . "[$call[2]]) $msg"; |
384
|
|
|
|
|
|
|
} # if debugging |
385
|
|
|
|
|
|
|
|
386
|
|
|
|
|
|
|
# to make sure we know what class the object that called us belongs to |
387
|
0
|
|
|
|
|
|
$msg = "$class: $msg"; |
388
|
0
|
0
|
0
|
|
|
|
if (exists $self->{ERRORLOG} && openhandle($self->{ERRORLOG})) { |
389
|
0
|
0
|
0
|
|
|
|
my $logmsg = ($die && $debug) || $debug >= 2 |
390
|
|
|
|
|
|
|
? Carp::longmess($msg) : Carp::shortmess($msg); |
391
|
0
|
|
|
|
|
|
my $fh = $self->{ERRORLOG}; |
392
|
0
|
|
|
|
|
|
print $fh $logmsg; |
393
|
|
|
|
|
|
|
} # if user wants errors loged |
394
|
|
|
|
|
|
|
|
395
|
|
|
|
|
|
|
# if we're dying and debug is on |
396
|
0
|
0
|
0
|
|
|
|
if ($die && $debug) { confess("$msg\n" . $self->messages) } |
|
0
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
397
|
0
|
|
|
|
|
|
elsif ($die) { croak($msg) } # or die with just the message |
398
|
0
|
|
|
|
|
|
elsif ($debug >= 2) { cluck("$msg\n") } # verbose warn |
399
|
0
|
|
|
|
|
|
else { carp("$msg\n") } # just let em know the basics |
400
|
|
|
|
|
|
|
} # gripe |
401
|
|
|
|
|
|
|
|
402
|
|
|
|
|
|
|
|
403
|
|
|
|
|
|
|
=head1 AUTHOR |
404
|
|
|
|
|
|
|
|
405
|
|
|
|
|
|
|
Sean P. Quinlan, C<< >> |
406
|
|
|
|
|
|
|
|
407
|
|
|
|
|
|
|
=head1 TO DO / development notes |
408
|
|
|
|
|
|
|
|
409
|
|
|
|
|
|
|
Gripe should have a way to output to a filehandle (provided when object |
410
|
|
|
|
|
|
|
created) so that output can be optionally logged. Should _set_result also |
411
|
|
|
|
|
|
|
record each invocation to the log if debugging? |
412
|
|
|
|
|
|
|
|
413
|
|
|
|
|
|
|
=head1 BUGS |
414
|
|
|
|
|
|
|
|
415
|
|
|
|
|
|
|
Please report any bugs or feature requests to |
416
|
|
|
|
|
|
|
C, or through the web interface at |
417
|
|
|
|
|
|
|
L. |
418
|
|
|
|
|
|
|
I will be notified, and then you'll automatically be notified of progress on |
419
|
|
|
|
|
|
|
your bug as I make changes. |
420
|
|
|
|
|
|
|
|
421
|
|
|
|
|
|
|
=head1 HISTORY |
422
|
|
|
|
|
|
|
|
423
|
|
|
|
|
|
|
=over 8 |
424
|
|
|
|
|
|
|
|
425
|
|
|
|
|
|
|
=item 0.01 |
426
|
|
|
|
|
|
|
|
427
|
|
|
|
|
|
|
Original version; created by module-starter |
428
|
|
|
|
|
|
|
|
429
|
|
|
|
|
|
|
|
430
|
|
|
|
|
|
|
=back |
431
|
|
|
|
|
|
|
|
432
|
|
|
|
|
|
|
|
433
|
|
|
|
|
|
|
=head1 SUPPORT |
434
|
|
|
|
|
|
|
|
435
|
|
|
|
|
|
|
You can find documentation for this module with the perldoc command. |
436
|
|
|
|
|
|
|
|
437
|
|
|
|
|
|
|
perldoc CAS |
438
|
|
|
|
|
|
|
|
439
|
|
|
|
|
|
|
|
440
|
|
|
|
|
|
|
Please join the CAS mailing list and suggest a final release name for |
441
|
|
|
|
|
|
|
the package. |
442
|
|
|
|
|
|
|
http://mail.grendels-den.org/mailman/listinfo/CAS_grendels-den.org |
443
|
|
|
|
|
|
|
|
444
|
|
|
|
|
|
|
You can also look for information at: |
445
|
|
|
|
|
|
|
|
446
|
|
|
|
|
|
|
=over 4 |
447
|
|
|
|
|
|
|
|
448
|
|
|
|
|
|
|
=item * AnnoCPAN: Annotated CPAN documentation |
449
|
|
|
|
|
|
|
|
450
|
|
|
|
|
|
|
L |
451
|
|
|
|
|
|
|
|
452
|
|
|
|
|
|
|
=item * CPAN Ratings |
453
|
|
|
|
|
|
|
|
454
|
|
|
|
|
|
|
L |
455
|
|
|
|
|
|
|
|
456
|
|
|
|
|
|
|
=item * RT: CPAN's request tracker |
457
|
|
|
|
|
|
|
|
458
|
|
|
|
|
|
|
L |
459
|
|
|
|
|
|
|
|
460
|
|
|
|
|
|
|
=item * Search CPAN |
461
|
|
|
|
|
|
|
|
462
|
|
|
|
|
|
|
L |
463
|
|
|
|
|
|
|
|
464
|
|
|
|
|
|
|
=back |
465
|
|
|
|
|
|
|
|
466
|
|
|
|
|
|
|
=head1 ACKNOWLEDGEMENTS |
467
|
|
|
|
|
|
|
|
468
|
|
|
|
|
|
|
The Bioinformatics Group at Massachusetts General Hospital during my |
469
|
|
|
|
|
|
|
tenure there for development assistance and advice, particularly the QA team |
470
|
|
|
|
|
|
|
for banging on the project code. |
471
|
|
|
|
|
|
|
|
472
|
|
|
|
|
|
|
|
473
|
|
|
|
|
|
|
=head1 COPYRIGHT & LICENSE |
474
|
|
|
|
|
|
|
|
475
|
|
|
|
|
|
|
Copyright 2006 Sean P. Quinlan, all rights reserved. |
476
|
|
|
|
|
|
|
|
477
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify it |
478
|
|
|
|
|
|
|
under the same terms as Perl itself. |
479
|
|
|
|
|
|
|
|
480
|
|
|
|
|
|
|
=cut |
481
|
|
|
|
|
|
|
|
482
|
|
|
|
|
|
|
1; # End of CAS::Messaging |