NAME
Jifty::Plugin::REST::Dispatcher - Dispatcher for REST plugin
show_help
Shows basic help about resources and formats available via this RESTian interface.
show_help_specific
Displays a help page about a specific topic. Will look for a method named show_help_specific_$1
.
show_help_specific_search
Explains /=/search/ a bit more in-depth.
show_version
Displays versions of the various bits of your application.
list PREFIX items
Takes a URL prefix and a set of items to render. passes them on.
output_format [prefix]
Returns the user's desired output format. Returns a hashref of:
format: JSON, JS, YAML, XML, Perl, or HTML
extension: json, js, yml, xml, pl, or html
content_type: text/x-yaml; charset=UTF-8, etc.
freezer: \&Jifty::YAML::Dump, etc.
outs PREFIX DATASTRUCTURE
TAkes a url path prefix and a datastructure. Depending on what content types the other side of the HTTP connection can accept, renders the content as yaml, json, javascript, perl, xml or html.
render_as_xml DATASTRUCTURE
Attempts to render DATASTRUCTURE as simple, tag-based XML.
render_as_html PREFIX URL DATASTRUCTURE
Attempts to render DATASTRUCTURE as simple semantic HTML suitable for humans to look at.
html_dump DATASTRUCTURE
Recursively render DATASTRUCTURE as some simple html dls and ols.
html_dump_record Jifty::Record
Returns a nice simple HTML definition list of the keys and values of a Jifty::Record object.
action ACTION
Canonicalizes ACTION into the class-name form preferred by Jifty by cleaning up casing, delimiters, etc. Throws an appropriate HTTP error code if the action is unavailable.
model MODEL
Canonicalizes MODEL into the class-name form preferred by Jifty by cleaning up casing, delimiters, etc. Throws an appropriate HTTP error code if the model is unavailable.
list_models
Sends the user a list of models in this application, with the names transformed from Perlish::Syntax to Everything.Else.Syntax
valid_column
Returns true if the column is a valid column to observe on the model
list_model_columns
Sends the user a nice list of all columns in a given model class. Exactly which model is shoved into $1 by the dispatcher. This should probably be improved.
list_model_items MODELCLASS COLUMNNAME
Returns a list of items in MODELCLASS sorted by COLUMNNAME, with only COLUMNAME displayed. (This should have some limiting thrown in)
show_item_field $model, $column, $key, $field
Loads up a model of type $model
which has a column $column
with a value $key
. Returns the value of $field
for that object. Returns 404 if it doesn't exist.
show_item $model, $column, $key
Loads up a model of type $model
which has a column $column
with a value $key
. Returns all columns for the object
Returns 404 if it doesn't exist.
search_items $model, [c1, v1, c2, v2, ...] [, $field]
Loads up all models of type $model
that match the given columns and values. If the column and value list has an odd count, then the last item is taken to be the output column. Otherwise, all items will be returned.
Will throw a 404 if there were no matches, or $field
was invalid.
Pseudo-columns:
- __per_page => N
-
Return the collection as N records per page.
- __page => N
-
Return page N of the collection
- __order_by =>
column
-
Order by the given column, ascending.
- __order_by_desc =>
column
-
Order by the given column, descending.
create_item
Implemented by redispatching to a CreateModel action.
replace_item
Implemented by redispatching to a CreateModel or UpdateModel action.
delete_item
Implemented by redispatching to a DeleteModel action.
list_actions
Returns a list of all actions visible to the current user. (Canonicalizes Perl::Style to Everything.Else.Style).
list_action_params
Takes a single parameter, $action, supplied by the dispatcher.
Shows the user all possible parameters to the action.
show_action_form $ACTION_CLASS
Takes a single parameter, the class of an action.
Shows the user an HTML form of the action's parameters to run that action.
run_action
Expects $1 to be the name of an action we want to run.
Runs the action, with the HTTP arguments as its arguments. That is, it's not looking for Jifty-encoded (J:F) arguments. If you have an action called "MyApp::Action::Ping" that takes a parameter, ip
, this action will look for an HTTP argument called ip
, (not J:F-myaction-ip).
Returns the action's result.
TODO, doc the format of the result.
On an invalid action name, throws a 404
. On a disallowed action mame, throws a 403
. On an internal error, throws a 500
.