NAME
riap - Riap client shell
VERSION
version 0.01
SYNOPSIS
% riap --help
% riap [opts] <uri>
Invoking:
# URI defaults to 'pl:/', which is the local Perl realm
% riap
# ditto, but specify initial "pwd"
% riap /Calendar/Indonesia/Holiday
% riap pl:/Calendar/Indonesia/Holiday
# access remote API starting point
% riap https://cpanlists.org/api/
% riap http://gudangapi.com/ga/
An example session:
riap> pwd
/
riap> cd /spanel/api
riap> ls
account/
disk_usage/
mysql/
pgsql/
plan/
...
riap> cd account/shared
riap> pwd
/spanel/api/account/shared/modify
riap> ls -l
create_account function
delete_accounts function
suspend_account function
unsuspend_account function
# execute a Riap function like it is an executable program
riap> list_accounts --nodisabled --nomigrated
andi
budi
charlie
devi
steven
riap> ./delete_account --help
riap> exit
DESCRIPTION
A Riap client in the form of a simple interactive command-line shell (as opposed to Perinci::Access which is a Perl library, or peri-run and peri-access which are non-interactive command-line interface). Provides a convenient way to explore API services which use the Riap protocol or explore Perl modules which have Rinci metadata.
Example API services that you can (or will be able to) test this with:
cpanlists.org at https://cpanlists.org/api/
gudangdata.org at https://gudangdata.org/gd/
gudangapi.com at https://gudangapi.com/ga/
Any server using the Spanel control panel software
The API daemon listens at the Unix socket at
/var/run/spanel/apid.sock
or at TCPhttps://localhost:1010
.
Example Perl libraries you can test this with (you need to install them first): Text::sprintfn, Git::Bunch, Calendar::Indonesia::Holiday, Perinci::Examples. Try to search for CPAN distributions which specify Rinci as their prerequisites.
Within the shell, you can browse packages and functions as if they were directories and executable files (using commands like cd
, ls
, pwd
). You can call functions like they were command-line programs, by passing command-line parameters for function arguments.
See "COMMANDS" for list of known commands.
OPTIONS
--help
Show short help message.
--user=S
Supply HTTP authentication user. You can also set this via environment PERINCI_HTTP_USER (see Perinci::Access for more details) or from inside the shell via
set user <S>
.--password=S
Supply HTTP authentication password. You can also set this via environment PERINCI_HTTP_PASSWORD (see Perinci::Access for more details) or from inside the shell via
set password <S>
.
COMMANDS
help [command]
Display help message.
exit
pwd
Print the current directory (package). When you first enter the shell, current directory is set to /
.
cd [path]
Change directory (package). You can use relative notation (../foo
) like in a Unix filesystem.
doc <path>
Perform meta
Riap request and format the result as text.
ls [options] [path ...]
List of content of directory (package) or other code entities by performing list
Riap request. If path
is not specified, will list the current directory (package).
Options:
--long (-l)
Add
detail => 1
to the Riap request, which will return more details.
list
Alias for ls
.
info [path]
Perform info
Riap request on an entity at path
.
request [options] <action> <path> [extra]
Perform Riap request to a code entity at path
. Extra request keys can be specified in extra
.
Examples:
riap> request call /Package/Sub/somefunc '{"args":{"a":1, "b":2}}'
riap> request list /Package/Sub/somefunc '{"detail":1}'
call [options] <path> [args]
Perform call
Riap request. Note that call
command is actually optional: the shell performs call requests by default on paths.
Examples:
riap> call /Package/Sub/somefunc '{"foo":1, "bar":2}'
which is equivalent to:
riap> /Package/Sub/somefunc --foo 1 --bar 2
set <name> <value>
If invoked without any argument, will list all known settings. If name
is specified but value
is not, will show value for that particular setting. If name
and value
is both specified, will set a setting's value.
SETTINGS
Settings are configuration and regulate how the shell behaves.
user => str
For HTTP authentication.
password => str
For HTTP authentication.
output_format => str (default: text
)
Set output format for command results. The same formatting is used by Perinci::CmdLine. See that module or Perinci::Result::Format for more details.
debug_show_request => bool (default: 0)
Whether to show raw Riap requests being sent to the server.
Note: since riap uses Perinci::Access, you can show the log statement, e.g. using:
% TRACE=1 LOG_RIAP_REQUEST=1 perl -MLog::Any::App /path/to/riap ...
debug_show_response => bool (default: 0)
Whether to show raw Riap responses returned by the server.
Note: since riap uses Perinci::Access, you can show the log statement, e.g. using:
% TRACE=1 LOG_RIAP_RESPONSE=1 perl -MLog::Any::App /path/to/riap ...
FAQ
How do I redirect output to files?
riap is meant to be a simple shell, not a full-blown Unix shell. Besides, a syntax like this:
riap> call /Package/Sub/somefunc > /path/to/file
will be confusing since paths map to code entity URIs in riap, not filesystem paths.
But something like a setting might be implemented if this is a popular feature request.
What about variables, aliases, looping, or $other_Unix_shell_feature?
Again, riap is meant to be a simple shell, not a full-blown Unix shell. To do those things, you are better off using peri-run or peri-access and incorporate them in a Unix shell script. For example you can write these two short scripts:
# list-accounts
#!/bin/sh
peri-access call https://yourservice.com/api/Account/list
# delete-account (input sanitizing is left as exercise for the readers)
#!/bin/sh
peri-access call "https://yourservice.com/api/Account/delete?account=$1"
and then write:
# delete all accounts
for a in `list-accounts`; do
delete-account "$a"
done
ENVIRONMENT
RIAP_HISTFILE => str (default: ~/.riap_history
)
Specify location of command history file. Like in shells, can be set to empty string to disable history loading/saving.
RIAPRC => str (default: ~/.riaprc
)
Specify location of settings file.
FILES
~/.riap_history
Command history file.
~/.riaprc
Settings file. Each line is either a blank line, a comment (# ...
), or <name>=<value-in-json>
. An invalid line (e.g. unknown settings, invalid JSON syntax) will cause shell to abort when loading.
TODO
Configurable prompt
RIAP_HISTSIZE
And also probably RIAP_HISTFILESIZE, RIAP_HISTIGNORE, RIAP_HISTTIMEFORMAT.
Something like PATH? [#E]
AUTHOR
Steven Haryanto <stevenharyanto@gmail.com>
COPYRIGHT AND LICENSE
This software is copyright (c) 2013 by Steven Haryanto.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.