Metadata-Version: 2.0
Name: prawcore
Version: 0.0.12
Summary: Low-level communication layer for PRAW 4+.
Home-page: https://github.com/praw-dev/prawcore
Author: Bryce Boe
Author-email: bbzbryce@gmail.com
License: Simplified BSD License
Keywords: praw reddit api
Platform: UNKNOWN
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: BSD License
Classifier: Natural Language :: English
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.3
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: Implementation :: CPython
Requires-Dist: requests (<3.0,>=2.9.1)

.. _main_page:

prawcore
========

.. image:: https://travis-ci.org/praw-dev/prawcore.svg?branch=master
           :target: https://travis-ci.org/praw-dev/prawcore
.. image:: https://coveralls.io/repos/github/praw-dev/prawcore/badge.svg?branch=master
           :target: https://coveralls.io/github/praw-dev/prawcore?branch=master


Notice: This package is in development and should not be used until this notice
is removed.

prawcore is a low-level communication layer for PRAW 4+.


Installation
------------

Install prawcore using ``pip`` via:

.. code-block:: console

    pip install prawcore


Execution Example
-----------------

The following example demonstrates how to use prawcore to obtain the list of
trophies for a given user. This example assumes you have the environment
variables ``PRAWCORE_CLIENT_ID`` and ``PRAWCORE_CLIENT_SECRET`` set to the
appropriate values for your application.

.. code-block:: python

   #!/usr/bin/env python
   import os
   import pprint
   import prawcore

   authenticator = prawcore.Authenticator(
       prawcore.Requestor('YOUR_VALID_USER_AGENT'),
       os.environ['PRAWCORE_CLIENT_ID'],
       os.environ['PRAWCORE_CLIENT_SECRET'])
   authorizer = prawcore.ReadOnlyAuthorizer(authenticator)
   authorizer.refresh()

   with prawcore.session(authorizer) as session:
       pprint.pprint(session.request('GET', '/api/v1/user/bboe/trophies'))

Save the above as ``trophies.py`` and then execute via:

.. code-block:: console

   python trophies.py

Additional examples can be found at:
https://github.com/praw-dev/prawcore/tree/master/examples


Depending on prawcore
---------------------

prawcore follows `semantic versioning <http://semver.org/>`_ with the exception
that deprecations will not be preceded by a minor release. In essense, expect
only major versions to introduce breaking changes to prawcore's public
interface. As a result, if you depend on prawcore then it is a good idea to
specify not only the minimum version of prawcore your package requires, but to
also limit the major version.

Below are two examples of how you may want to specify your prawcore dependency:

setup.py
~~~~~~~~

.. code-block:: python

   setup(...,
         install_requires=['prawcore >=0.1, <1'],
         ...)

requirements.txt
~~~~~~~~~~~~~~~~

.. code-block:: text

   prawcore >=1.5.1, <2


