Metadata-Version: 2.1
Name: wanikani-api
Version: 0.6.1
Summary: An API wrapper for Wanikani (V2)
Home-page: https://github.com/Kaniwani/wanikani_api
Author: Gary Grant Graham
Author-email: gary@kaniwani.com
License: BSD license
Keywords: wanikani_api
Platform: UNKNOWN
Classifier: Development Status :: 2 - Pre-Alpha
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: BSD License
Classifier: Natural Language :: English
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
License-File: LICENSE
License-File: AUTHORS.rst

======================
|wk_logo| wanikani_api
======================

.. |wk_logo| image:: https://discourse-cdn-sjc1.com/business5/uploads/wanikani_community/original/3X/7/a/7a2bd7e8dcf8d7766b51a77960d86949215c830c.png?v=5
        :target: https://wanikani.com
        :align: middle


.. image:: https://img.shields.io/pypi/v/wanikani_api.svg
        :target: https://pypi.python.org/pypi/wanikani_api

.. image:: https://img.shields.io/travis/Kaniwani/wanikani_api.svg
        :target: https://travis-ci.org/Kaniwani/wanikani_api

.. image:: https://readthedocs.org/projects/wanikani-api/badge/?version=latest
        :target: https://wanikani-api.readthedocs.io/en/latest/?badge=latest
        :alt: Documentation Status


.. image:: https://pyup.io/repos/github/Kaniwani/wanikani_api/shield.svg
     :target: https://pyup.io/repos/github/Kaniwani/wanikani_api/
     :alt: Updates


An API wrapper for Wanikani (V2)


* Free software: BSD license
* Documentation: https://wanikani-api.readthedocs.io.


Features
--------

* Easy access to Wanikani resources associated to your account.
* Automatic handling of pagination.
* Automatic fetching of related Subjects


Quickstart
----------

.. code-block:: python

    >>> from wanikani_api.client import Client
    >>> v2_api_key = "drop_your_v2_api_key_in_here" # You can get it here: https://www.wanikani.com/settings/account
    >>> client = Client(v2_api_key)
    >>> user_information = client.user_information()
    >>> print(user_information)
    UserInformation{ username:Tadgh11, level:8, max_level_granted_by_subscription:60, profile_url:https://www.wanikani.com/users/Tadgh11 started_at:2013-07-09 12:02:54.952786+00:00, subscribed:True, current_vacation_started_at:None }
    >>> all_vocabulary = client.subjects(types="vocabulary")
    >>> for vocab in all_vocabulary:
    >>>     print(vocab.meanings[0].meaning) #Vocabulary may have multiple meanings, we just grab the first in the list.
    One
    One Thing
    Seven
    Seven Things
    Nine
    Nine Things
    Two
    ...


TODO
----
* Make use of ETags for caching
* simplify API
* Improve automatic prefetching of subjects when relevant.

Credits
-------

This package was created with Cookiecutter_ and the `audreyr/cookiecutter-pypackage`_ project template.

.. _Cookiecutter: https://github.com/audreyr/cookiecutter
.. _`audreyr/cookiecutter-pypackage`: https://github.com/audreyr/cookiecutter-pypackage


=======
History
=======

0.5.0 (2020-08-18)
------------------
* Remove mock responses that included stage names.


0.5.0 (2020-08-18)
------------------
* Remove `passed` from resource.
* Remove `srs_stage_name` from assignments and reviews

0.4.0 (2020-04-30)
------------------
* Add Preferences to User Information
* Add Subscription to User Information

0.3.0 (2019-11-09)
------------------
* Add `auxiliary_meanings` to Subject

0.2.1 (2019-11-05)
------------------
* Fix crash caused by WK removing a field from their API.

0.1.1 (2018-06-26)
------------------

* Change Assignment endpoint to reflect the newly dropped fields from the api (`level` specifically).
* Add some proper String representation
* Work on the Etag cache, bringing it closer to completion.

0.1.0 (2018-06-26)
------------------

* First release on PyPI.


