leilukin-tumbleblog/tools/api_docs.txt

4236 lines
89 KiB
Plaintext

==============================================
includes/class/Config.php
==============================================
Class: Config
-------------
Holds all of the configuration settings for the entire site.
Function: __construct
---------------------
Loads the configuration file from disk.
Function: __get
---------------
Handles access to the configuration data.
Returns:
@mixed@
Function: __isset
-----------------
Handles access to the configuration data.
Function: read
--------------
Reads the configuration file and decodes the settings.
Function: write
---------------
Encodes the settings and writes the configuration file.
Function: set
-------------
Adds or replaces a configuration setting with the given value.
Parameters:
$setting - The setting name.
$value - The value to set.
$fallback - Add the setting only if it doesn't exist.
Function: remove
----------------
Removes a configuration setting.
Parameters:
$setting - The setting name.
Function: current
-----------------
Returns a singleton reference to the current configuration.
==============================================
includes/class/Controllers.php
==============================================
Class: Controllers
------------------
Acts as the backbone for all controllers.
==============================================
includes/class/Feathers.php
==============================================
Class: Feathers
---------------
Contains various functions, acts as the backbone for all feathers.
Function: setFilter
-------------------
Applies a filter to a specified field of the Feather.
Parameters:
$field - Attribute of the post to filter.
$name - Name of the filter to use.
See Also:
<Trigger.filter>
Function: customFilter
----------------------
Allows a Feather to apply its own filter to a specified field.
Parameters:
$field - Attribute of the post to filter.
$name - Name of the class function to use as the filter.
See Also:
<Trigger.filter>
Function: respondTo
-------------------
Allows a Feather to respond to a Trigger as a Module would.
Parameters:
$name - Name of the trigger to respond to.
$function - Name of the class function to respond with.
$priority - Priority of the response.
See Also:
<Trigger>
Function: setField
------------------
Sets the feather's fields for creating/editing posts with that feather.
Parameters:
$options - An array of key => val options for the field.
Options:
attr - The technical name for the field. Think $post->attr.
type - The field type. (text, file, text_block, or select)
label - The label for the field.
optional - Is this field optional?
extra - Stuff to output after the input field. Can be anything.
note - A minor note to display next to the label text.
==============================================
includes/class/Flash.php
==============================================
Class: Flash
------------
Stores messages, notices, and warnings to display to the user after a redirect.
Function: __construct
---------------------
Prepares the structure of session values.
Function: prepare
-----------------
Prepare the structure of a session value.
Function: message
-----------------
Create a message (neutral).
Parameters:
$message - Text of the message.
$redirect_to - URL to redirect to after the message is stored.
$code - Numeric HTTP status code to set.
Function: notice
----------------
Create a notice (positive).
Parameters:
$message - Text of the notice.
$redirect_to - URL to redirect to after the notice is stored.
$code - Numeric HTTP status code to set.
Function: warning
-----------------
Create a warning (negative).
Parameters:
$message - Text of the warning.
$redirect_to - URL to redirect to after the warning is stored.
$code - Numeric HTTP status code to set.
Function: messages
------------------
Calls <Flash.serve> "messages".
Function: notices
-----------------
Calls <Flash.serve> "notices".
Function: warnings
------------------
Calls <Flash.serve> "warnings".
Function: all
-------------
Serves an associative array of all flashes.
Returns:
An array of every flash available,
in the form of [type => [flashes]].
Function: serve
---------------
Serves flashes and removes them from the session.
Parameters:
$type - Type of flashes to serve.
Returns:
An array of flashes of the requested type.
Function: exists
----------------
Checks for the existence of stored flashes.
Parameters:
$type - Type to check for (optional).
Function: count
---------------
Counts the total number of stored flashes.
Parameters:
$type - Type to check for (optional).
Function: current
-----------------
Returns a singleton reference to the current class.
==============================================
includes/class/Model.php
==============================================
Class: Model
------------
The basis for the Models system.
Function: __get
---------------
Handles model relationships, deferred and dynamic attributes.
Returns:
@mixed@
Function __set
--------------
Handles dynamic attributes.
Function: __isset
-----------------
Handles model relationships, deferred and dynamic attributes.
Function: grab
--------------
Grabs a single model from the database.
Parameters:
$model - The instantiated model class to pass the object to (e.g. Post).
$id - The ID of the model to grab. Can be null.
$options - An array of options, mostly SQL things.
Options:
select - What to grab from the table.
from - Which table(s) to grab from?
left_join - A @LEFT JOIN@ associative array.
where - A string or array of conditions.
params - An array of parameters to pass to the SQL driver.
group - A string or array of "GROUP BY" conditions.
order - What to order the SQL result by.
offset - Offset for SQL query.
read_from - An array to read from instead of performing another query.
ignore_dupes - An array of columns in which duplicate values will be retained.
Function: search
----------------
Returns an array of model objects that are found by the $options array.
Parameters:
$options - An array of options, mostly SQL things.
$options_for_object - An array of options for the instantiation of the model.
Options:
select - What to grab from the table.
from - Which table(s) to grab from?
left_join - A @LEFT JOIN@ associative array.
where - A string or array of conditions.
params - An array of parameters to pass to the SQL driver.
group - A string or array of "GROUP BY" conditions.
order - What to order the SQL result by.
offset - Offset for SQL query.
limit - Limit for SQL query.
placeholders - Return an array of arrays instead of an array of objects?
ignore_dupes - An array of columns in which duplicate values will be retained.
See Also:
<Model.grab>
Function: delete
----------------
Deletes a given object.
Parameters:
$model - The model name.
$id - The ID of the object to delete.
$options_for_object - An array of options for the instantiation of the model.
Function: deletable
-------------------
Checks if the <User> can delete the object.
Function: editable
------------------
Checks if the <User> can edit the object.
Function: edit_link
-------------------
Outputs an edit link for the model, if the visitor's <Group.can> edit_[model].
Parameters:
$text - The text to show for the link.
$before - If the link can be shown, show this before it.
$after - If the link can be shown, show this after it.
$classes - Extra CSS classes for the link, space-delimited.
Function: delete_link
---------------------
Outputs a delete link for the post, if the <User.can> delete_[model].
Parameters:
$text - The text to show for the link.
$before - If the link can be shown, show this before it.
$after - If the link can be shown, show this after it.
$classes - Extra CSS classes for the link, space-delimited.
Function: etag
--------------
Generates an Etag for the object.
==============================================
includes/class/Modules.php
==============================================
Class: Modules
--------------
Contains various functions, acts as the backbone for all modules.
Function: setPriority
---------------------
Sets the priority of an action for the module this function is called from.
Parameters:
$name - Name of the trigger to respond to.
$priority - Priority of the response.
Function: addAlias
------------------
Allows a module to respond to a trigger with multiple functions and custom priorities.
Parameters:
$name - Name of the trigger to respond to.
$function - Name of the class function to respond with.
$priority - Priority of the response.
==============================================
includes/class/Paginator.php
==============================================
Class: Paginator
----------------
Paginates over an array.
Function: __construct
---------------------
Prepares an array for pagination.
Parameters:
$array - The array to paginate.
$per_page - Number of items per page.
$name - The $_GET parameter name to determin the current page.
$model - Is it an array of model placeholders to be initialized?
$page - Page number to start at.
Notes:
If $model is true, each $array item shown on the page will
be initialized as a model of the type specified in $array[1].
$array[0] is expected to be an array of model placeholders.
Function: reslice
-----------------
Reslices pagination with a new number of items per page.
Parameters:
$per_page - Number of items per page.
Function: next
--------------
Returns the next pagination sequence.
Function: prev
--------------
Returns the previous pagination sequence.
Function: next_page
-------------------
Checks whether or not it makes sense to show the Next Page link.
Function: prev_page
-------------------
Checks whether or not it makes sense to show the Previous Page link.
Function: next_link
-------------------
Outputs a link to the next page.
Parameters:
$text - The text for the link.
$class - The CSS class for the link.
$page - Page number to link to.
$anchor - An anchor target.
Function: prev_link
-------------------
Outputs a link to the previous page.
Parameters:
$text - The text for the link.
$class - The CSS class for the link.
$page - Page number to link to.
$anchor - An anchor target.
Function: final_link
--------------------
Outputs a link to the final page.
Parameters:
$text - The text for the link.
$class - The CSS class for the link.
$anchor - An anchor target.
Function: first_link
--------------------
Outputs a link to the first page.
Parameters:
$text - The text for the link.
$class - The CSS class for the link.
$anchor - An anchor target.
Function: next_page_url
-----------------------
Returns the URL to the next page.
Parameters:
$page - Page number to link to.
Function: prev_page_url
-----------------------
Returns the URL to the previous page.
Parameters:
$page - Page number to link to.
==============================================
includes/class/Query.php
==============================================
Class: Query
------------
Handles a SQL query.
Function: __construct
---------------------
Creates a query based on the <SQL.interface>.
Parameters:
$sql - <SQL> instance.
$query - Query to execute.
$params - An associative array of parameters used in the query.
$throw_exceptions - Throw exceptions instead of calling error()?
Function: fetchColumn
---------------------
Fetches a column of the current row.
Parameters:
$column - The offset of the column to grab. Default 0.
Function: fetch
---------------
Returns the current row as an array.
Function: fetchObject
---------------------
Returns the current row as an object.
Function: fetchAll
------------------
Returns an array of every result.
Function: grab
--------------
Grabs all of the given column out of the full result of a query.
Parameters:
$column - Name of the column to grab.
Returns:
An array of all of the values of that column in the result.
Function: exception_handler
---------------------------
Handles exceptions thrown by failed queries.
==============================================
includes/class/QueryBuilder.php
==============================================
Class: QueryBuilder
-------------------
A generic SQL query builder.
Function: build_select
----------------------
Creates a full SELECT query.
Parameters:
$sql - The SQL instance calling this method.
$tables - Tables to select from.
$fields - Columns to select.
$order - What to order by.
$limit - Limit of the result.
$offset - Starting point for the result.
$group - What to group by.
$left_join - Any @LEFT JOIN@s to add.
&$params - An associative array of parameters used in the query.
Returns:
A @SELECT@ query string.
Function: build_insert
----------------------
Creates a full insert query.
Parameters:
$sql - The SQL instance calling this method.
$table - Table to insert into.
$data - Data to insert.
&$params - An associative array of parameters used in the query.
Returns:
An @INSERT@ query string.
Function: build_update
----------------------
Creates a full update query.
Parameters:
$sql - The SQL instance calling this method.
$table - Table to update.
$conds - Conditions to update rows by.
$data - Data to update.
&$params - An associative array of parameters used in the query.
Returns:
An @UPDATE@ query string.
Function: build_delete
----------------------
Creates a full delete query.
Parameters:
$sql - The SQL instance calling this method.
$table - Table to delete from.
$conds - Conditions to delete by.
&$params - An associative array of parameters used in the query.
Returns:
A @DELETE@ query string.
Function: build_drop
--------------------
Creates a full drop table query.
Parameters:
$sql - The SQL instance calling this method.
$table - Table to drop.
Returns:
A @DROP TABLE@ query string.
Function: build_create
----------------------
Creates a full create table query.
Parameters:
$sql - The SQL instance calling this method.
$table - Table to create.
$cols - An array of column declarations.
Returns:
A @CREATE TABLE@ query string.
Function: build_update_values
-----------------------------
Creates an update data part.
Parameters:
$sql - The SQL instance calling this method.
$data - Data to update.
&$params - An associative array of parameters used in the query.
Function: build_insert_header
-----------------------------
Creates an insert header.
Parameters:
$sql - The SQL instance calling this method.
$data - Data to insert.
Function: build_limits
----------------------
Creates the LIMIT part of a query.
Parameters:
$sql - The SQL instance calling this method.
$offset - Offset of the result.
$limit - Limit of the result.
Function: build_from
--------------------
Creates a FROM header for select queries.
Parameters:
$sql - The SQL instance calling this method.
$tables - Tables to select from.
Function: build_count
---------------------
Creates a SELECT COUNT(1) query.
Parameters:
$sql - The SQL instance calling this method.
$tables - Tables to tablefy with.
$conds - Conditions to select by.
&$params - An associative array of parameters used in the query.
Function: build_select_header
-----------------------------
Creates a SELECT fields header.
Parameters:
$sql - The SQL instance calling this method.
$fields - Columns to select.
$tables - Tables to tablefy with.
Function: build_where
---------------------
Creates a WHERE query.
Parameters:
$sql - The SQL instance calling this method.
$conds - Conditions to select by.
$tables - Tables to tablefy with.
&$params - An associative array of parameters used in the query.
Function: build_group
---------------------
Creates a GROUP BY argument.
Parameters:
$sql - The SQL instance calling this method.
$order - Columns to group by.
$tables - Tables to tablefy with.
Function: build_order
---------------------
Creates an ORDER BY argument.
Parameters:
$sql - The SQL instance calling this method.
$order - Columns to order by.
$tables - Tables to tablefy with.
Function: build_list
--------------------
Creates a list of values.
Parameters:
$sql - The SQL instance calling this method.
$vals - An array of values.
&$params - An associative array of parameters used in the query.
Function: safecol
-----------------
Encloses a column name in quotes if it is a subset of SQL keywords.
Parameters:
$sql - The SQL instance calling this method.
$name - Name of the column.
Function: build_conditions
--------------------------
Builds an associative array of SQL values into parameterized query strings.
Parameters:
$sql - The SQL instance calling this method.
$conds - Conditions.
&$params - Parameters array to fill.
$tables - If specified, conditions will be tablefied with these tables.
$insert - Is this an insert/update query?
Function: tablefy
-----------------
Prepends table names and prefixes to a field if it doesn't already have them.
Parameters:
$sql - The SQL instance calling this method.
&$field - The field to "tablefy".
$tables - An array of tables. The first one will be used for prepending.
==============================================
includes/class/Route.php
==============================================
Class: Route
------------
Handles the routing process and other route-related tasks.
Function: __construct
---------------------
Parse the URL and give the controller an opportunity to determine the action.
Parameters:
$controller - The controller to use.
Function: init
--------------
Attempt to call a responder until one of them doesn't return false.
Function: url
-------------
Constructs an absolute URL from a relative one. Converts clean URLs to dirty.
Parameters:
$url - The relative URL. Assumed to be dirty if it begins with "/".
$controller - The controller to use. Current controller used if omitted.
Returns:
An absolute clean or dirty URL, depending on value of @Config->clean_urls@
and @controller->clean_urls@.
Function: add
-------------
Adds a route to the blog.
Parameters:
$path - The path to add. Wrap variables with () e.g. "tag/(name)/".
$action - The action. Add parameters with ; e.g "tag;foo=bar;baz=boo".
Notes:
Required for actions that have more than one parameter.
For example, not needed for /tags/ but needed for /tag/(name)/.
See Also:
<remove>
Function: remove
----------------
Removes a route added by <add>.
Parameters:
$path - The path to remove.
See Also:
<add>
Function: custom
----------------
Parses custom routes stored in the configuration.
Notes:
The / path strictly requires no request args.
Function: current
-----------------
Returns a singleton reference to the current class.
==============================================
includes/class/Session.php
==============================================
Class: Session
--------------
Handles visitor sessions.
Function: open
--------------
Opens the session and decides if session storage will be denied.
Parameters:
$path - Filesystem path.
$name - The session name.
Function: close
---------------
Executed when the session is closed.
Function: read
--------------
Reads a session from the database.
Parameters:
$id - Session ID.
Function: write
---------------
Writes a session to the database.
Parameters:
$id - Session ID.
$data - Data to write.
Function: destroy
-----------------
Deletes a session from the database.
Parameters:
$id - Session ID.
Function: gc
------------
Deletes sessions not updated for 30+ days, or with no stored data.
Parameters:
$lifetime - The configured maximum session lifetime in seconds.
Function: hash_token
--------------------
Generates an authentication token for this session.
Function: check_token
---------------------
Validates an authentication token for this session.
Parameters:
$hash - The token to validate.
==============================================
includes/class/SQL.php
==============================================
Class: SQL
----------
Contains the database settings and functions for interacting with the SQL database.
Function: __construct
---------------------
The class constructor is private so there is only one connection.
Parameters:
$settings - An array of settings (optional).
Function: connect
-----------------
Connects to the SQL database.
Parameters:
$checking - Return a boolean for failure, instead of triggering an error?
Function: query
---------------
Executes a query and increases <SQL->$queries>.
Parameters:
$query - Query to execute.
$params - An associative array of query parameters.
$throw_exceptions - Should exceptions be thrown on error?
Function: count
---------------
Performs a counting query and returns the number of matching rows.
Parameters:
$tables - An array (or string) of tables to count results on.
$conds - Rows to count. Supply @false@ to count all rows.
$params - An associative array of query parameters.
$throw_exceptions - Should exceptions be thrown on error?
Function: select
----------------
Performs a SELECT with given criteria and returns the query result object.
Parameters:
$tables - An array (or string) of tables to grab results from.
$fields - Fields to select.
$conds - Rows to select. Supply @false@ to select all rows.
$order - ORDER BY statement. Can be an array.
$params - An associative array of query parameters.
$limit - Limit for results.
$offset - Offset for the select statement.
$group - GROUP BY statement. Can be an array.
$left_join - An array of additional LEFT JOINs.
$throw_exceptions - Should exceptions be thrown on error?
Function: insert
----------------
Performs an INSERT with given data.
Parameters:
$table - Table to insert to.
$data - An associative array of data to insert.
$params - An associative array of query parameters.
$throw_exceptions - Should exceptions be thrown on error?
Function: replace
-----------------
Performs either an INSERT or an UPDATE depending
on whether a row exists with the specified keys.
Parameters:
$table - Table to update or insert into.
$keys - Columns to match on.
$data - Data for the insert and value matches for the keys.
$params - An associative array of query parameters.
$throw_exceptions - Should exceptions be thrown on error?
Function: update
----------------
Performs an UDATE with given criteria and data.
Parameters:
$table - Table to update.
$conds - Rows to update. Supply @false@ to update all rows.
$data - An associative array of data to update.
$params - An associative array of query parameters.
$throw_exceptions - Should exceptions be thrown on error?
Function: delete
----------------
Performs a DELETE with given criteria.
Parameters:
$table - Table to delete from.
$conds - Rows to delete. Supply @false@ to delete all rows.
$params - An associative array of query parameters.
$throw_exceptions - Should exceptions be thrown on error?
Function: drop
--------------
Performs a DROP TABLE with given criteria.
Parameters:
$table - Table to drop.
$throw_exceptions - Should exceptions be thrown on error?
Function: create
----------------
Performs a CREATE TABLE with given criteria.
Parameters:
$table - Table to create.
$cols - An array of column declarations.
$throw_exceptions - Should exceptions be thrown on error?
Function: latest
----------------
Returns the last inserted sequential value.
Parameters:
$table - Table to get the latest value from.
$seq - Name of the sequence.
Function: escape
----------------
Escapes a string for Query construction.
Parameters:
$string - String to escape.
Function: current
-----------------
Returns a singleton reference to the current connection.
==============================================
includes/class/Theme.php
==============================================
Class: Theme
------------
Various helper functions for blog themes.
Function: __construct
---------------------
Populates useful attributes.
Function: pages_list
--------------------
Returns an array of pages with @depth@ and @children@ attributes.
Parameters:
$page_id - Page ID to start from, or zero to return all pages.
$exclude - Page ID/s to exclude, integer or array of integers.
Function: recurse_pages
-----------------------
Populates the page cache and gives each page the attributes
of @depth@ (integer, 1 or greater) and @children@ (boolean).
Parameters:
$page - Page to start recursion at.
Function: archive_list
----------------------
Generates an array listing each month with entries in the archives.
Parameters:
$limit - Maximum number of months to list.
Function: recent_posts
----------------------
Generates an array of recent posts.
Parameters:
$limit - Maximum number of recent posts to list.
Function: related_posts
-----------------------
Ask modules to contribute to a list of related posts.
Parameters:
$post - The post to use as the basis.
$limit - Maximum number of related posts to list.
Function: file_exists
---------------------
Returns whether the specified Twig template file exists or not.
Parameters:
$name - The filename.
Function: stylesheets
---------------------
Outputs the stylesheet tags.
Function: javascripts
---------------------
Outputs the JavaScript tags.
Function: feeds
---------------
Outputs the feeds and other general purpose <link> tags.
Function: load_time
-------------------
Returns the total elapsed time for this page load.
Function: current
-----------------
Returns a singleton reference to the current class.
==============================================
includes/class/Translation.php
==============================================
Class: Translation
------------------
A shim for translation support in the absence of GNU gettext.
Function: __construct
---------------------
Discovers the current locale.
Function: load
--------------
Loads translations from the .mo file into the supplied domain.
Parameters:
$domain - The name of this translation domain.
$path - The path to the locale directory.
$reload - Reload the translation if already loaded?
Function: text
--------------
Returns the singular or plural translation of a string.
Parameters:
$domain - The translation domain to search.
$single - Singular string.
$plural - Pluralized string (optional).
$number - The number to judge by (optional).
Function: find
--------------
Returns a translation array from the supplied domain.
Function: nplural
-----------------
Support for for languages with n != 2 plural forms.
Function: current
-----------------
Returns a singleton reference to the current class.
==============================================
includes/class/Trigger.php
==============================================
Class: Trigger
--------------
Controls and keeps track of all of the Triggers and events.
Function: __construct
---------------------
Add predefined filters to implement Unicode emoji and Markdown support.
Function: cmp
-------------
Sorts actions by priority when used with usort.
Function: decide
----------------
Decides what to do with a call return value.
Function: call
--------------
Calls a trigger action.
Parameters:
$name - The name of the trigger, or an array of triggers to call.
Returns:
A concatenated string if all calls return a string, or;
@false@ if none of the triggers exist, or;
the most substantial returned value decided by oneof().
Notes:
Any additional arguments are passed on to the trigger responders.
Function: filter
----------------
Modify a variable by filtering it through a stack of trigger actions.
Parameters:
&$target - The variable to filter.
$name - The name of the trigger.
Returns:
$target, filtered through any/all actions for the trigger $name.
Notes:
Any additional arguments are passed on to the trigger responders.
Function: exists
----------------
Checks if there are any actions for a given $trigger.
Parameters:
$trigger - The trigger name.
Returns:
@true@ or @false@
Function: current
-----------------
Returns a singleton reference to the current class.
==============================================
includes/class/Update.php
==============================================
Class: Update
-------------
Informs the user if a newer version of Chyrp Lite is available.
Function: check
---------------
Checks the update channel.
Function: validate
------------------
Validates the XML dataset.
Function: message
-----------------
Flash the user about the newer version.
Function: warning
-----------------
Flash the user about the failed check.
==============================================
includes/common.php
==============================================
File: common
------------
Configures the Chyrp Lite environment.
==============================================
includes/controller/Admin.php
==============================================
Class: AdminController
----------------------
The logic controlling the administration console.
Function: __construct
---------------------
Loads the Twig parser and sets up the l10n domain.
Function: parse
---------------
Route constructor calls this to interpret clean URLs and determine the action.
Function: exempt
----------------
Route constructor calls this to determine "view_site" exemptions.
Function: admin_write_post
--------------------------
Post writing.
Function: admin_add_post
------------------------
Adds a post when the form is submitted.
Function: admin_edit_post
-------------------------
Post editing.
Function: admin_update_post
---------------------------
Updates a post when the form is submitted.
Function: admin_delete_post
---------------------------
Post deletion (confirm page).
Function: admin_destroy_post
----------------------------
Destroys a post.
Function: admin_manage_posts
----------------------------
Post management.
Function: admin_write_page
--------------------------
Page creation.
Function: admin_add_page
------------------------
Adds a page when the form is submitted.
Function: admin_edit_page
-------------------------
Page editing.
Function: admin_update_page
---------------------------
Updates a page when the form is submitted.
Function: admin_delete_page
---------------------------
Page deletion (confirm page).
Function: admin_destroy_page
----------------------------
Destroys a page.
Function: admin_manage_pages
----------------------------
Page management.
Function: admin_new_user
------------------------
User creation.
Function: admin_add_user
------------------------
Add a user when the form is submitted.
Function: admin_edit_user
-------------------------
User editing.
Function: admin_update_user
---------------------------
Updates a user when the form is submitted.
Function: admin_delete_user
---------------------------
User deletion (confirm page).
Function: admin_destroy_user
----------------------------
Destroys a user.
Function: admin_manage_users
----------------------------
User management.
Function: admin_new_group
-------------------------
Group creation.
Function: admin_add_group
-------------------------
Adds a group when the form is submitted.
Function: admin_edit_group
--------------------------
Group editing.
Function: admin_update_group
----------------------------
Updates a group when the form is submitted.
Function: admin_delete_group
----------------------------
Group deletion (confirm page).
Function: admin_destroy_group
-----------------------------
Destroys a group.
Function: admin_manage_groups
-----------------------------
Group management.
Function: admin_delete_upload
-----------------------------
Upload deletion (confirm page).
Function: admin_destroy_upload
------------------------------
Destroys a post.
Function: admin_manage_uploads
------------------------------
Upload management.
Function: admin_export
----------------------
Export content from this installation.
Function: admin_import
----------------------
Import content to this installation.
Function: admin_modules
-----------------------
Module enabling/disabling.
Function: admin_feathers
------------------------
Feather enabling/disabling.
Function: admin_themes
----------------------
Theme switching/previewing.
Function: admin_enable
----------------------
Enables a module or feather.
Function: admin_disable
-----------------------
Disables a module or feather.
Function: admin_change_theme
----------------------------
Changes the theme.
Function: admin_preview_theme
-----------------------------
Previews the theme.
Function: admin_general_settings
--------------------------------
General Settings page.
Function: admin_content_settings
--------------------------------
Content Settings page.
Function: admin_user_settings
-----------------------------
User Settings page.
Function: admin_route_settings
------------------------------
Route Settings page.
Function: admin_download_rewrites
---------------------------------
Downloads the files required for URL rewrite support.
Function: admin_login
---------------------
Mask for MainController->login().
Function: admin_logout
----------------------
Mask for MainController->logout().
Function: admin_help
--------------------
Serves help pages for core and extensions.
Function: navigation_context
----------------------------
Returns the navigation context for Twig.
Function: display
-----------------
Displays the page.
Parameters:
$template - The template file to display.
$context - The context to be supplied to Twig.
$title - The title for the page (optional).
$pagination - <Paginator> instance (optional).
Notes:
$template is supplied sans ".twig" and relative to /admin/
for core and extensions.
$title defaults to a camelization of the template filename,
e.g. foo_bar -> Foo Bar.
$pagination will be inferred from the context if not supplied.
Function: current
-----------------
Returns a singleton reference to the current class.
==============================================
includes/controller/Ajax.php
==============================================
Class: AjaxController
---------------------
The logic controlling AJAX requests.
Function: parse
---------------
Route constructor calls this to determine the action in the case of a POST request.
Function: exempt
----------------
Route constructor calls this to determine "view_site" exemptions.
Function: ajax_destroy_post
---------------------------
Destroys a post.
Function: ajax_destroy_page
---------------------------
Destroys a page.
Function: ajax_preview_post
---------------------------
Previews a post.
Function: ajax_preview_page
---------------------------
Previews a page.
Function: ajax_file_upload
--------------------------
Moves a file to the uploads directory.
Function: current
-----------------
Returns a singleton reference to the current class.
==============================================
includes/controller/Main.php
==============================================
Class: MainController
---------------------
The logic controlling the blog.
Function: __construct
---------------------
Loads the Twig parser and sets up the l10n domain.
Function: parse
---------------
Route constructor calls this to interpret clean URLs and determine the action.
Function: exempt
----------------
Route constructor calls this to determine "view_site" exemptions.
Function: main_index
--------------------
Grabs the posts for the main index.
Function: main_updated
----------------------
Grabs the posts that have been updated.
Function: main_author
---------------------
Grabs the posts created by a user.
Function: main_archive
----------------------
Grabs the posts for the archive page.
Function: main_search
---------------------
Grabs the posts and pages for a search query.
Function: main_drafts
---------------------
Grabs the posts with draft status created by this user.
Function: main_view
-------------------
Handles post viewing via dirty URL or clean URL.
E.g. /year/month/day/url/.
Function: main_page
-------------------
Handles page viewing via dirty URL or clean URL.
E.g. /parent/child/child-of-child/.
Function: main_id
-----------------
Views a post or page by its static ID.
Function: main_random
---------------------
Grabs a random post and redirects to it.
Function: main_matter
---------------------
Displays a standalone Twig template from the "pages" directory.
Function: main_register
-----------------------
Register a visitor as a new user.
Function: main_activate
-----------------------
Activates (approves) a given login.
Function: main_login
--------------------
Logs in a user if they provide the username and password.
Function: main_logout
---------------------
Logs out the current user.
Function: main_controls
-----------------------
Updates the current user when the form is submitted.
Function: main_lost_password
----------------------------
Emails a password reset link to the registered address of a user.
Function: main_reset_password
-----------------------------
Resets the password for a given login.
Function: main_webmention
-------------------------
Webmention receiver endpoint.
Function: main_feed
-------------------
Grabs posts and serves a feed.
Function: display
-----------------
Displays the page, or serves a feed if requested.
Parameters:
$template - The template file to display.
$context - The context to be supplied to Twig.
$title - The title for the page (optional).
$pagination - <Paginator> instance (optional).
Notes:
$template is supplied sans ".twig" and relative to THEME_DIR.
$template can be an array of fallback template filenames to try.
$pagination will be inferred from the context if not supplied.
Function: current
-----------------
Returns a singleton reference to the current class.
==============================================
includes/download.php
==============================================
File: download
--------------
Serve an uploaded file to the visitor as a file attachment.
==============================================
includes/error.php
==============================================
File: error
-----------
Functions for handling and reporting errors.
Function: error_composer
------------------------
Composes a message for the error() function to display.
Function: exception_composer
----------------------------
Composes a message for the error() function to display.
Function: error
---------------
Displays an error message via direct call or handler.
Parameters:
$title - The title for the error dialog.
$body - The message for the error dialog.
$backtrace - The trace of the error.
$code - Numeric HTTP status code to set.
==============================================
includes/helpers.php
==============================================
File: helpers
-------------
Various functions used throughout the codebase.
Function: session
-----------------
Begins Chyrp's custom session storage whatnots.
Parameters:
$secure - Send the cookie only over HTTPS?
Function: logged_in
-------------------
Mask for Visitor::logged_in().
Function: authenticate
----------------------
Mask for Session::hash_token().
Function: redirect
------------------
Redirects to the supplied URL and exits immediately.
Parameters:
$url - The absolute or relative URL to redirect to.
$code - Numeric HTTP status code to set (optional).
Function: show_403
------------------
Shows an error message with a 403 HTTP header.
Parameters:
$title - The title for the error dialog (optional).
$body - The message for the error dialog (optional).
Function: show_404
------------------
Shows an error message with a 404 HTTP header.
Parameters:
$title - The title for the error dialog (optional).
$body - The message for the error dialog (optional).
Function: url
-------------
Mask for Route::url().
Function: self_url
------------------
Returns an absolute URL for the current request.
Function: htaccess_conf
-----------------------
Creates the Apache rewrites for Chyrp Lite.
Parameters:
$url_path - The URL path to MAIN_DIR.
Returns:
The rewrite rules, or false on failure.
Function: caddyfile_conf
------------------------
Creates the Caddy rewrites for Chyrp Lite.
Parameters:
$url_path - The URL path to MAIN_DIR.
Returns:
The rewrite rules, or false on failure.
Function: nginx_conf
--------------------
Creates the nginx rewrites for Chyrp Lite.
Parameters:
$url_path - The URL path to MAIN_DIR.
Returns:
The rewrite rules, or false on failure.
Function: locales
-----------------
Returns an array of locale choices for the "chyrp" domain.
Function: set_locale
--------------------
Sets the locale with fallbacks for platform-specific quirks.
Parameters:
$locale - The locale name, e.g. @en_US@, @uk_UA@, @fr_FR@
Function: get_locale
--------------------
Gets the current locale setting.
Notes:
Does not use setlocale() because the return value is non-normative.
Function: load_translator
-------------------------
Sets the path for a gettext translation domain.
Parameters:
$domain - The name of this translation domain.
$locale - The path to the locale directory.
Function: lang_code
-------------------
Converts a language code to a localised display name.
Parameters:
$code - The language code to convert.
Returns:
A localised display name, e.g. "English (United States)".
Function: lang_base
-------------------
Extracts the primary language subtag for the supplied code.
Parameters:
$code - The language code to extract from.
Returns:
The primary subtag for this code, e.g. "en" from "en_US".
Function: text_direction
------------------------
Returns the correct text direction for the supplied language code.
Parameters:
$code - The language code.
Returns:
Either the string "ltr" or "rtl".
Function: __
------------
Translates a string using gettext.
Parameters:
$text - The string to translate.
$domain - The translation domain to read from.
Returns:
The translated string or the original.
Function: _p
------------
Translates a plural (or not) form of a string.
Parameters:
$single - Singular string.
$plural - Pluralized string.
$number - The number to judge by.
$domain - The translation domain to read from.
Returns:
The translated string or the original.
Function: _f
------------
Translates a string with sprintf() formatting.
Parameters:
$string - String to translate and format.
$args - One arg or an array of arguments to format with.
$domain - The translation domain to read from.
Returns:
The translated string or the original.
Function: _w
------------
Formats and internationalizes a string that isn't a regular time() value.
Parameters:
$formatting - The date()-compatible formatting.
$when - A time() value or string to be strtotime() converted.
Returns:
An internationalized time/date string with the supplied formatting.
Function: when
--------------
Formats a string that isn't a regular time() value.
Parameters:
$formatting - The formatting for date().
$when - A time() value or string to be strtotime() converted.
Returns:
A time/date string with the supplied formatting.
Function: datetime
------------------
Formats datetime for SQL queries.
Parameters:
$when - A timestamp (optional).
Returns:
A standard datetime string.
Function: now
-------------
Alias to strtotime, for prettiness like now("+1 day").
Function: convert_datetime
--------------------------
Converts datetime formatting from PHP to ICU format.
Parameters:
$formatting - The datetime formatting.
See Also:
https://unicode-org.github.io/icu/userguide/format_parse/datetime/
https://www.php.net/manual/en/datetime.format.php
Function: timezones
-------------------
Returns an array of timezone identifiers.
Function: set_timezone
----------------------
Sets the timezone for all date/time functions.
Parameters:
$timezone - The timezone to set.
Function: get_timezone
----------------------
Gets the timezone for all date/time functions.
Function: fallback
------------------
Sets the supplied variable if it is not already set.
Parameters:
&$variable - The variable to set and return.
Returns:
The value that was assigned to the variable.
Notes:
Additional arguments supplied to this function will be considered as
candidate values. The variable will be set to the value of the first
non-empty argument, or the last, or null if no arguments are supplied.
Function: oneof
---------------
Inspects the supplied arguments and returns the first substantial value.
Returns:
The first substantial value in the set, or the last, or null.
Notes:
Some type combinations will halt inspection of the full set:
- All types are comparable with null.
- All scalar types are comparable.
- Arrays, objects, and resources are incomparable with other types.
Function: token
---------------
Salt and hash a unique token using the supplied data.
Parameters:
$items - An array of items to hash.
Returns:
A unique token salted with the site's secure hashkey.
Function: crc24
---------------
Performs a 24-bit cyclic redundancy check.
Parameters:
$str - The data to check.
$polynomial - The polynomial to use.
$ini - The initial remainder value.
$xor - The value for the final XOR.
Returns:
The integer value of the check result.
Function: slug
--------------
Generates a random slug value for posts and pages.
Parameters:
$length - The number of characters to generate.
Returns:
A string of the requested length.
Function: random
----------------
Generates a string of alphanumeric random characters.
Parameters:
$length - The number of characters to generate.
Returns:
A string of the requested length.
Notes:
Uses a cryptographically secure pseudo-random method.
Function: shorthand_bytes
-------------------------
Decode shorthand bytes notation from php.ini.
Parameters:
$value - The value returned by ini_get().
Returns:
A byte value or the input if decoding failed.
Function: set_max_time
----------------------
Sets the PHP time limit to MAX_TIME_LIMIT.
Function: set_max_memory
------------------------
Sets the PHP memory limit to MAX_MEMORY_LIMIT.
Function: timer_start
---------------------
Starts the internal timer and returns the microtime.
Function: timer_stop
--------------------
Returns the elapsed time since the timer started.
Parameters:
$precision - Round to n decimal places.
Returns:
A formatted number with the requested $precision.
Function: match_any
-------------------
Try to match a string against an array of regular expressions.
Parameters:
$try - An array of regular expressions, or a single regular expression.
$haystack - The string to test.
Returns:
Whether or not the match succeeded.
Function: autoload
------------------
Autoload PSR-0 classes on demand by scanning lib directories.
Parameters:
$class - The name of the class to load.
Function: keywords
------------------
Parse keyword searches for values in specific database columns.
Parameters:
$query - The query to parse.
$plain - WHERE syntax to search for non-keyword queries.
$table - Check this table to ensure the keywords are valid.
Returns:
An array containing an array of "WHERE" conditions, an array
of "WHERE" parameters, and "ORDER BY" clause for the results.
Non-keyword text will be parameterized as array[1][":query"].
Function: pluralize
-------------------
Pluralizes a word.
Parameters:
$string - The lowercase string to pluralize.
$number - A number to determine pluralization.
Returns:
The supplied word with a trailing "s" added,
or the correct non-normative pluralization.
Function: depluralize
---------------------
Singularizes a word.
Parameters:
$string - The lowercase string to depluralize.
$number - A number to determine depluralization.
Returns:
The supplied word with trailing "s" removed,
or the correct non-normative singularization.
Function: normalize
-------------------
Attempts to normalize newlines and whitespace into single spaces.
Returns:
The normalized string.
Function: camelize
------------------
Converts a string to camel-case.
Parameters:
$string - The string to camelize.
$keep_spaces - Convert underscores to spaces?
Returns:
A CamelCased string.
See Also:
<decamelize>
Function: decamelize
--------------------
Undoes camel-case conversion.
Parameters:
$string - The string to decamelize.
Returns:
A de_camel_cased string.
See Also:
<camelize>
Function: truncate
------------------
Truncates a string to the requested number of characters or less.
Parameters:
$text - The string to be truncated.
$length - Truncate the string to this number of characters.
$ellipsis - A string to place at the truncation point.
$exact - Split words to return the exact length requested?
Returns:
A truncated string, with ellipsis appended, of <length> or less.
Function: markdown
------------------
Implements the Markdown content parsing filter.
Parameters:
$text - The body of the post/page to parse.
$context - Model instance for context (optional).
Returns:
The text with Markdown formatting applied.
See Also:
https://github.com/commonmark/CommonMark
https://github.github.com/gfm/
https://chyrplite.net/wiki/Chyrp-Flavoured-Markdown.html
Function: emote
---------------
Converts emoticons to Unicode emoji HTML entities.
Parameters:
$text - The body of the post/page to parse.
Returns:
The text with emoticons replaced by emoji.
See Also:
http://www.unicode.org/charts/PDF/U1F600.pdf
Function: fix
-------------
Neutralizes HTML and quotes in strings for display.
Parameters:
$string - String to fix.
$quotes - Encode quotes?
$double - Encode encoded?
Returns:
A sanitized version of the string.
Function: unfix
---------------
Undoes neutralization of HTML and quotes in strings.
Parameters:
$string - String to unfix.
$all - Decode all entities?
Returns:
An unsanitary version of the string.
Function: sanitize
------------------
Sanitizes a string of troublesome characters, typically for use in URLs.
Parameters:
$string - The string to sanitize - must be ASCII or UTF-8!
$lowercase - Force the string to lowercase?
$strict - Remove all characters except "-" and alphanumerics?
$truncate - Number of bytes to truncate to (0 to disable).
Returns:
A sanitized version of the string.
Function: sanitize_db_string
----------------------------
Purifies and trims a string for a database column.
Parameters:
$string - The string.
$length - The length limit in bytes (optional).
Returns:
A purified and trimmed version of the string.
See Also:
<Post::add> <Page::add> <Group::add> <User::add>
Function: sanitize_html
-----------------------
Sanitizes HTML to disable styles, scripts, and most attributes.
Parameters:
$string - String containing HTML to sanitize.
Returns:
A version of the string containing only valid HTML tags
and whitelisted attributes essential to tag functionality.
Function: get_remote
--------------------
Retrieves the contents of a URL.
Parameters:
$url - The URL of the resource to be retrieved.
$redirects - The maximum number of redirects to follow.
$timeout - The maximum number of seconds to wait.
$headers - Include response headers with the content?
$post - Set the request type to POST instead of GET?
$data - An array or urlencoded string of POST data.
Returns:
The response content, or false on failure.
Function: webmention_send
-------------------------
Sends Webmentions to the URLs discovered in a string.
Parameters:
$string - The string to crawl for Webmention URLs.
$post - The post this string belongs to.
$limit - Execution time limit in seconds (optional).
Function: webmention_receive
----------------------------
Receives and validates Webmentions.
Parameters:
$source - The sender's URL.
$target - The URL of our post.
Function: webmention_discover
-----------------------------
Determines if a URL is capable of receiving Webmentions.
Parameters:
$url - The URL to check.
$redirects - The maximum number of redirects to follow.
Returns:
The Webmention endpoint URL, or false on failure.
Function: grab_urls
-------------------
Crawls a string and grabs hyperlinks from it.
Parameters:
$string - The string to crawl.
Returns:
An array of all URLs found in the string.
Function: merge_urls
--------------------
Combines a base URL and relative path into a target URL.
Parameters:
$base - The base URL.
$rel - The relative path.
Returns:
A merged target URL, or false on failure.
Notes:
Does not attempt to resolve dot segments in the path.
Function: load_info
-------------------
Loads an extension's info.php file and returns an array of attributes.
Function: init_extensions
-------------------------
Initialize all Modules and Feathers.
Function: module_enabled
------------------------
Determines if a module is currently enabled and not cancelled.
Parameters:
$name - The non-camelized name of the module.
Returns:
Whether or not the supplied module is enabled.
Function: feather_enabled
-------------------------
Determines if a feather is currently enabled and not cancelled.
Parameters:
$name - The non-camelized name of the feather.
Returns:
Whether or not the supplied feather is enabled.
Function: cancel_module
-----------------------
Temporarily declares a module cancelled (disabled).
Parameters:
$target - The non-camelized name of the module.
$reason - Why was execution cancelled?
Notes:
A module can cancel itself in its __init() method.
Function: cancel_feather
------------------------
Temporarily declares a feather cancelled (disabled).
Parameters:
$target - The non-camelized name of the feather.
$reason - Why was execution cancelled?
Notes:
A feather can cancel itself in its __init() method.
Function: upload
----------------
Validates and moves an uploaded file to the uploads directory.
Parameters:
$file - The POST method upload array, e.g. $_FILES['userfile'].
$filter - An array of valid extensions (case-insensitive).
Returns:
The filename of the upload relative to the uploads directory.
Function: upload_from_url
-------------------------
Copies a file from a remote URL to the uploads directory.
Parameters:
$url - The URL of the resource to be copied.
$redirects - The maximum number of redirects to follow.
$timeout - The maximum number of seconds to wait.
Returns:
The filename of the copied file, or false on failure.
Function: uploaded
------------------
Generates an absolute URL or filesystem path to an uploaded file.
Parameters:
$filename - Filename relative to the uploads directory.
$url - Whether to return a URL or a filesystem path.
Returns:
The supplied filename prepended with URL or filesystem path.
Function: uploaded_search
-------------------------
Returns an array of files discovered in the uploads directory.
Parameters:
$search - A search term.
$filter - An array of valid extensions (case insensitive).
$sort - One of "name", "type", "size", or "modified".
Function: upload_tester
-----------------------
Tests uploaded file information to determine if the upload was successful.
Parameters:
$file - The POST method upload array, e.g. $_FILES['userfile'].
Returns:
True for a successful upload or false if no file was uploaded.
Notes:
$_POST and $_FILES are empty if post_max_size directive is exceeded.
Function: upload_filename
-------------------------
Generates a sanitized unique name for an uploaded file.
Parameters:
$filename - The filename to make unique.
$filter - An array of valid extensions (case insensitive).
Returns:
A sanitized unique filename, or false on failure.
Function: upload_filter_whitelist
---------------------------------
Returns an array containing a default list of allowed file extensions.
Function: delete_upload
-----------------------
Deletes an uploaded file.
Parameters:
$filename - Filename relative to the uploads directory.
Returns:
Whether or not the file was deleted successfully.
Function: password_strength
---------------------------
Award a numeric score for the strength of a password.
Parameters:
$password - The password string to score.
Returns:
A numeric score for the strength of the password.
Function: is_url
----------------
Does the string look like a web URL?
Parameters:
$string - The string to analyse.
Returns:
Whether or not the string matches the criteria.
Notes:
Recognises FQDN, IPv4 and IPv6.
See Also:
<add_scheme>
Function: add_scheme
--------------------
Prefixes a URL with a scheme if none was detected.
Parameters:
$url - The URL to analyse.
$scheme - Force this scheme (optional).
Returns:
URL prefixed with a default or supplied scheme.
See Also:
<is_url>
Function: is_email
------------------
Does the string look like an email address?
Parameters:
$string - The string to analyse.
Notes:
Recognises FQDN, IPv4 and IPv6.
Returns:
Whether or not the string matches the criteria.
Function: is_unsafe_ip
----------------------
Is the string a private or reserved IP address?
Parameters:
$string - The string to analyse.
Returns:
Whether or not the string matches the criteria.
Function: is_datetime_zero
--------------------------
Is the string a SQL datetime "zero" variant?
Parameters:
$string - The string to analyse.
Returns:
Whether or not the string matches the criteria.
Function: generate_captcha
--------------------------
Generates a captcha form element.
Returns:
A string containing HTML elements to add to a form.
Function: check_captcha
-----------------------
Checks the response to a captcha.
Returns:
Whether or not the captcha was defeated.
Function: esce
--------------
Outputs an escaped echo for JavaScripts.
Parameters:
$variable - The variable to echo.
Notes:
Strings are escaped with backslashes,
booleans expanded to "true" or "false".
Function: icon_img
------------------
Returns an img tag for the requested icon resource.
Parameters:
$filename - The icon filename.
$alt_text - The alternative text for the image.
$class - The CSS class for the image.
Function: icon_svg
------------------
Returns an SVG tag for the requested icon resource.
Parameters:
$filename - The icon filename.
$label - The ARIA label for the SVG.
$class - The CSS class for the SVG.
Function: json_set
------------------
JSON encodes a value and checks for errors.
Parameters:
$value - The value to be encoded.
$options - A bitmask of encoding options.
$depth - Recursion depth for encoding.
Returns:
A JSON encoded string or false on failure.
Function: json_get
------------------
JSON decodes a value and checks for errors.
Parameters:
$value - The UTF-8 string to be decoded.
$assoc - Convert objects into associative arrays?
$depth - Recursion depth for decoding.
$options - A bitmask of decoding options.
Returns:
A JSON decoded value of the appropriate PHP type.
Function: json_response
-----------------------
Send a structured JSON response.
Parameters:
$text - A string containing a response message.
$data - Arbitrary data to be sent with the response.
Function: file_attachment
-------------------------
Send a file attachment to the visitor.
Parameters:
$contents - The bitstream to be delivered to the visitor.
$filename - The name to be applied to the content upon download.
Function: zip_archive
---------------------
Creates a basic flat Zip archive from an array of items.
Parameters:
$array - An associative array of names and contents.
Returns:
A Zip archive.
See Also:
https://pkware.cachefly.net/webdocs/casestudies/APPNOTE.TXT
Function: email
---------------
Sends an email using PHP's mail() function or an alternative.
Function: email_activate_account
--------------------------------
Sends an activation email to a newly registered user.
Parameters:
$user - The user to receive the email.
Function: email_reset_password
------------------------------
Sends a password reset email to a user.
Parameters:
$user - The user to receive the email.
Function: javascripts
---------------------
Returns inline JavaScript for core functionality and extensions.
==============================================
includes/interface/CaptchaProvider.php
==============================================
Interface: CaptchaProvider
--------------------------
Describes the functions required by CaptchaProvider implementations.
Function: generateCaptcha
-------------------------
Returns the HTML form elements for the captcha challenge.
Function: checkCaptcha
----------------------
Checks the response and returns true (success) or false (failure).
==============================================
includes/interface/Controller.php
==============================================
Interface: Controller
---------------------
Describes the functions required by Controller implementations.
Function: parse
---------------
Route constructor calls this to determine the action.
Function: exempt
----------------
Route constructor calls this to determine "view_site" exemptions.
==============================================
includes/interface/Feather.php
==============================================
Interface: Feather
------------------
Describes the functions required by Feather implementations.
Function: submit
----------------
Handles post submitting.
Returns:
The <Post> object created.
Function: update
----------------
Handles updating a post.
Function: title
---------------
Returns the appropriate source to be treated as a "title" of a post.
If there is no immediate solution, you may use <Post::title_from_excerpt>.
Function: excerpt
-----------------
Returns the appropriate source, unmodified, to be used as an excerpt of a post.
Function: feed_content
----------------------
Returns the appropriate content for a feed.
==============================================
includes/interface/FeedGenerator.php
==============================================
Interface: FeedGenerator
------------------------
Describes the functions required by FeedGenerator implementations.
Function: type
--------------
Returns the content type of the feed.
Function: open
--------------
Opens the feed.
Function: entry
---------------
Adds an individual entry to the feed.
Function: category
------------------
Adds a category to an entry or feed.
Function: rights
----------------
Adds human-readable licensing information to an entry or feed.
Function: enclosure
-------------------
Adds a link for a resource that is potentially large in size.
Function: related
-----------------
Adds a link for a resource related to an entry or feed.
Function: feed
--------------
Returns the generated feed.
Function: display
-----------------
Displays the generated feed.
==============================================
includes/lib/AtomFeed.php
==============================================
Class: AtomFeed
---------------
Generates an Atom feed piece by piece.
See Also:
https://tools.ietf.org/html/rfc4287
Function: type
--------------
Returns the content type of the feed.
Function: open
--------------
Adds the opening feed element and top-level elements.
Parameters:
$title - Title for this feed.
$subtitle - Subtitle (optional).
$id - Feed ID (optional).
$updated - Time of update (optional).
Function: entry
---------------
Adds an individual feed entry.
Parameters:
$title - Title for this entry.
$id - The unique ID.
$content - Content for this entry.
$link - The URL to the resource.
$published - Time of creation.
$updated - Time of update (optional).
$name - Name of the author (optional).
$uri - URI of the author (optional).
$email - Email address of the author (optional).
Notes:
The entry remains open to allow triggered insertions.
Function: category
------------------
Adds a category element for an entry or feed.
Parameters:
$term - String that identifies the category.
$scheme - URI for the categorization scheme (optional).
$label - Human-readable label for the category (optional).
Function: rights
----------------
Adds a rights element for an entry or feed.
Parameters:
$text - Human-readable licensing information.
Function: enclosure
-------------------
Adds a link element for a resource that is potentially large in size.
Parameters:
$link - The URL to the resource.
$length - Size in bytes of the resource (optional).
$type - The media type of the resource (optional).
$title - Title for the resource (optional).
Function: related
-----------------
Adds a link element for a resource related to an entry or feed.
Parameters:
$link - The URL to the resource.
Function: feed
--------------
Returns the generated feed.
Function: display
-----------------
Displays the generated feed.
==============================================
includes/lib/JSONFeed.php
==============================================
Class: JSONFeed
---------------
Generates a JSON feed piece by piece.
See Also:
https://jsonfeed.org/version/1.1
Function: type
--------------
Returns the content type of the feed.
Function: open
--------------
Adds the top-level feed objects.
Parameters:
$title - Title for this feed.
$subtitle - Subtitle (optional).
$id - Feed ID (optional).
$updated - Time of update (optional).
Function: entry
---------------
Adds an individual feed item.
Parameters:
$title - Title for this item.
$id - The unique ID.
$content - Content for this item.
$link - The URL to the resource.
$published - Time of creation.
$updated - Time of update (optional).
$name - Name of the author (optional).
$uri - URI of the author (optional).
$email - Email address of the author (optional).
Function: category
------------------
Adds a tag object for an item.
Parameters:
$term - String that identifies the category.
$scheme - URI for the categorization scheme (optional).
$label - Human-readable label for the category (optional).
Function: rights
----------------
Not implemented in JSON Feed version 1.
Function: enclosure
-------------------
Adds an attachment object for an item.
Parameters:
$link - The URL to the resource.
$length - Size in bytes of the resource (optional).
$type - The media type of the resource (optional).
$title - Title for the resource (optional).
Function: related
-----------------
Adds an external_url attribute for an item.
Parameters:
$link - The external URL.
Function: feed
--------------
Returns the generated feed.
Function: display
-----------------
Displays the generated feed.
==============================================
includes/lib/Leaf.php
==============================================
Class: Leaf
-----------
Extends the Twig template engine.
Function: getFunctions
----------------------
Returns a list of operators to add to the existing list.
Function: getFilters
--------------------
Returns a list of filters to add to the existing list.
Function: twig_callback_missing_function
----------------------------------------
Scans callable methods of enabled modules in search of a missing Twig function.
Parameters:
$name - The name of the missing Twig function.
Function: twig_callback_missing_filter
--------------------------------------
Scans callable methods of enabled modules in search of a missing Twig filter.
Parameters:
$name - The name of the missing Twig filter.
Function: twig_function_paginate
--------------------------------
Paginates an array of items using the Paginator class.
Parameters:
$array - The array to paginate.
$per_page - The number of items per page.
$name - The $_GET value for the current page.
Function: twig_function_posted
------------------------------
Returns a $_POST value if set, otherwise returns the fallback value.
Parameters:
$key - The key to test in the $_POST array.
$fallback - The value to return if the $_POST value is not set.
Function: twig_function_mailto
------------------------------
Returns an obfuscated mailto: URL.
Parameters:
$email - The email address to obfuscate.
Function: twig_function_copyright_notice
----------------------------------------
Returns a copyright notice.
Parameters:
$holder - The copyright holder's name.
$date1 - A date to use for the year.
$date2 - End date (for a span of years).
Function: twig_function_uploaded_search
---------------------------------------
Returns an array of matches, if the visitor has the "export_content" privilege.
Parameters:
$search - A search term.
$filter - An array of valid extensions (case insensitive).
Function: twig_function_slug_pattern
------------------------------------
Returns a HTML @pattern@ attribute according to SLUG_STRICT constant.
Function: twig_function_javascripts_nonce
-----------------------------------------
Returns a nonce value to enable inline JavaScript with a Content Security Policy.
Function: twig_function_stylesheets_nonce
-----------------------------------------
Returns a nonce value to enable inline stylesheets with a Content Security Policy.
Function: twig_filter_translate
-------------------------------
Returns a translated string.
Parameters:
$text - The string to translate.
$domain - The translation domain to read from.
Function: twig_filter_translate_plural
--------------------------------------
Returns a plural (or not) form of a translated string.
Parameters:
$single - Singular string.
$plural - Pluralized string.
$number - The number to judge by.
$domain - The translation domain to read from.
Function: twig_filter_translate_time
------------------------------------
Returns a formatted and internationalized time string.
Parameters:
$timestamp - A time() value or string to be strtotime() converted.
$format - The date()-compatible formatting.
Function: twig_filter_time
--------------------------
Returns a <time> HTML element containing an internationalized time representation.
Parameters:
$timestamp - A time() value or string to be strtotime() converted.
$format - The date()-compatible formatting for the <time> representation.
$convert - Perform a case conversion:
"fold", "lower", "title", "upper", or null to retain case as-is.
Function: twig_filter_date_format
---------------------------------
Returns date formatting for a string that isn't a regular time() value.
Parameters:
$timestamp - A time() value or string to be strtotime() converted.
$formatting - The date()-compatible formatting.
Function: twig_filter_filesize_format
-------------------------------------
Returns a string containing a formatted filesize value.
Parameters:
$bytes - The filesize in bytes.
Function: twig_filter_preg_match
--------------------------------
Try to match a string against an array of regular expressions.
Parameters:
$try - An array of regular expressions, or a single regular expression.
$haystack - The string to test.
Function: twig_filter_preg_replace
----------------------------------
Performs a <preg_replace> on the supplied string or array.
Parameters:
$subject - The input string.
$pattern - The regular expression to match.
$replacement - The replacement string.
$limit - The maximum number of replacements.
Function: twig_filter_contains
------------------------------
Does the haystack variable contain the needle variable?
Parameters:
$haystack - The variable to search within.
$needle - The variable to search for.
Function: twig_filter_inspect
-----------------------------
Exports a variable for inspection.
Parameters:
$variable - The variable to inspect.
Function: twig_filter_checked
-----------------------------
Returns a HTML @checked@ attribute if the test evalutaes to true.
Parameters:
$test - The variable to test.
Function: twig_filter_selected
------------------------------
Returns a HTML @selected@ attribute if the
test matches any of the supplied arguments.
Parameters:
$test - The variable to test.
Function: twig_filter_disabled
------------------------------
Returns a HTML @disabled@ attribute if the
test matches any of the supplied arguments.
Parameters:
$test - The variable to test.
Function: twig_filter_download
------------------------------
Returns a download link for a file located in the uploads directory.
Parameters:
$filename - The uploaded filename.
Function: twig_filter_thumbnail
-------------------------------
Returns a thumbnail <img> tag for an uploaded image file,
optionally with sizes/srcset attributes and enclosing <a> tag.
Parameters:
$filename - The uploaded filename.
$alt_text - The alternative text for the image.
$url - A URL, @true@ to link to the uploaded file, @false@ to disable.
$args - An array of additional arguments to be appended as GET parameters.
$sizes - A string, @true@ to use "100vw", @false@ to disable sizes/srcset.
$lazy - Specify lazy-loading for this image?
==============================================
includes/lib/RSSFeed.php
==============================================
Class: RSSFeed
--------------
Generates an RSS feed piece by piece.
See Also:
http://www.rssboard.org/rss-2-0-11
Function: type
--------------
Returns the content type of the feed.
Function: open
--------------
Adds the opening channel element and top-level elements.
Parameters:
$title - Title for this channel.
$subtitle - Subtitle (optional).
$id - Feed ID (optional).
$updated - Time of update (optional).
Function: entry
---------------
Adds an individual feed item.
Parameters:
$title - Title for this item.
$id - The unique ID.
$content - Content for this item.
$link - The URL to the resource.
$published - Time of creation.
$updated - Time of update (optional).
$name - Name of the author (optional).
$uri - URI of the author (optional).
$email - Email address of the author (optional).
Notes:
The item remains open to allow triggered insertions.
Function: category
------------------
Adds a category element for an item.
Parameters:
$term - String that identifies the category.
$scheme - URI for the categorization scheme (optional).
$label - Human-readable label for the category (optional).
Function: rights
----------------
Not implemented in RSS 2.0.11.
Function: enclosure
-------------------
Adds an enclosure element for a resource that is potentially large in size.
Parameters:
$link - The URL to the resource.
$length - Size in bytes of the resource (optional).
$type - The media type of the resource (optional).
$title - Title for the resource (optional).
Function: related
-----------------
Not implemented in RSS 2.0.11.
Function: feed
--------------
Returns the generated feed.
Function: display
-----------------
Displays the generated feed.
==============================================
includes/lib/ThumbnailFile.php
==============================================
Class: ThumbnailFile
--------------------
Creates and serves compressed image thumbnails.
Function: __construct
---------------------
Receives the source filename and requested thumbnail parameters.
Parameters:
$filename - Filename relative to the uploads directory.
$thumb_w - Requested thumbnail width (0 = auto).
$thumb_h - Requested thumbnail height (0 = auto).
$quality - Quality factor for the thumbnail file.
$square - Create a square crop of the original image?
Function: upscaling
-------------------
Will the thumbnail be larger than the original?
Function: creatable
-------------------
Can the thumbnail file be created?
Function: extension
-------------------
Returns the correct extension for the image.
Function: mime_type
-------------------
Returns the correct MIME type for the image.
Function: name
--------------
Generates and returns a unique name for the thumbnail file.
Function: create
----------------
Creates a thumbnail file using the supplied parameters.
Parameters:
$overwrite - Overwrite an existing thumbnail file?
Function: serve
---------------
Serves a thumbnail file with correct Content-Type header.
Function: resize
----------------
Computes the final dimensions based on supplied parameters.
==============================================
includes/main.js.php
==============================================
File: main.js.php
-----------------
JavaScript for core functionality and extensions.
==============================================
includes/model/Group.php
==============================================
Class: Group
------------
The Group model.
See Also:
<Model>
Function: __construct
---------------------
See Also:
<Model::grab>
Function: find
--------------
See Also:
<Model::search>
Function: can
-------------
Checks if the group can perform the specified actions.
Parameters:
$permissions - Permissions to check, as separate args.
Returns:
@true@ or @false@
Notes:
If the last arg is <true>, logic is "and", otherwise "or".
Function: add
-------------
Adds a group to the database.
Parameters:
$name - The group's name
$permissions - An array of the permissions (IDs).
Returns:
The newly created <Group>.
See Also:
<update>
Function: update
----------------
Updates a group with the given name and permissions.
Parameters:
$name - The new Name to set.
$permissions - An array of the new permissions to set (IDs).
Returns:
The updated <Group>.
Function: delete
----------------
Deletes a given group and its permissions.
See Also:
<Model::destroy>
Function: add_permission
------------------------
Adds a permission to the Groups table.
Parameters:
$id - The ID for the permission, e.g "can_do_something".
$name - The name for the permission, e.g. "Can Do Something".
Function: remove_permission
---------------------------
Removes a permission from the Groups table.
Parameters:
$id - The ID of the permission to remove.
Function: list_permissions
--------------------------
Returns an array of all permissions in the Groups table.
Parameters:
$group_id - List enabled permissions for this group ID.
Function: size
--------------
Returns the number of users in the group.
==============================================
includes/model/Page.php
==============================================
Class: Page
-----------
The Page model.
See Also:
<Model>
Function: __construct
---------------------
See Also:
<Model::grab>
Function: find
--------------
See Also:
<Model::search>
Function: add
-------------
Adds a page to the database.
Parameters:
$title - The Title for the new page.
$body - The Body for the new page.
$user - The <User> or <User.id> of the page's author.
$parent_id - The ID of the new page's parent page (0 for none).
$public - Whether the page can be viewed without permission.
$show_in_list - Whether or not to show it in the pages list.
$list_order - The order of the page in the list.
$clean - The slug for this page.
$url - The unique URL (created from $clean by default).
$created_at - The new page's "created" timestamp.
$updated_at - The new page's "last updated" timestamp.
Returns:
The newly created <Page>.
Notes:
The caller is responsible for validating all supplied values.
See Also:
<update>
Function: update
----------------
Updates the page.
Parameters:
$title - The new Title.
$body - The new Body.
$user - The <User> or <User.id> of the page's author.
$parent_id - The new parent ID.
$public - Whether the page can be viewed without permission.
$show_in_list - Whether or not to show it in the pages list.
$clean - A new slug for the page.
$url - A new unique URL for the page (created from $clean by default).
$created_at - The page's "created" timestamp.
$updated_at - The page's "last updated" timestamp.
Returns:
The updated <Page>.
Notes:
The caller is responsible for validating all supplied values.
Function: delete
----------------
Deletes the given page.
Parameters:
$page_id - The ID of the page to delete.
$recursive - Should the page's children be deleted? (default: false)
See Also:
<Model::destroy>
Function: exists
----------------
Checks if a page exists.
Parameters:
$page_id - The page ID to check
Function: check_url
-------------------
Checks if a given URL value is already being used as another page's URL.
Parameters:
$url - The URL to check.
Returns:
The unique version of $url.
If unused, it's the same as $url. If used, a number is appended to it.
Function: filter
----------------
Filters the page attributes through filter_page and markup filters.
Function: from_url
------------------
Attempts to grab a page from its clean or dirty URL.
Parameters:
$request - The request URI to parse.
$route - The route to respond to, or null to return a Page.
Function: url
-------------
Returns a page's URL.
Function: author
----------------
Returns a page's author. Example: $page->author->name
==============================================
includes/model/Post.php
==============================================
Class: Post
-----------
The Post model.
See Also:
<Model>
Function: __construct
---------------------
See Also:
<Model::grab>
Function: find
--------------
See Also:
<Model::search>
Function: add
-------------
Adds a post to the database.
Parameters:
$values - The data to insert.
$clean - The slug for this post.
$url - The unique sanitised URL (created from $clean by default).
$feather - The feather to post as.
$user - <User> to set as the post's author.
$pinned - Pin the post?
$status - Post status
$created_at - New @created_at@ timestamp for the post.
$updated_at - New @updated_at@ timestamp for the post.
$pingbacks - Send pingbacks?
$options - Options for the post.
Returns:
The newly created <Post>.
Notes:
The caller is responsible for validating all supplied values.
See Also:
<update>
Function: update
----------------
Updates a post with the given attributes.
Parameters:
$values - An array of data to set for the post.
$user - <User> to set as the post's author.
$pinned - Pin the post?
$status - Post status
$clean - A new slug for the post.
$url - A new unique URL for the post.
$created_at - New @created_at@ timestamp for the post.
$updated_at - New @updated_at@ timestamp for the post.
$options - Options for the post.
$pingbacks - Send pingbacks?
Returns:
The updated <Post>.
Notes:
The caller is responsible for validating all supplied values.
See Also:
<add>
Function: delete
----------------
Deletes a post from the database.
See Also:
<Model::destroy>
Function: deletable
-------------------
Checks if the <User> can delete the post.
Function: editable
------------------
Checks if the <User> can edit the post.
Function: any_editable
----------------------
Checks if the <Visitor> can edit any posts.
Function: any_deletable
-----------------------
Checks if the <Visitor> can delete any posts.
Function: exists
----------------
Checks if a post exists.
Parameters:
$post_id - The post ID to check
Returns:
true - if a post with that ID is in the database.
Function: check_url
-------------------
Checks if a given URL value is already being used as another post's URL.
Parameters:
$url - The URL to check.
Returns:
The unique version of the URL value.
If unused, it's the same as $url. If used, a number is appended to it.
Function: url
-------------
Returns a post's URL.
Function: title_from_excerpt
----------------------------
Generates an acceptable title from the post's excerpt.
Returns:
filtered -> first line -> ftags stripped ->
truncated to 75 characters -> normalized.
Function: title
---------------
Returns the given post's title, provided by its Feather.
Function: excerpt
-----------------
Returns the given post's excerpt, provided by its Feather.
Function: feed_content
----------------------
Returns the given post's feed content, provided by its Feather.
Function: next
--------------
Returns:
The next post (the post made before this one).
Function: prev
--------------
Returns:
The previous post (the post made after this one).
Function: theme_exists
----------------------
Checks if the current post's feather theme file exists.
Function: filter
----------------
Filters the post attributes through filter_post and any Feather filters.
Function: from_url
------------------
Attempts to grab a post from its clean or dirty URL.
Parameters:
$request - The request URI to parse.
$route - The route to respond to, or null to return a Post.
$options - Additional options for the Post object (optional).
Function: statuses
------------------
Returns a SQL query "chunk" for the "status" column permissions of the current user.
Parameters:
$start - An array of additional statuses to allow;
"registered_only", "private" and "scheduled" are added deterministically.
Function: feathers
------------------
Returns a SQL query "chunk" for the "feather" column so that it matches enabled feathers.
Function: author
----------------
Returns a post's author. Example: $post->author->name
Function: groups
----------------
Returns the IDs of any groups given viewing permission in the post's status.
Function: publish_scheduled
---------------------------
Searches for and publishes scheduled posts.
Calls the @publish_post@ trigger with the updated <Post>.
==============================================
includes/model/User.php
==============================================
Class: User
-----------
The User model.
See Also:
<Model>
Function: __construct
---------------------
See Also:
<Model::grab>
Function: find
--------------
See Also:
<Model::search>
Function: authenticate
----------------------
Checks to see if a given login and password match a user in the database.
Parameters:
$login - The Login to check.
$password - The matching Password to check.
Returns:
@true@ or @false@
Function: add
-------------
Adds a user to the database.
Parameters:
$login - The Login for the new user.
$password - The hashed password for the new user.
$email - The email for the new user.
$full_name - The full name of the user (optional).
$website - The user's website (optional).
$group_id - The user's <Group> ID (defaults to the default group).
$joined_at - Join date (defaults to now).
Returns:
The newly created <User>.
See Also:
<update>
Function: update
----------------
Updates a user with the given parameters.
Parameters:
$login - The new Login to set.
$password - The new hashed password to set.
$full_name - The new Full Name to set.
$email - The new email to set.
$website - The new Website to set.
$group_id - The new <Group> ID to set.
Returns:
The updated <User>.
See Also:
<add>
Function: delete
----------------
Deletes a given user.
See Also:
<Model::destroy>
Function: hash_password
-----------------------
Creates a hash of a user's password for the database.
Parameters:
$password - The unhashed password.
Returns:
The password hashed using the SHA-512 algorithm.
Notes:
<random> uses a cryptographically secure function.
Function: check_password
------------------------
Checks a given password against the user's stored hash.
Parameters:
$password - The unhashed password given during a login attempt.
$stored - The the user's stored hash value from the database.
Returns:
@true@ or @false@
Notes:
Uses <password_verify> to mitigate timing attacks.
==============================================
includes/model/Visitor.php
==============================================
Class: Visitor
--------------
The model for the currently browsing <User>.
Notes:
Group falls back to whatever group is set as the "Guest Group".
See Also:
<User>
Function: __construct
---------------------
Checks if a valid user is logged in.
Function: __get
---------------
A detour around belongs_to "group" to account for the default Guest group.
Function: find
--------------
See Also:
<Model::search>
Function: logged_in
-------------------
Returns whether or not the visitor is logged in.
Function: log_in
----------------
Logs in a visitor as a registered user.
Parameters:
$user - The <User> to log in.
Notes:
A redirect() is required after calling this method.
Function: log_out
-----------------
Logs out a registered user.
Notes:
A redirect() is required after calling this method.
Function: current
-----------------
Returns a singleton reference to the current visitor.
==============================================
includes/thumbnail.php
==============================================
File: thumbnail
---------------
Serves compressed image thumbnails for uploaded files.