Metadata-Version: 2.1
Name: betagr-common
Version: 0.1.4a0
Summary: API-Common package for betagr-project.
Home-page: https://github.com/AndsoiIo/betagr-common
Author: AndsoiIo
Author-email: andsoiio@gmail.com
License: UNKNOWN
Description: # BetAgr-common - base async api-clients for betagr-project wrote with aiohttp
        
        A set of tools, utilities and base async api-classes for maintaining the infrastructure of betagr-project services.
        
        ### Requirements
        
        * python>=3.6
        * aiohttp>=3.6
        
        ### Usage
        
        ```
        pip install betagr-common
        
        # or only for user
        python -m pip install --user betagr-common
        
        # or for pipenv
        pipenv install betagr-common
        ```
        
        BetAgr-common ships with two base api-classes: BaseClient and BaseClientSSO.
        
        ##### BaseClient
        
        It is a base class provides a basic REST API methods which are simple wrapper over a aiohttp.request.
        Сlass also implements basic logging of client requests and handling cookies within one client, since the connection session exists only during one request.
        
        Api-clients of each  services should be inherited from the BaseClient.
        
        ```python
        from common.rest_client.base_client import BaseClient
        
        class BakeryClient(BaseClient):
        
            _host = 'www.some-bakery.com'
            _port = 8000
        
            def __init__(self, headers):
                super().__init__(headers=headers)
        
            async def bake_bread(self, bread_flour='first-grade'):
                body = {'flour': bread_flour}
                api_uri = 'api/bake-bread'
                
                return await self.post(api_uri, body=body)
        ```
        
        ```python
        import asyncio
        import BakeryClient
        
        db_orders = {'John Doe': {'flour': 'first-grade'},
                     'Anderson': {'flour': 'second-grade'}}
        
        async def main():
            async for client in db_orders:
                custom_headers = {'Content-Type': 'application/json'}
        
                bakery_client = BakeryClient(custom_headers)
                
                bread_flour_type = db_orders[client].get('flour')            
        
                response = await bakery_client.bake_bread(bread_flour_type)
                assert response.status == 200    # bread was bake!
                                
        
        loop = asyncio.get_event_loop()
        loop.run_until_complete(main())  
        ```
        
        ##### BaseClientSSO
        Api abstraction for sso-client with the release of basic methods:
        * sign_up
        * sign_in
        * sign_out
        * reset_password
        
        ```python
        import os
        import asyncio
        from common.rest_client.base_client_sso import BaseClientSSO
        
        
        async def main():
            # env should contains 'SSO_API_HOST' and 'SSO_API_PORT' variables
            headers = {'Content-Type': 'application/x-www-form-urlencoded'}
            
            sso_client = BaseClientSSO(headers)
        
            body = {'username': 'john doe',
                    'password': 'qwerty'}
        
            response = await sso_client.sign_up(body)
            print(response)    # ClientResponse -> defaults
                               # {'json': {},
                               #  'status': 200,
                               #  'headers': {'Content-Type: "application/json"},
                               #  'raw_content': b''}
        
            body = {'username': 'john doe',
                    'password': 'qwerty'}
        
            response = await sso_client.sign_in(body)
            print(response)
        
            body = {'username': 'john doe',
                    'old_password': 'qwerty',
                    'new_password': 'qwerty'}
        
            response = await sso_client.reset_password(body)
            print(response)
        
            response = await sso_client.sign_out()
            print(response)
        
        loop = asyncio.get_event_loop()
        loop.run_until_complete(main())
        
        ```
        Environment variables are used to determine url/connection parameters in base classes:
        
        |            env variable         |             value               |
        |               ---               |              ---                |
        | SSO_API_HOST                    |    localhost, www.example.com   |
        | SSO_API_PORT                    |              8080               |
        | PARSER_API_HOST                 |    localhost, www.example.com   |
        | PARSER_API_PORT                 |              8080               |
        | AGGREGATOR_API_HOST             |    localhost, www.example.com   |
        | AGGREGATOR_API_PORT             |              8080               |
        | COMMON_API_CLIENT_LOGGING_LEVEL |               40                |
        
        see numeric represents logging level here: https://docs.python.org/3/library/logging.html#logging-levels
        
Platform: UNKNOWN
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Requires-Python: >=3.6
Description-Content-Type: text/markdown
