File size: 1,856 Bytes
c2c5fc6
 
 
074c9bf
5179dac
c2c5fc6
 
6c8a384
 
c2c5fc6
 
 
 
 
074c9bf
 
 
c2c5fc6
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
21c2d6e
c2c5fc6
 
 
 
 
 
 
 
5179dac
21c2d6e
c2c5fc6
 
 
 
 
 
51a30bb
c2c5fc6
 
51a30bb
21c2d6e
 
c2c5fc6
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
56
57
58
59
60
61
62
import pymongo
import os
import pandas as pd
from config import PRODUCTION_URL, PRODUCTION_DATABASE, PRODUCTION_COLLECTION
from logger import get_logger


logger = get_logger()

class DBRead:
    """
    Reads news from MongoDB
    """
    def __init__(self):
        self.url = PRODUCTION_URL
        self.database = PRODUCTION_DATABASE
        self.collection = PRODUCTION_COLLECTION
        self.__client = None
        self.__error = 0

    def __connect(self):
        try:
            self.__client = pymongo.MongoClient(self.url)
            _ = self.__client.list_database_names()
        except Exception as conn_exception:
            self.__error = 1
            self.__client = None

    def __read(self):
        try:
            db = self.__client[self.database]
            coll = db[self.collection]
            docs = []
            for doc in coll.find():
                docs.append(doc)
            rss_df = pd.DataFrame(docs)
        except Exception as insert_err:
            self.__error = 1
            rss_df = pd.DataFrame()
        return rss_df

    def __close_connection(self):
        if self.__client is not None:
            self.__client.close()
            self.__client = None

    def read_news_from_db(self):
        logger.warning('Entering read_news_from_db() to read old news')
        rss_df = pd.DataFrame()
        if self.url is not None:
            if self.__error == 0:
                self.__connect()
            if self.__error == 0:
                rss_df = self.__read()
            if self.__error == 0:
                logger.warning(f"Read Successful. Read {len(rss_df)} documents.")
            if self.__client is not None:
                self.__close_connection()
        logger.warning(f'Exiting read_news_from_db()')
        if len(rss_df) == 0:
            rss_df = None
        return rss_df