NAME

    spread-revolutionary-date - Spread date and time from Revolutionary
    (Republican) Calendar

VERSION

    version 0.03

DESCRIPTION

    spread-revolutionary-date is a Free Software
    <https://www.gnu.org/philosophy/free-sw.htmlhttps://www.gnu.org/philosophy/free-sw.html>
    that spreads the current date, expressed in French Revolutionary
    calendar <https://en.wikipedia.org/wiki/French_Republican_calendar>, to
    various social networks: Twitter <https://twitter.com/>, Mastodon
    <https://mastodon.social/>, and the Freenode <https://freenode.net/>
    Internet Relay Chat network.

    The French Revolutionary calendar, also called Republican calendar, was
    introduced during the French Revolution
    <https://en.wikipedia.org/wiki/French_Revolution>, and used from late
    1793 to 1805, and also during the Paris Commune
    <https://en.wikipedia.org/wiki/Paris_Commune> in 1871. This was an
    attempt to get rid of religious and royalist references found in
    Gregorian calendar when naming measures of Time. Months were given new
    names based on nature, each day of the year, instead of being named
    after an associated saint, had a unique name associated with the rural
    economy: agricultural tools, common animals, grains, pastures, trees,
    roots, flowers, fruits, plants, and minerals. But this was also an
    attempt to give more rational in measuring Time, basing measures on
    decimal system. Instead of weeks, each month was divided into exactly 3
    décades, that is ten days; days were divided into ten hours; hours into
    100 minutes; and minutes into 100 seconds.

    You must have a registering account on each of the targets you want to
    spread the revolutionary date. And you must get credentials for
    spread-revolutionary-date to post on Twitter and Mastodon. Finally, you
    have to configure spread-revolutionary-date to use these credentials,
    see "CONFIGURATION" and "COMMAND LINE PARAMETERS" below.

    The revolutionary date and time is computed thanks to the
    DateTime::Calendar::FrenchRevolutionary Perl module, by Jean Forget.

USAGE

      # Just execute the script in your shell
      # to spread current date to configured accounts on Twitter, Mastodon and Freenode:
      $ spread-revolutionary-date
    
      # Or, since this script do nothing but calling the L<App::SpreadRevolutionaryDate> Perl module,
      # use this one-liner:
      $ perl -MApp::SpreadRevolutionaryDate -e 'App::SpreadRevolutionaryDate->new->spread;'
    
      # Test spreading to Mastodon only:
      $ spread-revolutionary-date --mastodon --test
    
      # Spread to Twitter and Freenode explicit channels
      $ spread-revolutionary-date --twitter --freenode \
          --freenode-channels='#revolution' --freenode-channels='#acab'

