###############################################################################
# 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 {}.ports where network_id = %s AND {}"""\
                .format(self.neutron_db, search)
        result = self.get_objects_list_for_id(query, "port", id)
        return result[0]['id'] if result != [] else None