Pangloss::Segment::LoadTermStatus - load term status from an OpenFrame::Request.


Pangloss documentation Contained in the Pangloss distribution.

Index


Code Index:

NAME

Top

Pangloss::Segment::LoadTermStatus - load term status from an OpenFrame::Request.

SYNOPSIS

Top

  $pipe->add_segment( Pangloss::Segment::LoadTermStatus->new )

DESCRIPTION

Top

This class inherits its interface from Pipeline::Segment.

METHODS

Top

$status = $obj->dispatch();

attempts to load a term status from the stored OpenFrame::Request's arguments.

$status = $obj->new_term_status_from_args( \%args );

Creates a new term status from the hash given. uses the following keys:

    new_term_status_code
    new_term_status_notes

Returns undef if no useable keys were present.

AUTHOR

Top

Steve Purkis <spurkis@quiup.com>

SEE ALSO

Top

Pipeline::Segment, Pangloss::Term::Status


Pangloss documentation Contained in the Pangloss distribution.
package Pangloss::Segment::LoadTermStatus;

use Pangloss::Term;

use base qw( OpenFrame::WebApp::Segment::User::Session );

our $VERSION  = ((require Pangloss::Version), $Pangloss::VERSION)[1];
our $REVISION = (split(/ /, ' $Revision: 1.4 $ '))[2];

sub dispatch {
    my $self    = shift;
    my $request = $self->store->get('OpenFrame::Request') || return;
    return $self->new_term_status_from_args( $request->arguments );
}

sub new_term_status_from_args {
    my $self = shift;
    my $args = shift;
    my $user = $self->get_user_from_session;

    my $status   = new Pangloss::Term::Status();
    my $modified = 0;

    $status->creator( $user->key ) if ($user);

    foreach my $var (qw( code notes )) {
	if (exists( $args->{"new_term_status_$var"} )) {
	    $status->$var( $args->{"new_term_status_$var"} );
	    $modified++;
	}
    }

    return $modified ? $status : undef;
}

1;

__END__

#------------------------------------------------------------------------------