aboutsummaryrefslogtreecommitdiffstats
path: root/app/discover/fetchers/db/db_fetch_port.py
blob: 2cb814a430a180d237c303f0c845dc0fb1fc7ceb (plain)
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
###############################################################################
# Copyright (c) 2017 Koren Lev (Cisco Systems), Yaron Yogev (Cisco Systems)   #
# and others                                                                  #
#                                                                             #
# All rights reserved. This program and the accompanying materials            #
# are made available under the terms of the Apache License, Version 2.0       #
# which accompanies this distribution, and is available at                    #
# http://www.apache.org/licenses/LICENSE-2.0                                  #
###############################################################################
from discover.fetchers.db.db_access import DbAccess
from utils.inventory_mgr import InventoryMgr


class DbFetchPort(DbAccess):
    def __init__(self):
        super().__init__()
        self.inv = InventoryMgr()
        self.env_config = self.config.get_env_config()

    def get(self, id=None):
        query = """SELECT * FROM {}.ports where network_id = %s""" \
            .format(self.neutron_db)
        return self.get_objects_list_for_id(query, "port", id)

    def get_id(self, id=None):
        query = """SELECT id FROM {}.ports where network_id = %s""" \
            .format(self.neutron_db)
        result = self.get_objects_list_for_id(query, "port", id)
        return result[0]['id'] if result != [] else None

    def get_id_by_field(self, id, search=''):
        query = """SELECT id FROM neutron.ports where network_id = %s AND """ + search
        result = self.get_objects_list_for_id(query, "port", id)
        return result[0]['id'] if result != [] else None