NAME

    Etherpad - interact with Etherpad API

VERSION

    version 1.2.13.2

SYNOPSIS

      use Etherpad;
      my $ec = Etherpad->new(
        url      => 'http://pad.example.org',
        apikey   => 'secret_etherpad_API_key',
        user     => 'http_user',
        password => 'http_password',
        proxy    => {
            http  => 'http://proxy.example.org',
            https => 'http://proxy.example.org'
        }
      );
    
      $ec->create_pad('new_pad_name');

DESCRIPTION

    Client module for the Etherpad HTTP API.

    The Etherpad API currently supported is the 1.2.13 (Etherpad version:
    1.6.0)

    This module aims to replace Etherpad::API

ATTRIBUTES

    Etherpad implements the following attributes.

 url

      my $url = $ec->url;
      $ec     = $ec->url('http://pad.example.org');

    MANDATORY. The Etherpad URL, no default.

 apikey

      my $apikey = $ec->apikey;
      $ec        = $ec->apikey('secret_etherpad_API_key');

    MANDATORY. Secret API key, located in the APIKEY.txt file of your
    Etherpad installation directory, no default.

 ua

      my $ua = $ec->ua;
      $ec    = $ec->ua(Mojo::UserAgent->new);

    OPTIONAL. User agent, default to a Mojo::UserAgent. Please, don't use
    anything other than a Mojo::Useragent.

 user

      my $user = $ec->user;
      $ec      = $ec->user('bender');

    OPTIONAL. HTTP user, use it if your Etherpad is protected by a HTTP
    authentication, no default.

 password

      my $password = $ec->password;
      $ec          = $ec->password('beer');

    OPTIONAL. HTTP password, use it if your Etherpad is protected by a HTTP
    authentication, no default.

 proxy

      my $proxy = $ec->proxy;
      $ec       = $ec->proxy({
        http  => 'http://proxy.example.org',
        https => 'http://proxy.example.org'
      });

    OPTIONAL. Proxy settings. If set to { detect => 1 }, Etherpad will
    check environment variables HTTP_PROXY, http_proxy, HTTPS_PROXY,
    https_proxy, NO_PROXY and no_proxy for proxy information. No default.

