Nav apraksta

Alexander aae7dab732 - updated readme with chromedriver 4 gadi atpakaļ
src 8baac5e99e - added browser.py to extend webbot to use stealth 4 gadi atpakaļ
tests 7582662543 Fix some false negative tests 4 gadi atpakaļ
.gitignore a14a2618cb Ignore build 4 gadi atpakaļ
LICENSE 28ab3e2958 Update license 4 gadi atpakaļ
Pipfile 8baac5e99e - added browser.py to extend webbot to use stealth 4 gadi atpakaļ
Pipfile.lock 8baac5e99e - added browser.py to extend webbot to use stealth 4 gadi atpakaļ
README.md aae7dab732 - updated readme with chromedriver 4 gadi atpakaļ
setup.py 721c835b36 Bump version 4 gadi atpakaļ
tox.ini 5bdd799a79 Remove python 2.7 from tox test 4 gadi atpakaļ

README.md

Rival-Regions-Wrapper

This library will functions as an authenticator an API wrapper for interaction with Rival Regions. Use at your own risk.

Install

The following steps can be used to install the package with pip:

pip install rival_regions_wrapper

The package should be available globally.

Testing

This appplication supports unit tests, these are located in rival_regions_wrapper/tests/. Intall required dependancies using pipenv install --dev. After installing you should be able to test the python package with pytest. Requests are cached for quick testing using VCR.py located at rival_regions_wrapper/tests/cassettes/. If you run in problems with testing you are advised to them run again after removing the cassettes directory.

The tests read login credentials from the following environment variables: LOGIN_METHOD, USERNAME, PASSWORD. You can set those by creating an file named .env with te following:

LOGIN_METHOD=PLACEHOLDER
USERNAME=PLACEHOLDER
PASSWORD=PLACEHOLDER

Replace PLACEHOLDER with your credentials.

Also must have the chromedriver which can be found here https://sites.google.com/a/chromium.org/chromedriver/home

Add this to the system PATH environmental variable.

Login methods

Currently the only working login method is Google. If you can help me out and make the other login methods working it would be appreciated.

login methods:

  • google
  • vk
  • facebook

Middleware

The API wrapper uses middleware to decide where how to send the request. Middlewares can also be used to write direct requests to Rival Regions.

Current middleware

LocalAuthentication

Use username, password, and login method to log in local instance of the authenticator.

RemoteAuthentication

Connect through a remote API using URL and authentication key.

Examples

Create local authentication middleware and log in with environ variables

import os
from rival_regions_wrapper import LocalAuthentication

authentication = LocalAuthentication(
  os.environ["USERNAME"],
  os.environ["PASSWORD"],
  os.environ["LOGIN_METHOD"]
)

request region page from Rival Regions

region = authentication.get('listed/upgrades/{}'.format(region_id))

Example of API wrapper to get oil current available resources from a state

from rival_regions_wrapper import apiWrapper
from rival_regions_wrapper.api_wrapper import ResourceState

api_wrapper = ApiWrapper(authentication)

state = 3382
resource = 'oil'
response = ResourceState(api_wrapper, state).info(resource)

For more examples look at the unit tests.

Contact