CONFIGURATION

    Once again: you have to configure spread-revolutionary-date with
    credentials for registered account on each of the desired targets, so
    it can spread the revolutionary date on behalf of theses accounts.

    Configuration options may also be specified as command line parameters,
    see "COMMAND LINE PARAMETERS" below, which take precedence on options
    of the configuration file.

    The configuration file should lie on
    ~/.config/spread-revolutionary-date/spread-revolutionary-date.conf or
    ~/.spread-revolutionary-date.conf. In case a file is found on both
    paths, the second one is ignored. The configuration file should use the
    popular INI file format <https://en.wikipedia.org/wiki/INI_file>. A
    sample configuration file can be found in this distribution at
    etc/sample-spread-revolutionary-date.conf.

 General options

    These options should appear outside of any section of the cofiguration
    file.

  twitter

    Spread on Twitter explicitely. If none of the twitter, mastodon,
    freenode option is set, the revolutionary date is spread on all of
    these three targets.

  mastodon

    Spread on Mastodon explicitely. If none of the twitter, mastodon,
    freenode option is set, the revolutionary date is spread on all of
    these three targets.

  freenode

    Spread on Freenode explicitely. If none of the twitter, mastodon,
    freenode option is set, the revolutionary date is spread on all of
    these three targets.

  test

    Do no not actually spread the revolutionary date, just print it on
    standard output for Twitter and Mastodon, and send it on configured
    test channels for Freenode (see <L/"test channels> below).

  acab

    Instead of spreading the current date and time, pretend that decimal
    time is 1:31:20 (which corresponds to 03:08:56 Paris winter time, in
    sexagesimal scale used by common Anglo-Babylonian Time).

 Twitter options

    Theses options are credentials for spread-revolutionary-date to spread
    on a Twitter account. You have to get them from your Twitter API
    account <https://apps.twitter.com/> with write access level.

  consumer_key

    Your Twitter Consumer API key for this application.

  consumer_secret

    Your Twitter Consumer API secret key for this application.

  access_token

    Your Twitter Access token for this application.

  access_token_secret

    Your Twitter Access token secret for this application.

 Mastodon options

    Theses options are credentials for spread-revolutionary-date to spread
    on a Mastodon account. You have to get them from your Mastodon instance
    API account <https://mstdn.fr/settings/applications> with write scope.
    Note that Mastodon is a decentralized network with multiple instances,
    the previous link is for mstdn.fr instance, please replace url with
    your preferred instance.

  instance

    The domain name of your instance, eg: mastodon.social, mstdn.fr, etc.

  client_id

    Your Mastodon Client key for this application.

  client_secret

    Your Mastodon Client secret for this application.

  access_token

    Your Mastodon Access token for this application.

 Freenode options

    The first two options are credentials for spread-revolutionary-date to
    spread on a Freenode account. See
    https://freenode.net/kb/answer/registration to find out how to register
    an account on Freenode.

  nickname

    Your Freenode nickname.

  password

    Your Freenode password.

  channels

    This option can be specified multiple time. spread-revolutionary-date
    will spread on every channel specified with this option. This option
    should be specified at least one time if "test" option is not set. It
    is ignored if "test" option is set.

  test_channels

    This option can be specified multiple time. spread-revolutionary-date
    will spread on every channel specified with this option. This option
    should be specified at least one time if "test" option is set. It is
    ignored if "test" option is not set.

COMMAND LINE PARAMETERS

    Any command line parameter takes precedence on the corresponding option
    specified on the confiuration file, see ""CONFIGURATION" below.

 General parameters

  --twitter

    Same as "twitter" configuration option below.

  --mastodon

    Same as "mastodon" configuration option below.

  --freenode

    Same as "freenode" configuration option below.

  --test

    Same as "test" configuration option below.

  --acab

    Same as "acab" configuration option below.

 Twitter parameters

    Theses parameters specify credentials for spread-revolutionary-date to
    spread on a Twitter account. You have to get them from your Twitter API
    account <https://apps.twitter.com/> with write access level.

  --twitter-consumer_key

    Same as "consumer-key" configuration option below.

  --twitter-consumer_secret

    Same as "consumer-secret" configuration option below.

  --twitter-access_token

    Same as "access_token" configuration option below.

  --twitter-access_token_secret

    Same as "access_token_secret" configuration option below.

 Mastodon parameters

    Theses parameters specify credentials for spread-revolutionary-date to
    spread on a Mastodon account. You have to get them from your Mastodon
    instance API account <https://mstdn.fr/settings/applications> with
    write scope. Note that Mastodon is a decentralized network with
    multiple instances, the previous link is for mstdn.fr instance, please
    replace url with your preferred instance.

  --mastodon-instance

    Same as "instance" configuration option below.

  --mastodon-client_id

    Same as "client_id" configuration option below.

  --mastodon-client_secret

    Same as "client_secret" configuration option below.

  --mastodon-access_token

    Same as "access_token" configuration option below.

 Freenode parameters

    The first two parameters are credentials for spread-revolutionary-date
    to spread on a Freenode account. See
    https://freenode.net/kb/answer/registration to find out how to register
    an account on Freenode.

  --freenode-nickname

    Same as "nickname" configuration option below.

  --freenode-password

    Same as "password" configuration option below.

  --freenode-channels

    Same as "channels" configuration option below.

  --freenode-test_channels

    Same as "test_channels" configuration option below.

SEE ALSO

    App::SpreadRevolutionaryDate

    DateTime::Calendar::FrenchRevolutionary

    AppConfig

    Net::Twitter::Lite::WithAPIv1_1

    Mastodon::Client

    Bot::BasicBot

AUTHOR

    Gérald Sédrati-Dinet <gibus@cpan.org>

COPYRIGHT AND LICENSE

    This software is Copyright (c) 2019 by Gérald Sédrati-Dinet.

    This is free software, licensed under:

      The GNU General Public License, Version 3, June 2007

