WebService::Hexonet::Connector::Response - Library to provide accessibility to API response data.
This module is internally used by the WebService::Hexonet::Connector::APIClient module. To be used in the way:
    # specify the used API command (used for the request that responsed with $plain)
    $command = {
            COMMAND => 'StatusAccount'
    };
    # specify the API plain-text response (this is just an example that won't fit to the command above)
    $plain = "[RESPONSE]\r\nCODE=200\r\nDESCRIPTION=Command completed successfully\r\nEOF\r\n";
    # create a new instance by
    $r = WebService::Hexonet::Connector::Response->new($plain, $command);
HEXONET Backend API always responds in plain-text format that needs to get parsed into a useful data structure. This module manages all this: parsing data into hash format, into columns and records. It provides different methods to access the data to fit your needs.
new( $plain, $command )Returns a new WebService::Hexonet::Connector::Response object. Specify the plain-text API response by $plain. Specify the used command by $command.
addColumn( $key, @data )Add a new column. Specify the column name by $key. Specify the column data by @data. Returns the current WebService::Hexonet::Connector::Response instance in use for method chaining.
addRecord( $hash )Add a new record. Specify the row data in hash notation by $hash. Where the hash key represents the column name. Where the hash value represents the row value for that column. Returns the current WebService::Hexonet::Connector::Response instance in use for method chaining.
getColumn( $key )Get a column for the specified column name $key. Returns an instance of WebService::Hexonet::Connector::Column.
getColumnIndex( $key, $index ) {Get Data of the specified column $key for the given column index $index. Returns a scalar.
getColumnKeysGet a list of available column names. NOTE: columns may differ in their data size. Returns an array.
getCommandGet the command used within the request that resulted in this api response. This is in general the command you provided in the constructor. Returns a hash.
getCurrentPageNumberReturns the current page number we are in with this API response as int. Returns -1 if not found.
getCurrentRecordReturns the current record of the iteration. It internally uses recordIndex as iterator index. Returns an instance of WebService::Hexonet::Connector::Record. Returns undef if not found.
getFirstRecordIndexReturns the first record index of this api response as int. Returns undef if not found.
getLastRecordIndexReturns the last record index of this api response as int. Returns undef if not found.
getListHashReturns this api response in a List-Hash format. You will find the row data under hash key "LIST". You will find meta data under hash key "meta". Under "meta" data you will again find a hash, where hash key "columns" provides you a list of available column names and "pg" provides you useful paginator data. This method is thought to be used if you need something that helps you realizing tables with or without a pager. Returns a Hash.
getNextRecordReturns the next record of the current iteration. Returns an instance of WebService::Hexonet::Connector::Record. Returns undef if not found.
getNextPageNumberReturns the number of the next api response page for the current request as int. Returns -1 if not found.
getNumberOfPagesReturns the total number of response pages in our API for the current request as int.
getPaginationReturns paginator data of the current response / request. Returns a hash.
getPreviousPageNumberReturns the number of the previous api response page for the current request as int. Returns -1 if not found.
getPreviousRecordReturns the previous record of the current iteration. Returns undef if not found otherwise an instance of WebService::Hexonet::Connector::Record.
getRecord( $index )Returns the record of the specified record index $index. Returns undef if not found otherwise an instance of WebService::Hexonet::Connector::Record.
getRecordsReturns a list of available records. Returns an array of instances of WebService::Hexonet::Connector::Record.
getRecordsCountReturns the amount of returned records for the current request as int.
getRecordsTotalCountReturns the total amount of available records for the current request as int.
getRecordsLimitationReturns the limitation of the current request as int. LIMIT = ... NOTE: Our system comes with a default limitation if you do not specify a limitation in list commands to avoid data load in our systems. This limitation is then returned in column "LIMIT" at index 0.
hasNextPageChecks if a next response page exists for the current query. Returns boolean 0 or 1.
hasPreviousPageChecks if a previous response page exists for the current query. Returns boolean 0 or 1.
rewindRecordListResets the current iteration to index 0.
_hasColumn( $key )Private method. Checks if a column specified by $key exists. Returns boolean 0 or 1.
_hasCurrentRecordPrivate method. Checks if the current record exists in the iteration. Returns boolean 0 or 1.
_hasNextRecordPrivate method. Checks if the next record exists in the iteration. Returns boolean 0 or 1.
_hasPreviousRecordPrivate method. Checks if the previous record exists in the iteration. Returns boolean 0 or 1.
This program is licensed under the MIT License.