https://github.com/scorphus/okapi
Request Wrapper to instrument HTTP calls
https://github.com/scorphus/okapi
Last synced: 11 months ago
JSON representation
Request Wrapper to instrument HTTP calls
- Host: GitHub
- URL: https://github.com/scorphus/okapi
- Owner: scorphus
- License: bsd-3-clause
- Created: 2015-09-02T20:20:15.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2015-09-02T21:16:05.000Z (almost 11 years ago)
- Last Synced: 2025-02-16T20:28:05.697Z (over 1 year ago)
- Language: Python
- Size: 127 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.rst
- Changelog: CHANGES.rst
- License: LICENSE
Awesome Lists containing this project
README
Okapi
=====
Python Library to send API info to Storage Server
Okapi setup
===========
In an existing project you should at least modify the following files:
requirements/base.txt
---------------------
Add the following requirement to the project's settings. It won't be needed to
add ``requests`` if the project is already using it.
``requests`` version should be >= 2.2.11:
.. code-block:: python
okapi==X.Y.Z
settings.py
-----------
Add the following configuration to the project's settings:
.. code-block:: python
########## OKAPI CONFIGURATION
OKAPI_PROJECT = 'your-project-name'
OKAPI_URI = None
if settings.has_section('okapi'):
OKAPI_URI = 'mongodb://{0},{1},{2}/{3}?replicaSet={4}'.format(
settings.get('okapi', 'host0'),
settings.get('okapi', 'host1'),
settings.get('okapi', 'host2'),
settings.get('okapi', 'name'),
settings.get('okapi', 'replica'),
)
########## END OKAPI CONFIGURATION
Note that if the project is already using *MongoDB*, you shouldn't store Okapi's
data into the same database. Okapi creates collections dynamically and could
conflict with your the project's.
Initialization
--------------
Initialize Okapi in the ``models.py`` file of a basic application of the project.
This way Okapi will be imported at startup time:
.. code-block:: python
import requests
from django.conf import settings
from okapi.api import Api
project_name = getattr(settings, 'OKAPI_PROJECT')
mongodb_uri = getattr(settings, 'MONGODB_URI')
okapi_client = Api(project_name, requests, mongodb_uri)
Usage
-----
Once initialized you can use Okapi wherever you use ``requests`` library.
Think of Okapi as if you were using ``requests`` because they both have the same
API.
Requests documentation: http://docs.python-requests.org/en/latest/
Activating/deactivating okapi in your project
---------------------------------------------
In the file ``settings/base.py`` under the ``OKAPI CONFIGURATION`` section, you
can add a boolean setting in order to enable/disable okapi for your project. It
could be interesting to have it enabled in QA or staging environment and after
it has been properly tested, activate it also in production.
You can have a section into ``your-project-name/settings/dev.py``:
.. code-block:: python
########## OKAPI CONFIGURATION
OKAPI_ENABLED = True
########## END OKAPI CONFIGURATION
Another one into ``your-project-name/settings/production.py``:
.. code-block:: python
########## OKAPI CONFIGURATION
OKAPI_ENABLED = False
########## END OKAPI CONFIGURATION
And so on. Note that ``get_custom_setting`` is a wrapper around ``getattr``.
Then you could initialize it conditionally as shown below:
.. code-block:: python
http_lib = requests
if (get_custom_setting('OKAPI_ENABLED') and okapi_uri is not None):
project_name = get_custom_setting('OKAPI_PROJECT', required=True)
okapi_uri = get_custom_setting('OKAPI_URI', required=True)
okapi_client = Api(project_name, requests, okapi_uri)
http_lib = okapi_client