No Description
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

utils.py 2.7KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. # -*- coding: utf-8 -*-
  2. import pymongo
  3. from pymongo import MongoClient
  4. from lodel.settings.settings import Settings as settings
  5. common_collections = {
  6. 'object': 'objects',
  7. 'relation': 'relation'
  8. }
  9. LODEL_SORT_OPERATORS_MAP = {
  10. 'ASC': pymongo.ASCENDING,
  11. 'DESC': pymongo.DESCENDING
  12. }
  13. MONGODB_SORT_OPERATORS_MAP = {
  14. 'ASC': 1,
  15. 'DESC': -1
  16. }
  17. MANDATORY_CONNECTION_ARGS = ('host', 'port', 'login', 'password', 'dbname')
  18. class MongoDbConnectionError(Exception):
  19. pass
  20. def connection_string(host, port, username, password):
  21. ret = 'mongodb://'
  22. if username != None:
  23. ret += username
  24. if password != None:
  25. ret += ':'+password
  26. ret+='@'
  27. elif password != None:
  28. raise RuntimeError("Password given but no username given...")
  29. host = 'localhost' if host is None else host
  30. ret += host
  31. if port != None:
  32. ret += ':'+str(port)
  33. return ret
  34. ##@brief Return an instanciated MongoClient
  35. #@param host str : hostname or ip
  36. #@param port int : port
  37. #@param username str | None: username
  38. #@param password str|None : password
  39. def connection(host, port, username, password):
  40. conn_str = connection_string(host, port, username, password)
  41. return MongoClient(conn_str)
  42. ##@brief Return a database cursor
  43. #@param host str : hostname or ip
  44. #@param port int : port
  45. #@param db_name str : database name
  46. #@param username str | None: username
  47. #@param password str|None : password
  48. def connect(host, port, db_name, username, password):
  49. conn = connection(host, port, username, password)
  50. database = conn[db_name]
  51. return database
  52. ## @brief Returns a collection name given a EmClass
  53. # @param class_object EmClass
  54. # @return str
  55. def object_collection_name(class_object):
  56. return class_object.__name__
  57. ## @brief Determine a collection field name given a lodel2 fieldname
  58. # @note For the moment this method only return the argument but EVERYWHERE
  59. # in the datasource we should use this method to gather proper fieldnames
  60. # @param fieldname str : A lodel2 fieldname
  61. # @return A string representing a well formated mongodb fieldname
  62. # @see mongo_filednames
  63. def mongo_fieldname(fieldname):
  64. return fieldname
  65. ## @brief Same as mongo_fieldname but for list of fields
  66. #
  67. # A small utility function
  68. # @param fieldnames iterable : contains str only
  69. # @return a list of converted fildnames (str)
  70. # @see mongo_fieldname
  71. def mongo_fieldnames(fieldnames):
  72. return [mongo_fieldname(fname) for fname in fieldnames]
  73. ## @brief Returns a list of orting options
  74. # @param query_filters_order list
  75. # @return list
  76. def parse_query_order(query_filters_order):
  77. return [(field, LODEL_SORT_OPERATORS_MAP[direction])
  78. for field, direction in query_filters_order]