NAME

GSSAPI::Status - methods for handlings GSSAPI statuses

SYNOPSIS

use GSSAPI;

$status = GSSAPI::Status->new(GSS_S_COMPLETE, 0);

if (GSS_ERROR($status->major)) {
  die "a horrible death";
}
if (! $status) {			# another way of writing the above
  die "a horrible death";
}

$status = $some_GSSAPI->someop($args1, etc);
if ($status) {
  foreach ($status->generic_message, $status->specific_message) {
    print "GSSAPI error: $_\n";
  }
  die "help me";
}

DESCRIPTION

GSSAPI::Status objects are returned by most other GSSAPI operations. Such statuses consist of a GSSAPI generic code and, for most operations, a mechanism specific code. These numeric codes can be accessed via the methods major and minor. The standard textual messages that go with the current status can be obtained via the generic_message and specific_message methods. Each of these returns a list of text which should presumably be displayed in order.

The generic code part of a GSSAPI::Status is composed of three subfields that can be accessed with the GSS_CALLING_ERROR, GSS_ROUTINE_ERROR, and GSS_SUPPLEMENTARY_INFO functions. The returned values can be compared against the constants whose names start with GSS_S_ if your code wants to handle particular errors itself. The GSS_ERROR function returns true if and only if the given generic code contains neither a calling error nor a routine error.

When evaluated in a boolean context, a GSSAPI::Status object will be true if and only if the major status code is GSS_S_COMPLETE.

When evaluated in a string contect, a GSSAPI::Status object will return the generic and specific messages all joined together with newlines. This may or may not make die $status work usefully.

BUGS

The base objects are currently implmented as a blessed C structure containing the major and minor status codes. It should probably be a blessed array or hash instead, thereby cutting down on the amount of C code involved and making it more flexible.

AUTHOR

Philip Guenther, guenther@gac.edu

SEE ALSO

perl(1) RFC2743