Libreria para manejar objetos almacenados en MongoDB, usando la referencia de los CRUDRepository de SpringBoot
Project description
Mongo Manager (0.9.1)
Libreria para el manejo de Objetos almacenados en base de datos MongoDB.
Testeado el funcionamiento basico en Python 3.7, 3.8, 3.9, 3.10 y 3.11 y para las versiones de Mongo 4.2, 4.4, 5.0 y 6.0.
Clases
MongoManager
Crea la conexion con la base de datos, se debe inicilizar antes de invocar ningun repositorio de objetos.
ObjetoMongoAbstract
Clase abstracta en la que se representa un objeto mongo predefinido, su constructor recibe un object _id haciendo referencia al '_id' del objeto Mongo y **kwargs con los argumentos desechados por el constructor concreto de tu clase. Es recomendable llamar al contructor padre para establecer los atributos.
Objetos internos
En caso de tener objetos interno dentro del objeto principal es necesario reescribir las funciones internas get_dict y generar_object_from_dict de forma que el objeto se transforme y destransforme en un diccionario.
En caso de que el objeto o la lista de objetos internos hereden de la clase ObjetoMongoAbstract se puede modificar el metodo get_attr_nested_objects de la siguiente manera {nombre_atributo: clase_atributo(aunque sea una lista)} y automaticamente se instanciaran y desinstanciaran solos.
RepositoryBase
Repositorio base de mongo, recibe como parametros en el constructor, la coleccion a la que se hace referencia y el objeto al que va a convertir los resultados de las query que se realicen.
En caso de querer usar una coleccion no perteneciente a la base de datos instanciada, se puede pasar el atributo connection_collection que debe ser una instancia de la conexion MongoClient para la coleccion a tratar por el repositorio.
Ejemplo 1
En este ejemplo veremos el uso de la libreria definiendo un objeto Book que hereda de ObjetoMongoAbstract y para el que implementa un RepositoryBook para poder manejar el objeto de manera más comoda.
class Book(ObjetoMongoAbstract):
def __init__(self, name, id_mongo=None, **kwargs):
super().__init__(id_mongo, **kwargs)
self.name = name
def __str__(self) -> str:
return "{}".format(self.name)
class BookOverrided(ObjetoMongoAbstract):
def __init__(self, name, id_mongo=None, **kwargs):
super().__init__(id_mongo, **kwargs)
self.name = name
def get_dict(self, id_mongo=True, id_as_string=False) -> dict:
d = super().get_dict(id_mongo, id_as_string)
d.pop('name')
d['nombre'] = self.name
return d
@classmethod
def generar_object_from_dict(cls, dictionary):
if dictionary is None:
return None
return cls(name=dictionary.get('nombre'))
def __str__(self) -> str:
return "{}".format(self.name)
class RepositoryBook(RepositoryBase[Book]):
def __init__(self, conection_collection=None) -> None:
super().__init__('book', Book, conection_collection)
class RepositoryBookOverrided(RepositoryBase[BookOverrided]):
def __init__(self, conection_collection=None) -> None:
super().__init__('book', BookOverrided, conection_collection)
def main():
a = RepositoryBook()
b = Book('test')
c = RepositoryBookOverrided()
d = BookOverrided('test')
a.insert_one(b)
c.insert_one(d)
print(a.find_all()[-1])
print(c.find_all()[-1])
if __name__ == '__main__':
MongoManager('user', 'psw', 'bd', 'authenticationDatabase')
main()
Aggregates
Los Aggregates se han dispuesto para poder ser creados de dos maneras distintas.
-
Usando los decoradores definidos en el fichero aggregation_decorator.py en combinacion con las clases AggregationStage y AggregationOperation cuyos hijos implementan los distintas funciones permitidas en MongoDB, asi como los parametros que reciben.
El decorador permite a la función definida dentro de una clase que herede de RepositoryBase, recibir un AggregationExecutor que se ejecutar una vez finalizada la función, para ello todas las funciones usen estos decoradores deberán devolver dicho parametro.
Un ejemplo se puede ver a continuación, en el que se realiza un match a todos los libros que tengan en su nombre una s mayuscula o minuscula, agrupa el resultado por nombre y cuenta los integrantes de cada grupo y finalmente genera el resultado con el formato {name: book_name_group, counter: total_books}:
class RepositoryBook(RepositoryBase[Book]): def __init__(self, conection_collection=None) -> None: super().__init__('book', Book, conection_collection) @agg_de.aggregation_decorator def test_aggregation(self, agg: AggregationExecutor): a = agg_st.AggStMatch() a['nombre'] = agg_op_re.AggOpRegex('test', agg_op_re.AggOpRegex.get_options_regex(insensitive=True)) b = agg_st.AggStGroup(id_mapping={'name': '$name'}) b['counter'] = {'$sum': 1} c = agg_st.AggStProject({'name': '$_id.name', 'counter': 1}) agg.add_steps(a, b, c) return agg
-
Usando los antigüos metodos definidos en el mongo_utils.py que sirven de ayuda para poder generar los aggregates.
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
Hashes for mongo-manager-juan-palma-borda-0.9.1.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4326eaef6ad9670a3a1f22521484c7fce3a947ae0328e01321b1d1db4bce6d75 |
|
MD5 | 0fd9ddd5c574341d5f9b74ce910a2dc7 |
|
BLAKE2b-256 | 9581c01c23ca679819a3e2c4e5f9add713d6b0e6980d5f4459ae12b50ee5c8e0 |
Hashes for mongo_manager_juan_palma_borda-0.9.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 674acdfb6db1b493be539891c80e605199c8aed3c05458214c62ab9f69bd2824 |
|
MD5 | d944c102653acf3a249a3aa53173d825 |
|
BLAKE2b-256 | 1438b9dcf4bf3922581e4b6d042e1702f3f3d14c805fbf582ea4b6d3708158f9 |