METHODS

    Etherpad inherits all methods from Mojo::Base and implements the
    following new ones.

 Groups

    Pads can belong to a group. The padID of grouppads is starting with a
    groupID like g.asdfasdfasdfasdf$test

    See http://etherpad.org/doc/v1.6.0/#index_groups

  create_group

     Usage     : $ec->create_group();
     Purpose   : Creates a new group
     Returns   : The new group ID
     Argument  : None
     See       : http://etherpad.org/doc/v1.6.0/#index_creategroup

  create_group_if_not_exists_for

     Usage     : $ec->create_group_if_not_exists_for('groupMapper');
     Purpose   : This functions helps you to map your application group ids to epl group ids
     Returns   : The epl group id
     Argument  : Your application group id
     See       : http://etherpad.org/doc/v1.6.0/#index_creategroupifnotexistsfor_groupmapper

  delete_group

     Usage     : $ec->delete_group('groupId');
     Purpose   : Deletes a group
     Returns   : 1 if it succeeds
     Argument  : The id of the group you want to delete
     See       : http://etherpad.org/doc/v1.6.0/#index_deletegroup_groupid

  list_pads

     Usage     : $ec->list_pads('groupId');
     Purpose   : Returns all pads of this group
     Returns   : An array or an array reference (depending on the context) which contains the pad ids
     Argument  : The id of the group from which you want the pads
     See       : http://etherpad.org/doc/v1.6.0/#index_listpads_groupid

  create_group_pad

     Usage     : $ec->create_group_pad('groupID', 'padName' [, 'text'])
     Purpose   : Creates a new pad in this group
     Returns   : 1 if it succeeds
     Argument  : The group id, the pad name, optionally takes the pad's initial text
     See       : http://etherpad.org/doc/v1.6.0/#index_creategrouppad_groupid_padname_text

  list_all_groups

     Usage     : $ec->list_all_groups()
     Purpose   : Lists all existing groups
     Returns   : An array or an array reference (depending on the context) which contains the groups ids
     Argument  : None
     See       : http://etherpad.org/doc/v1.6.0/#index_listallgroups

 Author

    These authors are bound to the attributes the users choose (color and
    name).

    See http://etherpad.org/doc/v1.6.0/#index_author

  create_author

     Usage     : $ec->create_author(['name'])
     Purpose   : Creates a new author
     Returns   : The new author ID
     Argument  : Optionally takes a string as argument : the new author's name
     See       : http://etherpad.org/doc/v1.6.0/#index_createauthor_name

  create_author_if_not_exists_for

     Usage     : $ec->create_author_if_not_exists_for(authorMapper [, name])
     Purpose   : This functions helps you to map your application author ids to epl author ids
     Returns   : The epl author ID
     Argument  : Your application author ID (mandatory) and optionally the epl author name
     See       : http://etherpad.org/doc/v1.6.0/#index_createauthorifnotexistsfor_authormapper_name

  list_pads_of_author

     Usage     : $ec->list_pads_of_author('authorID')
     Purpose   : Returns an array of all pads this author contributed to
     Returns   : An array or an array reference depending on the context, containing the pads names
     Argument  : An epl author ID
     See       : http://etherpad.org/doc/v1.6.0/#index_listpadsofauthor_authorid

  get_author_name

     Usage     : $ec->get_author_name('authorID')
     Purpose   : Returns the Author Name of the author
     Returns   : The author name
     Argument  : The epl author ID
     See       : http://etherpad.org/doc/v1.6.0/#index_getauthorname_authorid

 Session

    Sessions can be created between a group and an author. This allows an
    author to access more than one group. The sessionID will be set as a
    cookie to the client and is valid until a certain date. The session
    cookie can also contain multiple comma-seperated sessionIDs, allowing a
    user to edit pads in different groups at the same time. Only users with
    a valid session for this group, can access group pads. You can create a
    session after you authenticated the user at your web application, to
    give them access to the pads. You should save the sessionID of this
    session and delete it after the user logged out.

    See http://etherpad.org/doc/v1.6.0/#index_session

  create_session

     Usage     : $ec->create_session('groupID', 'authorID', 'validUntil')
     Purpose   : Creates a new session. validUntil is an unix timestamp in seconds
     Returns   : The epl session ID
     Argument  : An epl group ID, an epl author ID and an valid unix timestamp (the session validity end date)
     See       : http://etherpad.org/doc/v1.6.0/#index_createsession_groupid_authorid_validuntil

  delete_session

     Usage     : $ec->delete_session('sessionID')
     Purpose   : Deletes a session
     Returns   : 1 if it succeeds
     Argument  : An epl session ID
     See       : http://etherpad.org/doc/v1.6.0/#index_deletesession_sessionid

  get_session_info

     Usage     : $ec->get_session_info('sessionID')
     Purpose   : Returns informations about a session
     Returns   : A hash reference, containing 3 keys : authorID, groupID and validUntil
     Argument  : An epl session ID
     See       : http://etherpad.org/doc/v1.6.0/#index_getsessioninfo_sessionid

  list_sessions_of_group

     Usage     : $ec->list_sessions_of_group('groupID')
     Purpose   : Returns all sessions of a group
     Returns   : Returns a hash reference, which keys are sessions ID and values are sessions infos (see get_session_info)
     Argument  : An epl group ID
     See       : http://etherpad.org/doc/v1.6.0/#index_listsessionsofgroup_groupid

  list_sessions_of_author

     Usage     : $ec->list_sessions_of_author('authorID')
     Purpose   : Returns all sessions of an author
     Returns   : Returns a hash reference, which keys are sessions ID and values are sessions infos (see get_session_info)
     Argument  : An epl group ID
     See       : http://etherpad.org/doc/v1.6.0/#index_listsessionsofauthor_authorid

 Pad Content

    Pad content can be updated and retrieved through the API.

    See http://etherpad.org/doc/v1.6.0/#index_pad_content

  get_text

     Usage     : $ec->get_text('padID', ['rev'])
     Purpose   : Returns the text of a pad
     Returns   : A string, containing the text of the pad
     Argument  : Takes a pad ID (mandatory) and optionally a revision number
     See       : http://etherpad.org/doc/v1.6.0/#index_gettext_padid_rev

  set_text

     Usage     : $ec->set_text('padID', 'text')
     Purpose   : Sets the text of a pad
     Returns   : 1 if it succeeds
     Argument  : Takes a pad ID and the text you want to set (both mandatory)
     See       : http://etherpad.org/doc/v1.6.0/#index_settext_padid_text

  append_text

     Usage     : $ec->append_text('padID', 'text')
     Purpose   : Appends text to a pad
     Returns   : 1 if it succeeds
     Argument  : Takes a pad ID and the text you want to append (both mandatory)
     See       : http://etherpad.org/doc/v1.6.0/#index_appendtext_padid_text

  get_html

     Usage     : $ec->get_html('padID', ['rev'])
     Purpose   : Returns the text of a pad formatted as html
     Returns   : A string, containing the text of the pad formatted as html
     Argument  : Takes a pad ID (mandatory) and optionally a revision number
     See       : http://etherpad.org/doc/v1.6.0/#index_gethtml_padid_rev

  set_html

     Usage     : $ec->set_html('padID', 'html')
     Purpose   : Sets the text of a pad based on HTML, HTML must be well formed.
     Returns   : 1 if it succeeds
     Argument  : Takes a pad ID and the HTML code you want to set (both mandatory)
     See       : http://etherpad.org/doc/v1.6.0/#index_sethtml_padid_html

  get_attribute_pool

     Usage     : $ec->get_attribute_pool('padID')
     Purpose   : Returns the attribute pool of a pad
     Returns   : A hash reference, containing 3 keys
                 * numToAttrib, containing a hash reference, which keys are integers and contents are array references
                 * attribToNum, containing a hash reference, which keys are string and contents are integers
                 * nextNum, which content is an integer
     Argument  : Takes a pad ID (mandatory)
     See       : http://etherpad.org/doc/v1.6.0/#index_getattributepool_padid

  get_revision_changeset

     Usage     : $ec->get_revision_changeset('padID' [, rev])
     Purpose   : Get the changeset at a given revision, or last revision if 'rev' is not defined
     Returns   : A string, representing an etherpad changeset
     Argument  : Takes a pad ID (mandatory) and optionally a revision number
     See       : http://etherpad.org/doc/v1.6.0/#index_getrevisionchangeset_padid_rev

  create_diff_html

     Usage     : $ec->create_diff_html('padId', rev1, rev2)
     Purpose   : Returns an object of diffs from 2 points in a pad
     Returns   : A hash reference which keys are
                 * html, which content is a string representing the diff between the two revisions
                 * authors, which content is an array reference of authors
     Argument  : Takes a pad ID, a revision number to start and a revision number to end. All arguments are mandatory
     See       : http://etherpad.org/doc/v1.6.0/#index_creatediffhtml_padid_startrev_endrev

  restore_revision

     Usage     : $ec->restore_revision('padId', rev)
     Purpose   : Restores revision from past as new changeset
     Returns   : 1 if it succeeds
     Argument  : Takes a pad ID, a revision number to restore. All arguments are mandatory
     See       : http://etherpad.org/doc/v1.7.0/#index_restorerevision_padid_rev

 Chat

    See http://etherpad.org/doc/v1.6.0/#index_chat

  get_chat_history

     Usage     : $ec->get_chat_history('padID' [, start, end])
     Purpose   : Returns
                  - a part of the chat history, when start and end are given
                  - the whole chat history, when no extra parameters are given
     Returns   : An array or an array reference, depending of the context, containing hash references with 4 keys :
                  - text     => text of the message
                  - userId   => epl user id
                  - time     => unix timestamp of the message
                  - userName => epl user name
     Argument  : Takes a pad ID (mandatory) and optionally the start and the end numbers of the messages you want.
                 The start number can't be higher than or equal to the current chatHead. The first chat message is number 0.
                 If you specify a start but not an end, all messages will be returned.
     See       : http://etherpad.org/doc/v1.6.0/#index_getchathistory_padid_start_end

  get_chat_head

     Usage     : $ec->get_chat_head('padID')
     Purpose   : Returns the chatHead (last number of the last chat-message) of the pad
     Returns   : The last chat-message number. -1 if there is no chat message
     Argument  : A pad ID
     See       : http://etherpad.org/doc/v1.6.0/#index_getchathead_padid

  append_chat_message

     Usage     : $ec->append_chat_message('padID', 'text', 'authorID', 'timestamp')
     Purpose   : Add a message to chat
     Returns   : 1 if it succeeds
     Argument  : Takes a pad ID (mandatory), a text (mandatory), an author ID (mandatory) and a timestamp (mantdatory)
     See       : Undocumented yet

 Pad

    Group pads are normal pads, but with the name schema GROUPID$PADNAME. A
    security manager controls access of them and its forbidden for normal
    pads to include a $ in the name.

    See http://etherpad.org/doc/v1.6.0/#index_pad

  create_pad

     Usage     : $ec->create_pad('padID' [, 'text'])
     Purpose   : Creates a new (non-group) pad. Note that if you need to create a group Pad, you should call create_group_pad.
     Returns   : 1 if it succeeds
     Argument  : Takes a pad ID (mandatory) and optionally a text to fill the pad
     See       : http://etherpad.org/doc/v1.6.0/#index_createpad_padid_text

  get_revisions_count

     Usage     : $ec->get_revisions_count('padID')
     Purpose   : Returns the number of revisions of this pad
     Returns   : The number of revisions
     Argument  : A pad ID
     See       : http://etherpad.org/doc/v1.6.0/#index_getrevisionscount_padid

  get_saved_revisions_count

     Usage     : $ec->get_saved_revisions_count('padID')
     Purpose   : Returns the number of saved revisions of this pad
     Returns   : The number of saved revisions
     Argument  : A pad ID
     See       : http://etherpad.org/doc/v1.6.0/#index_getsavedrevisionscount_padid

  list_saved_revisions

     Usage     : $ec->list_saved_revisions('padID')
     Purpose   : Returns the list of saved revisions of this pad
     Returns   : An array or an array reference, depending of the context, containing the saved revisions numbers
     Argument  : A pad ID
     See       : http://etherpad.org/doc/v1.6.0/#index_listsavedrevisions_padid

  save_revision

     Usage     : $ec->save_revision('padID', ['rev'])
     Purpose   : Saves a revision
     Returns   : 1 if it succeeds
     Argument  : Takes a pad ID (mandatory) and optionally a revision number
     See       : http://etherpad.org/doc/v1.6.0/#index_saverevision_padid_rev

  get_users_count

     Alias for pad_users_count (see below)

  pad_users_count

     Usage     : $ec->pad_users_count('padID')
     Purpose   : Returns the number of user that are currently editing this pad
     Returns   : The number of users
     Argument  : A pad ID
     See       : http://etherpad.org/doc/v1.6.0/#index_paduserscount_padid

  pad_users

     Usage     : $ec->pad_users('padID')
     Purpose   : Returns the list of users that are currently editing this pad
     Returns   : An array or an array reference, depending of the context, containing hash references with 3 keys : colorId, name and timestamp
     Argument  : A pad ID
     See       : http://etherpad.org/doc/v1.6.0/#index_padusers_padid

  delete_pad

     Usage     : $ec->delete_pad('padID')
     Purpose   : Deletes a pad
     Returns   : 1 if it succeeds
     Argument  : A pad ID
     See       : http://etherpad.org/doc/v1.6.0/#index_deletepad_padid

  copy_pad

     Usage     : $ec->copy_pad('sourceID', 'destinationID' [, 1])
     Purpose   : Copies a pad with full history and chat. If force is true and the destination pad exists, it will be overwritten
     Returns   : 1 if it succeeds
     Argument  : A source pad ID
                 A destination pad ID
                 A force flag : a value which is true or false, in perl interpretation (for example; 0 and '' are false, 1, 2 and 'foo' are true)
     See       : http://etherpad.org/doc/v1.6.0/#index_copypad_sourceid_destinationid_force_false

  move_pad

     Usage     : $ec->move_pad('sourceID', 'destinationID' [, 1])
     Purpose   : Moves a pad. If force is true and the destination pad exists, it will be overwritten
     Returns   : 1 if it succeeds
     Argument  : A source pad ID
                 A destination pad ID
                 A force flag : a value which is true or false, in perl interpretation (for example; 0 and '' are false, 1, 2 and 'foo' are true)
     See       : http://etherpad.org/doc/v1.6.0/#index_movepad_sourceid_destinationid_force_false

  get_read_only_id

     Usage     : $ec->get_read_only_id('padID')
     Purpose   : Returns the read only link of a pad
     Returns   : A string
     Argument  : A pad ID
     See       : http://etherpad.org/doc/v1.6.0/#index_getreadonlyid_padid

  get_pad_id

     Usage     : $ec->get_pad_id('readOnlyID')
     Purpose   : Returns the id of a pad which is assigned to the readOnlyID
     Returns   : A string
     Argument  : A read only ID
     See       : http://etherpad.org/doc/v1.6.0/#index_getpadid_readonlyid

  set_public_status

     Usage     : $ec->set_public_status('padID', 'publicStatus')
     Purpose   : Sets a boolean for the public status of a pad
     Returns   : 1 if it succeeds
     Argument  : A pad ID and the public status you want to set : 1 or 0
     See       : http://etherpad.org/doc/v1.6.0/#index_setpublicstatus_padid_publicstatus

  get_public_status

     Usage     : $ec->get_public_status('padID')
     Purpose   : Return true of false
     Returns   : 1 or 0
     Argument  : A pad ID
     See       : http://etherpad.org/doc/v1.6.0/#index_getpublicstatus_padid

  set_password

     Usage     : $ec->set_password('padID', 'password')
     Purpose   : Returns ok or a error message
     Returns   : 1 if it succeeds
     Argument  : A pad ID and a password
     See       : http://etherpad.org/doc/v1.6.0/#index_setpassword_padid_password

  is_password_protected

     Usage     : $ec->is_password_protected('padID')
     Purpose   : Returns true or false
     Returns   : 1 or 0
     Argument  : A pad ID
     See       : http://etherpad.org/doc/v1.6.0/#index_ispasswordprotected_padid

  list_authors_of_pad

     Usage     : $ec->list_authors_of_pad('padID')
     Purpose   : Returns an array of authors who contributed to this pad
     Returns   : An array or an array reference depending on the context, containing the epl authors IDs
     Argument  : A pad ID
     See       : http://etherpad.org/doc/v1.6.0/#index_listauthorsofpad_padid

  list_names_of_authors_of_pad

     Usage     : $ec->list_names_authors_of_pad('padID')
     Returns   : Returns an array of the names of the authors who contributed to this pad in list context
                 Returns an array reference in scalar context
     Argument  : The pad ID
     See       : This is not part of the Etherpad API but a facility offered by this module

  get_last_edited

     Usage     : $ec->get_last_edited('padID')
     Purpose   : Returns the timestamp of the last revision of the pad
     Returns   : A unix timestamp
     Argument  : A pad ID
     See       : http://etherpad.org/doc/v1.6.0/#index_getlastedited_padid

  send_clients_message

     Usage     : $ec->send_clients_message('padID', 'msg')
     Purpose   : Sends a custom message of type msg to the pad
     Returns   : 1 if it succeeds
     Argument  : A pad ID and the message you want to send
     See       : http://etherpad.org/doc/v1.6.0/#index_sendclientsmessage_padid_msg

 check_token

     Usage     : $ec->check_token()
     Purpose   : Returns ok when the current api token is valid
     Returns   : 1 if the token is valid, 0 otherwise
     Argument  : None
     See       : http://etherpad.org/doc/v1.6.0/#index_checktoken

 Pads

    See http://etherpad.org/doc/v1.6.0/#index_pads

  list_all_pads

     Usage     : $ec->list_all_pads()
     Purpose   : Lists all pads on this epl instance
     Returns   : An array or an array reference depending on the context, containing the pads names
     See       : http://etherpad.org/doc/v1.6.0/#index_listallpads

