Source code for pm4py.streaming.util.dictio.versions.redis
'''
PM4Py – A Process Mining Library for Python
Copyright (C) 2024 Process Intelligence Solutions UG (haftungsbeschränkt)
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as
published by the Free Software Foundation, either version 3 of the
License, or any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see this software project's root or
visit <https://www.gnu.org/licenses/>.
Website: https://processintelligence.solutions
Contact: info@processintelligence.solutions
'''
from enum import Enum
from threading import Lock
from typing import Optional, Dict, Any
from pm4py.util import exec_utils
[docs]
class Parameters(Enum):
HOSTNAME = "hostname"
PORT = "port"
DICT_ID = "dict_id"
[docs]
class ThreadSafeRedisDict(dict):
def __init__(self, redis_connection, *args, **kw):
super(ThreadSafeRedisDict, self).__init__(*args, **kw)
self.redis_connection = redis_connection
self.lock = Lock()
def __setitem__(self, key, value):
# TODO: what should happen to the order if
# the key is already in the dict
self.lock.acquire()
self.redis_connection[key] = value
super(ThreadSafeRedisDict, self).__setitem__(key, value)
self.lock.release()
def __iter__(self):
self.lock.acquire()
ret = iter(list(self.redis_connection.keys()))
self.lock.release()
return ret
[docs]
def keys(self):
self.lock.acquire()
ret = list(self.redis_connection.keys())
self.lock.release()
return ret
[docs]
def values(self):
self.lock.acquire()
ret = self.redis_connection.values()
self.lock.release()
return ret
[docs]
def itervalues(self):
self.lock.acquire()
ret = self.redis_connection.itervalues()
self.lock.release()
return ret
[docs]
def flushdb(self):
self.lock.acquire()
self.redis_connection.flushdb()
self.lock.release()
[docs]
def flushall(self):
self.lock.acquire()
self.redis_connection.flushall()
self.lock.release()
# typing not applied, since redis is not installed by default
# anyhow, the type of the returned "r" is redis.redis.Redis
[docs]
def apply(parameters: Optional[Dict[Any, Any]] = None):
"""
Create a Python dictionary supported by a Redis database
Parameters
--------------
parameters
Parameters of the algorithm, including:
- Parameters.HOSTNAME => hostname of the connection to Redis (default: 127.0.0.1)
- Parameters.PORT => port of the connection to Redis (default: 6379)
- Parameters.DICT_ID => integer identifier of the specific dictionary in Redis (default: 0)
Returns
--------------
r
Redis (Python-like) dictionary
"""
if parameters is None:
parameters = {}
import redis
hostname = exec_utils.get_param_value(
Parameters.HOSTNAME, parameters, "127.0.0.1"
)
port = exec_utils.get_param_value(Parameters.PORT, parameters, 6379)
dict_id = exec_utils.get_param_value(Parameters.DICT_ID, parameters, 0)
r = redis.StrictRedis(
host=hostname, port=port, db=dict_id, decode_responses=True
)
return ThreadSafeRedisDict(r)