Some extensions for redis-limpyd, a redis orm (sort of) in python.
Project description
redis-limpyd-extensions
Some extensions for redis-limpyd (redis orm (sort of) in python)
Where to find it:
Github repository: https://github.com/limpyd/redis-limpyd-extensions
Pypi package: https://pypi.python.org/pypi/redis-limpyd-extensions
Documentation: http://documentup.com/limpyd/redis-limpyd-extensions
Install:
Python versions 2.7, and 3.5 to 3.8 are supported (CPython and PyPy).
Redis-server versions >= 3 are supported.
Redis-py versions >= 3 are supported.
Redis-limpyd versions >= 2 are supported.
You can still use limpyd-extensions versions < 2 if you need something older than the above requirements.
pip install redis-limpyd-extensions
List of available extensions:
Add/remove related on both sides
Dynamic fields
Dynamic fields
Dynamic fields provide a way to add unlimited fields to a model by defining a (or many) dynamic field, and use it with a dynamic part. ie a dynamic field name “foo” can be used with as many dynamic parts as you want to create dynamic variations: “foo_bar” for the dynamic part “bar”, “foo_baz” for the dynamic part “baz”, and so on.
A simple API to use them, and filter on them, is provided.
To use a dynamic field, your model must inherit from the following mixin: ModelWithDynamicFieldMixin, found in limpyd_extensions.dynamic.model. It’s a mixin, you should use it with another RedisModel class. Fields are available as field classes (DynamicStringField, DynamicInstanceHashField, DynamicListField, DynamicSetField, DynamicSortedSetField, DynamicHashField) or as a mixin (DynamicFieldMixin) if you want to adapt an external field. You can find them in limpyd_extensions.dynamic.fields
A short example on how to define a dynamic field on a model:
from limpyd.model import RedisModel
from limpyd_extension.dynamic.model import ModelWithDynamicFieldMixin
from limpyd_extension.dynamic.fields import DynamicSetField
class MyModel(ModelWithDynamicFieldMixin, RedisModel):
foo = DynamicSetField(indexable=True)
As the foo field is dynamic, you cannot run any command on it, but only on its dynamic variations. How to do it ?
There is two ways:
use the get_field method of the model:
foo_bar = myinstance.get_field('foo_bar')
use the get_for method of the field:
foo_bar = myinstance.foo.get_for('bar')
The latter is useful if you have a variable instead of known value:
somebar = 'bar'
foo_bar = myinstance.foo.get_for(somevar)
Note that you can use this shortcut instead of using get_for:
foo_bar = myinstance.foo(somevar)
Knowing this, you can do operations on these fields:
myinstance.foo(somevar).sadd('one', 'two', 'three')
myinstance.foo(othervar).sadd('four', 'five')
myotherinstance.foo(somevar).sadd('three', 'thirty')
print myinstance.foo(somevar).smembers()
print myinstance.foo(othervar).smembers()
print myotherinstance.foo(somevar).smembers()
To know the existing versions in a dynamic_field, you can use scan_fields.
It takes the same argument as the sscan command of SetField (from limpyd), because it is applied on the inventory key where all versions are saved.
So if you have some versions:
You can retrieve them all:
Or only a part:
Filtering
To filter on indexable dynamic fields, there is two ways too:
use the classic way, if you now the dynamic part in advance:
MyModel.collection(foo_bar='three')
use the new dynamic_filter method:
MyModel.collection().dynamic_filter('foo', 'bar', 'three')
Parameters are: the field name, the dynamic part, the value for the filter and, not show in the previous example, the index suffix to use.
This suffix is default to ‘’.
But if what you want to do is
MyModel.collection(foo_bar__eq='three')
You can use dynamic_filter this way:
MyModel.collection().dynamic_filter('foo', 'bar', 'three', 'eq') # you can use '__eq' too
The collection manager used with ModelWithDynamicFieldMixin depends on ExtendedCollectionManager, so you can chain filters and dynamic filters on the resulting collection.
Provided classes
Here is the list of modules and classes provided with the limpyd_extensions.dynamic module:
model
mixins
ModelWithDynamicFieldMixin(object) - A mixin tu use for your model with dynamic fields
collection
mixins
CollectionManagerForModelWithDynamicFieldMixin(object) - A mixin to use if you want to add the dynamic_filter method to your own collection manager
full classes
CollectionManagerForModelWithDynamicField(CollectionManagerForModelWithDynamicFieldMixin, ExtendedCollectionManager) - A simple class inheriting from our mixin and the manager from limpyd.contrib.collection
field
mixins
DynamicFieldMixin(object) - A mixin within all the stuff for dynamic fields is done, to use to add dynamic field support to your own fields
full classes All fields simply inherits from our mixin and the wanted base field, without anymore addition:
DynamicStringField(DynamicFieldMixin, StringField)
DynamicInstanceHashField(DynamicFieldMixin, InstanceHashField)
DynamicListField(DynamicFieldMixin, ListField)
DynamicSetField(DynamicFieldMixin, SetField)
DynamicSortedSetField(DynamicFieldMixin, SortedSetField)
DynamicHashField(DynamicFieldMixin, HashField)
related
mixins
DynamicRelatedFieldMixin(DynamicFieldMixin) - A mixin within all the stuff for dynamic related fields is done, to use to add dynamic field support to your own related fields
full classes
DynamicFKStringField(DynamicRelatedFieldMixin, FKStringField)
DynamicFKInstanceHashField(DynamicRelatedFieldMixin, FKInstanceHashField)
DynamicM2MSetField(DynamicRelatedFieldMixin, M2MSetField)
DynamicM2MListField(DynamicRelatedFieldMixin, M2MListField)
DynamicM2MSortedSetField(DynamicRelatedFieldMixin, M2MSortedSetField)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file redis-limpyd-extensions-2.1.tar.gz
.
File metadata
- Download URL: redis-limpyd-extensions-2.1.tar.gz
- Upload date:
- Size: 17.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.15.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.8.0b4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8e7122695f37d8314d30ad799d4614a5be2d0fe4d238f6e99aca5fc177ecfbd6 |
|
MD5 | fc207098c3d98317fd2424763241f6ad |
|
BLAKE2b-256 | b32d93f0eaa15aef9e3f2e85ae244de81eabcef7fe4a5b1a6863cb7c563bb016 |
File details
Details for the file redis_limpyd_extensions-2.1-py2.py3-none-any.whl
.
File metadata
- Download URL: redis_limpyd_extensions-2.1-py2.py3-none-any.whl
- Upload date:
- Size: 14.4 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.15.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.8.0b4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | de1a2e2d3592d13244905242e1d63d4b0d06039c14bd14a485d0f42f6a6869a7 |
|
MD5 | 32410c04f4d3965a0bd4eb5d879fe7f3 |
|
BLAKE2b-256 | f8cca8cdcbb53615c41c9fce62592054c549c71e4f1b7466a2fcafdb07fa78c5 |