INSTALL

    After getting the tarball on https://metacpan.org/release/Etherpad,
    untar it, go to the directory and:

        perl Makefile.PL
        make
        make test
        make install

    If you are on a windows box you should use 'nmake' rather than 'make'.

BUGS and SUPPORT

    You can find documentation for this module with the perldoc command.

        perldoc Etherpad

    Bugs and feature requests will be tracked on:

        https://framagit.org/fiat-tux/etherpad/issues

    The latest source code can be browsed and fetched at:

        https://framagit.org/fiat-tux/etherpad
        git clone https://framagit.org/fiat-tux/etherpad.git

    Source code mirror:

        https://github.com/ldidry/etherpad

    You can also look for information at:

        AnnoCPAN: Annotated CPAN documentation
    
        http://annocpan.org/dist/Etherpad
        CPAN Ratings
    
        http://cpanratings.perl.org/d/Etherpad
        Search CPAN
    
        http://search.cpan.org/dist/Etherpad

AUTHOR

        Luc DIDRY
        CPAN ID: LDIDRY
        ldidry@cpan.org
        https://fiat-tux.fr/

COPYRIGHT

    This program is free software; you can redistribute it and/or modify it
    under the same terms as Perl itself.

    The full text of the license can be found in the LICENSE file included
    with this module.

SEE ALSO

    perl(1), Mojolicious

AUTHOR

    Luc Didry <ldidry@cpan.org>

COPYRIGHT AND LICENSE

    This software is copyright (c) 2015 by Luc Didry.

    This is free software; you can redistribute it and/or modify it under
    the same terms as the Perl 5 programming language system itself.