This repository contains a simple implementation of the Repository pattern in Python. The implementation is based on the SOLID principles.
It supports:
- PostgreSQL
- JSON
Check the ./scripts/main.py for a full example.
# main.py
# ...
# Define the fields for the table and entities
datasource = DataSource()
table = JsonTable('users', os.path.join(path_root, 'scripts', 'data'), fields)
datasource.add_table(table)
datasource.clear('users')
dummy_users = [
User('John Doe', '[email protected]', 'johndoe'),
User('Jane Doe', '[email protected]', 'janedoe'),
User('Mary Poppins', '[email protected]', 'marypoppins'),
]
for user in dummy_users:
datasource.insert('users', user)
filters = [
Filter([
FilterCondition('name', 'Doe', FilterTypes.CONTAINS),
FilterCondition('email', '[email protected]', FilterTypes.EQUAL)
]),
Filter([
FilterCondition('name', 'Mary', FilterTypes.CONTAINS),
])
]
for user in datasource.get_by_filters('users', filters):
print(user)
print("Unique")
mary = datasource.get_unique('users', 'username', 'marypoppins')
print(mary)