File size: 1,933 Bytes
1fed057
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
import os
from dotenv import load_dotenv
from pymongo import MongoClient
from src.utils.constants import Constants
from src.utils.logging import get_logger

class DatabaseConnection:
    """
    Class to handle the connection to MongoDB Atlas and provide methods for database operations.
    """

    def __init__(self):
        """
        Initialize the database connection using the MongoDB URI from environment variables.
        """
        self.logger = get_logger()
        self.logger.info("Initializing database connection")

        load_dotenv()
        self.mongodb_uri = os.getenv("MONGODB_URI")
        if not self.mongodb_uri:
            self.logger.error("MONGODB_URI environment variable is not set")
            raise ValueError("MONGODB_URI environment variable is not set")

        try:
            self.client = MongoClient(self.mongodb_uri)
            self.db = self.client[Constants.DB_NAME]
            self.collection = self.db[Constants.COLLECTION_NAME]
            self.logger.info(f"Connected to MongoDB database: {Constants.DB_NAME}, collection: {Constants.COLLECTION_NAME}")
        except Exception as e:
            self.logger.error(f"Failed to connect to MongoDB: {str(e)}")
            raise

    def get_collection(self):
        """
        Get the MongoDB collection.

        Returns:
            pymongo.collection.Collection: The MongoDB collection.
        """
        self.logger.debug(f"Getting collection: {Constants.COLLECTION_NAME}")
        return self.collection

    def close_connection(self):
        """
        Close the MongoDB connection.
        """
        self.logger.info("Closing MongoDB connection")
        if self.client:
            try:
                self.client.close()
                self.logger.info("MongoDB connection closed successfully")
            except Exception as e:
                self.logger.error(f"Error closing MongoDB connection: {str(e)}")