WebService::Recruit::Jalan::StockSearch - Jalan Web Service "StockSearch" API


WebService-Recruit-Jalan documentation Contained in the WebService-Recruit-Jalan distribution.

Index


Code Index:

NAME

Top

WebService::Recruit::Jalan::StockSearch - Jalan Web Service "StockSearch" API

SYNOPSIS

Top

    use WebService::Recruit::Jalan;

    my $jalan = WebService::Recruit::Jalan->new();
    $jalan->key( 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' );

    my $param = {
        s_area      =>  '137412',
        stay_date   =>  '20070910',
        stay_count  =>  '3',
        adult_num   =>  '2',
    };
    my $res = $jalan->StockSearch( %$param );
    die "error!" if $res->is_error;

    my $list = $res->root->Plan;
    foreach my $plan ( @$list ) {
        print "PlanName: ",  $plan->PlanName, "\n";
        print "HotelName: ", $plan->Hotel->HotelName, "\n";
    }

DESCRIPTION

Top

This module is a interface for the StockSearch API. It accepts following query parameters to make an request.

    my $param = {
        reg             =>  '10',
        pref            =>  '130000',
        l_area          =>  '136200',
        s_area          =>  '136202',
        h_id            =>  '324994',
        o_area_id       =>  '50024',
        o_id            =>  '0042',
        x               =>  '503037529',
        y               =>  '128366212',
        range           =>  '10',
        h_name          =>  'Hotel Name',
        stay_date       =>  '20070803',
        stay_count      =>  '1',
        room_count      =>  '1',
        adult_num       =>  '1',
        sc_num          =>  '0',
        lc_num_bed_meal     =>  '0',
        lc_num_meal_only    =>  '0',
        lc_num_bed_only     =>  '0',
        lc_num_no_bed_meal  =>  '0',
        min_rate        =>  '100000',
        max_rate        =>  '10000',
        h_type          =>  '0',
        o_pool          =>  '0',
        parking         =>  '0',
        pub_bath        =>  '0',
        onsen           =>  '0',
        prv_bath        =>  '0',
        v_bath          =>  '0',
        sauna           =>  '0',
        jacz            =>  '0',
        mssg            =>  '0',
        r_ski           =>  '0',
        r_brd           =>  '0',
        pet             =>  '0',
        esthe           =>  '0',
        p_pong          =>  '0',
        limo            =>  '0',
        high            =>  '0',
        p_ok            =>  '0',
        o_bath          =>  '0',
        pour            =>  '0',
        cloudy          =>  '0',
        i_pool          =>  '0',
        fitness         =>  '0',
        gym             =>  '0',
        p_field         =>  '0',
        bbq             =>  '0',
        hall            =>  '0',
        5_station       =>  '0',
        5_beach         =>  '0',
        5_slope         =>  '0',
        c_card          =>  '0',
        c_jcb           =>  '0',
        c_visa          =>  '0',
        c_master        =>  '0',
        c_amex          =>  '0',
        c_uc            =>  '0',
        c_dc            =>  '0',
        c_nicos         =>  '0',
        c_diners        =>  '0',
        c_saison        =>  '0',
        c_ufj           =>  '0',
        cvs             =>  '0',
        room_b          =>  '0',
        room_d          =>  '0',
        prv_b           =>  '0',
        prv_d           =>  '0',
        early_in        =>  '0',
        late_out        =>  '0',
        no_smk          =>  '0',
        net             =>  '0',
        r_room          =>  '0',
        sp_room         =>  '0',
        bath_to         =>  '0',
        no_meal         =>  '0',
        b_only          =>  '0',
        d_only          =>  '0',
        2_meals         =>  '0',
        sng_room        =>  '0',
        twn_room        =>  '0',
        dbl_room        =>  '0',
        tri_room        =>  '0',
        4bed_room       =>  '0',
        jpn_room        =>  '0',
        j_w_room        =>  '0',
        child_price     =>  '0',
        c_bed_meal      =>  '0',
        c_no_bed_meal   =>  '0',
        c_meal_only     =>  '0',
        c_bed_only      =>  '0',
        pict_size       =>  '3',    # pictM
        picts           =>  '3',
        order           =>  '0',
        start           =>  '1',
        count           =>  '10',
    };

$jalan above is an instance of WebService::Recruit::Jalan.

METHODS

Top

root

This returns the root element of the response.

    my $root = $res->root;

You can retrieve each element by the following accessors.

    $root->NumberOfResults;
    $root->DisplayPerPage;
    $root->DisplayFrom;
    $root->APIVersion;
    $root->Plan;
    $root->Plan->[0]->PlanName;
    $root->Plan->[0]->RoomName;
    $root->Plan->[0]->PlanDetailURL;
    $root->Plan->[0]->Facilities;
    $root->Plan->[0]->Facilities->Facility->[0];
    $root->Plan->[0]->PlanCheckIn;
    $root->Plan->[0]->PlanCheckOut;
    $root->Plan->[0]->PlanPictureURL;
    $root->Plan->[0]->PlanPictureCaption;
    $root->Plan->[0]->Meal;
    $root->Plan->[0]->RateType;
    $root->Plan->[0]->SampleRate;
    $root->Plan->[0]->Stay;
    $root->Plan->[0]->Stay->[0]->PlanDetailURL;
    $root->Plan->[0]->Stay->[0]->Date;
    $root->Plan->[0]->Stay->[0]->Date->[0]->date;
    $root->Plan->[0]->Stay->[0]->Date->[0]->month;
    $root->Plan->[0]->Stay->[0]->Date->[0]->year;
    $root->Plan->[0]->Stay->[0]->Date->[0]->Rate;
    $root->Plan->[0]->Stay->[0]->Date->[0]->Stock;
    $root->Plan->[0]->Hotel;
    $root->Plan->[0]->Hotel->HotelID;
    $root->Plan->[0]->Hotel->HotelName;
    $root->Plan->[0]->Hotel->PostCode;
    $root->Plan->[0]->Hotel->HotelAddress;
    $root->Plan->[0]->Hotel->Area;
    $root->Plan->[0]->Hotel->Area->Region;
    $root->Plan->[0]->Hotel->Area->Prefecture;
    $root->Plan->[0]->Hotel->Area->LargeArea;
    $root->Plan->[0]->Hotel->Area->SmallArea;
    $root->Plan->[0]->Hotel->HotelType;
    $root->Plan->[0]->Hotel->HotelDetailURL;
    $root->Plan->[0]->Hotel->HotelCatchCopy;
    $root->Plan->[0]->Hotel->HotelCaption;
    $root->Plan->[0]->Hotel->PictureURL;
    $root->Plan->[0]->Hotel->PictureCaption;
    $root->Plan->[0]->Hotel->X;
    $root->Plan->[0]->Hotel->Y;
    $root->Plan->[0]->Hotel->HotelNameKana;
    $root->Plan->[0]->Hotel->NumberOfRatings;
    $root->Plan->[0]->Hotel->Rating;

xml

This returns the raw response context itself.

    print $res->xml, "\n";

code

This returns the response status code.

    my $code = $res->code; # usually "200" when succeeded

is_error

This returns true value when the response has an error.

    die 'error!' if $res->is_error;

page

This returns a Data::Page instance.

    my $page = $res->page();
    print "Total: ", $page->total_entries, "\n";
    print "Page: ", $page->current_page, "\n";
    print "Last: ", $page->last_page, "\n";

pageset

This returns a Data::Pageset instance.

    my $pageset = $res->pageset( 'fixed' );
    $pageset->pages_per_set($pages_per_set);
    my $set = $pageset->pages_in_set();
    foreach my $num ( @$set ) {
        print "$num ";
    }

page_param

This returns a hash to specify the page for the next request.

    my %hash = $res->page_param( $page->next_page );

page_query

This returns a query string to specify the page for the next request.

    my $query = $res->page_query( $page->prev_page );

SEE ALSO

Top

WebService::Recruit::Jalan

AUTHOR

Top

Yusuke Kawasaki http://www.kawa.net/

This module is unofficial and released by the author in person.

COPYRIGHT AND LICENSE

Top


WebService-Recruit-Jalan documentation Contained in the WebService-Recruit-Jalan distribution.

package WebService::Recruit::Jalan::StockSearch;
use strict;
use vars qw( $VERSION );
use base qw( WebService::Recruit::Jalan::Base );
$VERSION = '0.10';

sub url { 'http://jws.jalan.net/APIAdvance/StockSearch/V1/'; }

sub query_class { 'WebService::Recruit::Jalan::StockSearch::Query'; }
sub query_fields { [qw(
    key reg pref l_area s_area h_id o_area_id o_id x y range h_name
    stay_date stay_count room_count adult_num sc_num lc_num_bed_meal
    lc_num_meal_only lc_num_bed_only lc_num_no_bed_meal min_rate
    max_rate h_type o_pool parking pub_bath onsen prv_bath v_bath
    sauna jacz mssg r_ski r_brd pet esthe p_pong limo high p_ok
    o_bath pour cloudy i_pool fitness gym p_field bbq hall 5_station
    5_beach 5_slope c_card c_jcb c_visa c_master c_amex c_uc c_dc
    c_nicos c_diners c_saison c_ufj cvs room_b room_d prv_b prv_d
    early_in late_out no_smk net r_room sp_room bath_to no_meal
    b_only d_only 2_meals sng_room twn_room dbl_room tri_room 4bed_room
    jpn_room j_w_room child_price c_bed_meal c_no_bed_meal c_meal_only
    c_bed_only pict_size picts order start count
)]; }
sub notnull_param { [qw( key )]; }

sub elem_class { 'WebService::Recruit::Jalan::StockSearch::Element'; }
sub root_elem { 'Results'; }
sub elem_fields { {
    Results => [qw(
        NumberOfResults DisplayPerPage DisplayFrom APIVersion Plan
    )],
    Plan => [qw(
        PlanName RoomName PlanDetailURL Facilities PlanCheckIn PlanCheckOut
        PlanPictureURL PlanPictureCaption Meal RateType SampleRate Stay Hotel
    )],
    Facilities => [qw(
        Facility
    )],
    Stay => [qw(
        PlanDetailURL Date
    )],
    Date => [qw(
        date month year Rate Stock
    )],
    Hotel => [qw(
        HotelID HotelName PostCode HotelAddress Area HotelType
        HotelDetailURL HotelCatchCopy HotelCaption PictureURL
        PictureCaption X Y HotelNameKana NumberOfRatings Rating
    )],
    Area => [qw(
        Region Prefecture LargeArea SmallArea
    )],
}; }
sub force_array { [qw(
    Plan Facility PlanPictureURL PlanPictureCaption Stay Date
)]; }

# __PACKAGE__->mk_query_accessors();

@WebService::Recruit::Jalan::StockSearch::Query::ISA = qw( Class::Accessor::Fast );
WebService::Recruit::Jalan::StockSearch::Query->mk_accessors( @{query_fields()} );

# __PACKAGE__->mk_elem_accessors();

@WebService::Recruit::Jalan::StockSearch::Element::ISA = qw( Class::Accessor::Children::Fast );
WebService::Recruit::Jalan::StockSearch::Element->mk_ro_accessors( root_elem() );
WebService::Recruit::Jalan::StockSearch::Element->mk_child_ro_accessors( %{elem_fields()} );

1;