mirror of
https://github.com/ets-labs/python-dependency-injector.git
synced 2024-11-29 13:04:02 +03:00
Add services mini app example to docs
This commit is contained in:
parent
31f2a5d24d
commit
079d3f5ea7
|
@ -1,5 +0,0 @@
|
||||||
``dependency_injector.utils``
|
|
||||||
-----------------------------
|
|
||||||
|
|
||||||
.. automodule:: dependency_injector.utils
|
|
||||||
:members:
|
|
|
@ -16,3 +16,4 @@ and powered by *Dependency Injector* framework.
|
||||||
:maxdepth: 2
|
:maxdepth: 2
|
||||||
|
|
||||||
movie_lister
|
movie_lister
|
||||||
|
services_miniapp
|
||||||
|
|
73
docs/examples/services_miniapp.rst
Normal file
73
docs/examples/services_miniapp.rst
Normal file
|
@ -0,0 +1,73 @@
|
||||||
|
Services mini application example
|
||||||
|
---------------------------------
|
||||||
|
|
||||||
|
.. meta::
|
||||||
|
:description: "Services miniapp" is an example mini application that
|
||||||
|
consists from several services that have dependencies on
|
||||||
|
some standard and 3rd-party libraries for logging,
|
||||||
|
interaction with database and remote service via API.
|
||||||
|
"Services miniapp" example demonstrates usage of
|
||||||
|
Dependency Injector for creating several IoC containers.
|
||||||
|
|
||||||
|
"Services miniapp" is an example mini application that consists from several
|
||||||
|
services that have dependencies on some standard and 3rd-party libraries for
|
||||||
|
logging, interaction with database and remote service calls via API.
|
||||||
|
|
||||||
|
"Services miniapp" example demonstrates usage of
|
||||||
|
:doc:`Dependency Injector <../index>` for creating several IoC containers.
|
||||||
|
|
||||||
|
Instructions for running:
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
python run.py 1 secret photo.jpg
|
||||||
|
|
||||||
|
Example application
|
||||||
|
~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Classes diagram:
|
||||||
|
|
||||||
|
.. image:: /images/miniapps/services/classes.png
|
||||||
|
:width: 100%
|
||||||
|
:align: center
|
||||||
|
|
||||||
|
|
||||||
|
Example application structure:
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
/example
|
||||||
|
/__init__.py
|
||||||
|
/main.py
|
||||||
|
/services.py
|
||||||
|
|
||||||
|
|
||||||
|
Listing of ``example/services.py``:
|
||||||
|
|
||||||
|
.. literalinclude:: ../../examples/miniapps/services/example/services.py
|
||||||
|
:language: python
|
||||||
|
:linenos:
|
||||||
|
|
||||||
|
Listing of ``example/main.py``:
|
||||||
|
|
||||||
|
.. literalinclude:: ../../examples/miniapps/services/example/main.py
|
||||||
|
:language: python
|
||||||
|
:linenos:
|
||||||
|
|
||||||
|
IoC containers
|
||||||
|
~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Listing of ``containers.py``:
|
||||||
|
|
||||||
|
.. literalinclude:: ../../examples/miniapps/services/containers.py
|
||||||
|
:language: python
|
||||||
|
:linenos:
|
||||||
|
|
||||||
|
Run application
|
||||||
|
~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Listing of ``run.py``:
|
||||||
|
|
||||||
|
.. literalinclude:: ../../examples/miniapps/services/run.py
|
||||||
|
:language: python
|
||||||
|
:linenos:
|
BIN
docs/images/miniapps/services/classes.png
Normal file
BIN
docs/images/miniapps/services/classes.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 49 KiB |
|
@ -11,6 +11,11 @@ Development version
|
||||||
-------------------
|
-------------------
|
||||||
- No features.
|
- No features.
|
||||||
|
|
||||||
|
3.1.0
|
||||||
|
-----
|
||||||
|
- Add "Services mini application" example.
|
||||||
|
- Fix minor error in ``Factory`` provider API doc.
|
||||||
|
|
||||||
3.0.1
|
3.0.1
|
||||||
-----
|
-----
|
||||||
- Add ``*.c`` source files under version control.
|
- Add ``*.c`` source files under version control.
|
||||||
|
|
|
@ -2,7 +2,26 @@
|
||||||
|
|
||||||
|
|
||||||
def main(uid, password, photo, users_service, auth_service, photos_service):
|
def main(uid, password, photo, users_service, auth_service, photos_service):
|
||||||
"""Example main function."""
|
"""Authenticate user and upload photo.
|
||||||
|
|
||||||
|
:param uid: User identifier.
|
||||||
|
:type uid: int
|
||||||
|
|
||||||
|
:param password: User's password for verification.
|
||||||
|
:type password: str
|
||||||
|
|
||||||
|
:param photo_path: Path to photo for uploading.
|
||||||
|
:type photo_path: str
|
||||||
|
|
||||||
|
:param users_service: Users service.
|
||||||
|
:type users_service: example.services.UsersService
|
||||||
|
|
||||||
|
:param auth_service: Authentication service.
|
||||||
|
:type auth_service: example.services.AuthService
|
||||||
|
|
||||||
|
:param photo_service: Photo service.
|
||||||
|
:type photo_service: example.services.PhotoService
|
||||||
|
"""
|
||||||
user = users_service.get_user_by_id(uid)
|
user = users_service.get_user_by_id(uid)
|
||||||
auth_service.authenticate(user, password)
|
auth_service.authenticate(user, password)
|
||||||
photos_service.upload_photo(user['uid'], photo)
|
photos_service.upload_photo(user['uid'], photo)
|
||||||
|
|
|
@ -1,47 +1,103 @@
|
||||||
"""Example business services module."""
|
"""Example business services module."""
|
||||||
|
|
||||||
|
|
||||||
class UsersService(object):
|
class BaseService(object):
|
||||||
|
"""Service base class."""
|
||||||
|
|
||||||
|
|
||||||
|
class UsersService(BaseService):
|
||||||
"""Users service."""
|
"""Users service."""
|
||||||
|
|
||||||
def __init__(self, logger, db):
|
def __init__(self, logger, db):
|
||||||
"""Initializer."""
|
"""Initializer.
|
||||||
|
|
||||||
|
:param logger: Logger instance.
|
||||||
|
:type logger: logging.Logger
|
||||||
|
|
||||||
|
:param db: Database connection.
|
||||||
|
:type db: sqlite3.Connection
|
||||||
|
"""
|
||||||
self.logger = logger
|
self.logger = logger
|
||||||
self.db = db
|
self.db = db
|
||||||
|
|
||||||
def get_user_by_id(self, uid):
|
def get_user_by_id(self, uid):
|
||||||
"""Return user's information by login."""
|
"""Return user's data by identifier.
|
||||||
|
|
||||||
|
:param uid: User identifier.
|
||||||
|
:type uid: int
|
||||||
|
|
||||||
|
:rtype: dict
|
||||||
|
"""
|
||||||
self.logger.debug('User %s has been found in database', uid)
|
self.logger.debug('User %s has been found in database', uid)
|
||||||
return {'uid': uid,
|
return dict(uid=uid, password_hash='secret_hash')
|
||||||
'password_hash': 'secret_hash'}
|
|
||||||
|
|
||||||
|
|
||||||
class AuthService(object):
|
class AuthService(BaseService):
|
||||||
"""Auth service."""
|
"""Authentication service."""
|
||||||
|
|
||||||
def __init__(self, logger, db, token_ttl):
|
def __init__(self, logger, db, token_ttl):
|
||||||
"""Initializer."""
|
"""Initializer.
|
||||||
|
|
||||||
|
:param logger: Logger instance.
|
||||||
|
:type logger: logging.Logger
|
||||||
|
|
||||||
|
:param db: Database connection.
|
||||||
|
:type db: sqlite3.Connection
|
||||||
|
|
||||||
|
:param token_ttl: Token lifetime in seconds.
|
||||||
|
:type token_ttl: int
|
||||||
|
"""
|
||||||
self.logger = logger
|
self.logger = logger
|
||||||
self.db = db
|
self.db = db
|
||||||
self.token_ttl = token_ttl
|
self.token_ttl = token_ttl
|
||||||
|
|
||||||
def authenticate(self, user, password):
|
def authenticate(self, user, password):
|
||||||
"""Authenticate user."""
|
"""Authenticate user.
|
||||||
|
|
||||||
|
:param user: User's data.
|
||||||
|
:type user: dict
|
||||||
|
|
||||||
|
:param password: User's password for verification.
|
||||||
|
:type password: str
|
||||||
|
|
||||||
|
:raises: AssertionError when password is wrong
|
||||||
|
|
||||||
|
:rtype: None
|
||||||
|
"""
|
||||||
assert user['password_hash'] == '_'.join((password, 'hash'))
|
assert user['password_hash'] == '_'.join((password, 'hash'))
|
||||||
self.logger.debug('User %s has been successfully authenticated',
|
self.logger.debug('User %s has been successfully authenticated',
|
||||||
user['uid'])
|
user['uid'])
|
||||||
|
|
||||||
|
|
||||||
class PhotosService(object):
|
class PhotosService(BaseService):
|
||||||
"""Photos service."""
|
"""Photos service."""
|
||||||
|
|
||||||
def __init__(self, logger, db, s3):
|
def __init__(self, logger, db, s3):
|
||||||
"""Initializer."""
|
"""Initializer.
|
||||||
|
|
||||||
|
:param logger: Logger instance.
|
||||||
|
:type logger: logging.Logger
|
||||||
|
|
||||||
|
:param db: Database connection.
|
||||||
|
:type db: sqlite3.Connection
|
||||||
|
|
||||||
|
:param s3: AWS S3 client.
|
||||||
|
:type s3: boto.s3.connection.S3Connection
|
||||||
|
"""
|
||||||
self.logger = logger
|
self.logger = logger
|
||||||
self.db = db
|
self.db = db
|
||||||
self.s3 = s3
|
self.s3 = s3
|
||||||
|
|
||||||
def upload_photo(self, uid, photo_path):
|
def upload_photo(self, uid, photo_path):
|
||||||
"""Upload user photo."""
|
"""Upload user photo.
|
||||||
|
|
||||||
|
:param uid: User identifier.
|
||||||
|
:type uid: int
|
||||||
|
|
||||||
|
:param photo_path: Path to photo for uploading.
|
||||||
|
:type photo_path: str
|
||||||
|
|
||||||
|
:rtpe: None
|
||||||
|
"""
|
||||||
self.logger.debug('Photo %s has been successfully uploaded by user %s',
|
self.logger.debug('Photo %s has been successfully uploaded by user %s',
|
||||||
photo_path, uid)
|
photo_path, uid)
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
"""Dependency injector top-level package."""
|
"""Dependency injector top-level package."""
|
||||||
|
|
||||||
VERSION = '3.0.1'
|
VERSION = '3.1.0'
|
||||||
"""Version number that follows semantic versioning.
|
"""Version number that follows semantic versioning.
|
||||||
|
|
||||||
:type: str
|
:type: str
|
||||||
|
|
Loading…
Reference in New Issue
Block a user