123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118 |
- # -*- coding: utf-8 -*-
-
- import pymongo
- from pymongo import MongoClient
-
- from lodel.settings.settings import Settings as settings
-
- common_collections = {
- 'object': 'objects',
- 'relation': 'relation'
- }
-
- collection_prefix = {
- 'relation': 'rel_',
- 'object': 'class_'
- }
-
-
- LODEL_SORT_OPERATORS_MAP = {
- 'ASC': pymongo.ASCENDING,
- 'DESC': pymongo.DESCENDING
- }
-
- MONGODB_SORT_OPERATORS_MAP = {
- 'ASC': 1,
- 'DESC': -1
- }
-
- MANDATORY_CONNECTION_ARGS = ('host', 'port', 'login', 'password', 'dbname')
-
-
- class MongoDbConnectionError(Exception):
- pass
-
-
- ## @brief gets the settings given a connection name
- # @param connection_name str
- # @return dict
- # @todo Use the settings module to store the connections parameters
- def get_connection_args(connnection_name='default'):
- return {'host': 'localhost', 'port': 28015, 'login': 'lodel_admin', 'password': 'lapwd', 'dbname': 'lodel'}
-
-
- def connection_string(host, port, username, password):
- ret = 'mongodb://'
- if username != None:
- ret += username
- if password != None:
- ret += ':'+password
- ret+='@'
- elif password != None:
- raise RuntimeError("Password given but no username given...")
- host = 'localhost' if host is None else host
- ret += host
- if port != None:
- ret += ':'+str(port)
- return ret
-
- ##@brief Return an instanciated MongoClient
- #@param host str : hostname or ip
- #@param port int : port
- #@param username str | None: username
- #@param password str|None : password
- def connection(host, port, username, password):
- conn_str = connection_string(host, port, username, password)
- return MongoClient(conn_str)
-
- ##@brief Return a database cursor
- #@param host str : hostname or ip
- #@param port int : port
- #@param db_name str : database name
- #@param username str | None: username
- #@param password str|None : password
- def connect(host, port, db_name, username, password):
- conn = connection(host, port, username, password)
- database = conn[db_name]
- return database
-
-
- ## @brief Returns a collection name given a EmClass
- # @param class_object EmClass
- # @return str
- def object_collection_name(class_object):
- if not class_object.pure_abstract:
- class_parent = class_object.parents[0].uid
- collection_name = ("%s%s" % (collection_prefix['object'], class_parent)).lower()
- else:
- collection_name = ("%s%s" % (collection_prefix['object'], class_object.name)).lower()
-
- return collection_name
-
-
- ## @brief Determine a collection field name given a lodel2 fieldname
- # @note For the moment this method only return the argument but EVERYWHERE
- # in the datasource we should use this method to gather proper fieldnames
- # @param fieldname str : A lodel2 fieldname
- # @return A string representing a well formated mongodb fieldname
- # @see mongo_filednames
- def mongo_fieldname(fieldname):
- return fieldname
-
-
- ## @brief Same as mongo_fieldname but for list of fields
- #
- # A small utility function
- # @param fieldnames iterable : contains str only
- # @return a list of converted fildnames (str)
- # @see mongo_fieldname
- def mongo_fieldnames(fieldnames):
- return [mongo_fieldname(fname) for fname in fieldnames]
-
-
- ## @brief Returns a list of orting options
- # @param query_filters_order list
- # @return list
- def parse_query_order(query_filters_order):
- return [(field, LODEL_SORT_OPERATORS_MAP[direction])
- for field, direction in query_filters_order]
|