本文整理匯總了Python中networkapi.plugins.factory.PluginFactory.factory方法的典型用法代碼示例。如果您正苦於以下問題:Python PluginFactory.factory方法的具體用法?Python PluginFactory.factory怎麽用?Python PluginFactory.factory使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類networkapi.plugins.factory.PluginFactory
的用法示例。
在下文中一共展示了PluginFactory.factory方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: _remove_svi
# 需要導入模塊: from networkapi.plugins.factory import PluginFactory [as 別名]
# 或者: from networkapi.plugins.factory.PluginFactory import factory [as 別名]
def _remove_svi(equipment, vlan_num):
equip_plugin = PluginFactory.factory(equipment)
equip_plugin.connect()
output = equip_plugin.remove_svi(vlan_num)
equip_plugin.close()
return output
示例2: _applyconfig
# 需要導入模塊: from networkapi.plugins.factory import PluginFactory [as 別名]
# 或者: from networkapi.plugins.factory.PluginFactory import factory [as 別名]
def _applyconfig(equipment, filename, equipment_access=None, source_server=None, port=22):
"""Apply configuration file on equipment
Args:
equipment: networkapi.equipamento.Equipamento()
filename: relative file path from TFTPBOOT_FILES_PATH to apply in equipment
equipment_access: networkapi.equipamento.EquipamentoAcesso() to use
source_server: source TFTP server address
port: ssh tcp port
Returns:
equipment output
Raises:
"""
if equipment.maintenance is True:
return 'Equipment is in maintenance mode. No action taken.'
if source_server is None:
source_server = TFTP_SERVER_ADDR
# TODO: Handle exceptions from the following methods and generate response
# for the caller
equip_plugin = PluginFactory.factory(equipment)
equip_plugin.connect()
equip_plugin.ensure_privilege_level()
equip_output = equip_plugin.copyScriptFileToConfig(filename)
equip_plugin.close()
return equip_output
示例3: undeploy_neighbor_v6
# 需要導入模塊: from networkapi.plugins.factory import PluginFactory [as 別名]
# 或者: from networkapi.plugins.factory.PluginFactory import factory [as 別名]
def undeploy_neighbor_v6(neighbor_id):
neighbor = NeighborV6.objects.get(id=neighbor_id)
if not neighbor.created:
raise exceptions.NeighborV6IsUndeployed(neighbor)
locks_list = lock_resources_used_by_neighbor_v6(neighbor)
try:
get_created_neighbors_v4_shares_same_eqpt_and_peer(neighbor)
get_created_neighbors_v6_shares_same_eqpt_and_peer(neighbor)
eqpt = get_v6_equipment(neighbor)
plugin = PluginFactory.factory(eqpt)
plugin.bgp().undeploy_neighbor(neighbor)
neighbor.deploy()
except Exception as e:
raise api_rest_exceptions.NetworkAPIException(str(e))
finally:
destroy_lock(locks_list)
示例4: deploy_neighbor_v4
# 需要導入模塊: from networkapi.plugins.factory import PluginFactory [as 別名]
# 或者: from networkapi.plugins.factory.PluginFactory import factory [as 別名]
def deploy_neighbor_v4(neighbor_id):
neighbor = NeighborV4.objects.get(id=neighbor_id)
if neighbor.created:
raise NeighborV4IsDeployed(neighbor)
locks_list = lock_resources_used_by_neighbor_v4(neighbor)
try:
depl_v4 = get_created_neighbors_v4_shares_same_eqpt_and_peer(neighbor)
depl_v6 = get_created_neighbors_v6_shares_same_eqpt_and_peer(neighbor)
eqpt = get_v4_equipment(neighbor)
plugin = PluginFactory.factory(eqpt)
plugin.bgp().deploy_neighbor(neighbor)
neighbor.deploy()
except Exception as e:
raise NetworkAPIException(str(e))
finally:
destroy_lock(locks_list)
示例5: __applyConfig
# 需要導入模塊: from networkapi.plugins.factory import PluginFactory [as 別名]
# 或者: from networkapi.plugins.factory.PluginFactory import factory [as 別名]
def __applyConfig(equipment,filename, equipment_access=None,source_server=None,port=22):
'''Apply configuration file on equipment
Args:
equipment: networkapi.equipamento.Equipamento()
filename: relative file path from TFTPBOOT_FILES_PATH to apply in equipment
equipment_access: networkapi.equipamento.EquipamentoAcesso() to use
source_server: source TFTP server address
port: ssh tcp port
Returns:
equipment output
Raises:
'''
if equipment.maintenance == True:
return "Equipment is in maintenance mode. No action taken."
if source_server == None:
source_server = TFTP_SERVER_ADDR
equip_plugin = PluginFactory.factory(equipment)
equip_plugin.connect()
equip_plugin.ensure_privilege_level()
equip_output = equip_plugin.copyScriptFileToConfig(filename)
equip_plugin.close()
return equip_output
示例6: test_factory_bgp_undeploy_neighbor
# 需要導入模塊: from networkapi.plugins.factory import PluginFactory [as 別名]
# 或者: from networkapi.plugins.factory.PluginFactory import factory [as 別名]
def test_factory_bgp_undeploy_neighbor(self):
equipment = self._mock_equipment()
plugin = PluginFactory.factory(equipment)
neighbor = {}
self.assertEqual(hasattr(plugin.bgp(neighbor), 'undeploy_neighbor'),
True)
示例7: test_factory_bgp_deploy_prefix_list
# 需要導入模塊: from networkapi.plugins.factory import PluginFactory [as 別名]
# 或者: from networkapi.plugins.factory.PluginFactory import factory [as 別名]
def test_factory_bgp_deploy_prefix_list(self):
equipment = self._mock_equipment()
plugin = PluginFactory.factory(equipment)
neighbor = {}
self.assertEqual(
hasattr(plugin.bgp(neighbor), 'deploy_prefix_list'), True)
示例8: remove_svi
# 需要導入模塊: from networkapi.plugins.factory import PluginFactory [as 別名]
# 或者: from networkapi.plugins.factory.PluginFactory import factory [as 別名]
def remove_svi(equipment, vlan_num):
"""Call function "remove_svi" of Plugin for model of equipment."""
equip_plugin = PluginFactory.factory(equipment)
equip_plugin.connect()
output = equip_plugin.remove_svi(vlan_num)
equip_plugin.close()
return output
示例9: flush_flows
# 需要導入模塊: from networkapi.plugins.factory import PluginFactory [as 別名]
# 或者: from networkapi.plugins.factory.PluginFactory import factory [as 別名]
def flush_flows(env_id):
""" Flushes flow from a environment without restore it """
eqpts = get_controller_by_envid(env_id)
for eqpt in eqpts:
plugin = PluginFactory.factory(eqpt, env_id=env_id)
try:
plugin.flush_flows()
except Exception as e:
log.error(e)
raise NetworkAPIException('Failed to flush Controller '
'plugin. %s' % e)
示例10: _prepare_apply_state
# 需要導入模塊: from networkapi.plugins.factory import PluginFactory [as 別名]
# 或者: from networkapi.plugins.factory.PluginFactory import factory [as 別名]
def _prepare_apply_state(pools, user=None):
load_balance = dict()
keys = list()
for pool in pools:
server_pool = ServerPool.objects.get(id=pool['id'])
server_pool_members = server_pool.serverpoolmember_set.all()
if pool['server_pool_members']:
equips = _validate_pool_members_to_apply(pool, user)
keys.append(sorted([str(eqpt.id) for eqpt in equips]))
for e in equips:
eqpt_id = str(e.id)
equipment_access = EquipamentoAcesso.search(
equipamento=e.id
)
plugin = PluginFactory.factory(e)
if not load_balance.get(eqpt_id):
load_balance[eqpt_id] = {
'plugin': plugin,
'access': equipment_access,
'pools': [],
}
mbs = pool['server_pool_members']
idx_mbs = [mb['id'] for mb in mbs]
load_balance[eqpt_id]['pools'].append({
'id': server_pool.id,
'nome': server_pool.identifier,
'pools_members': [{
'id': pool_member.id,
'ip': pool_member.ip.ip_formated
if pool_member.ip else pool_member.ipv6.ip_formated,
'port': pool_member.port_real,
'member_status': mbs
[idx_mbs.index(pool_member.id)]['member_status']
} for pool_member in server_pool_members
if pool_member.id in idx_mbs]
})
# pools are in differents load balancers
keys = [','.join(key) for key in keys]
if len(list(set(keys))) > 1:
raise Exception('Pools are in differents load balancers')
return load_balance
示例11: setUp
# 需要導入模塊: from networkapi.plugins.factory import PluginFactory [as 別名]
# 或者: from networkapi.plugins.factory.PluginFactory import factory [as 別名]
def setUp(self):
# Must chose the equipment with the right version running on docker
# Beryllium
self.equipment = Equipamento.objects.filter(id=10).uniqueResult()
# Nitrogen
#self.equipment = Equipamento.objects.filter(id=11).uniqueResult()
self.equipment_access = EquipamentoAcesso.objects.filter(id=1).uniqueResult()
self.utils.set_controller_endpoint(self.equipment_access)
self.odl = PluginFactory.factory(self.equipment)
self.flow_key = "flow-node-inventory:flow"
示例12: insert_flow
# 需要導入模塊: from networkapi.plugins.factory import PluginFactory [as 別名]
# 或者: from networkapi.plugins.factory.PluginFactory import factory [as 別名]
def insert_flow(env_id, data, user_id):
eqpts = get_controller_by_envid(env_id)
plugins = []
for eqpt in eqpts:
plugins.append(PluginFactory.factory(eqpt, env_id=env_id))
try:
return async_add_flow.apply_async(
args=[plugins, user_id, data], queue='napi.odl_flow'
)
except Exception as e:
log.error(e)
raise NetworkAPIException('Failed to insert flow(s) '
'plugin. %s' % e)
示例13: update_flows
# 需要導入模塊: from networkapi.plugins.factory import PluginFactory [as 別名]
# 或者: from networkapi.plugins.factory.PluginFactory import factory [as 別名]
def update_flows(env_id, data, user_id):
""" Call equipment plugin to asynchronously flush the environment """
eqpts = get_controller_by_envid(env_id)
plugins = []
for eqpt in eqpts:
plugins.append(PluginFactory.factory(eqpt, env_id=env_id))
try:
return async_flush_environment.apply_async(
args=[plugins, user_id, data], queue='napi.odl_flow'
)
except Exception as e:
log.error(e)
raise NetworkAPIException('Failed to flush flow(s) '
'from environment: %s \n%s' % (env_id, e))
示例14: delete_flow
# 需要導入模塊: from networkapi.plugins.factory import PluginFactory [as 別名]
# 或者: from networkapi.plugins.factory.PluginFactory import factory [as 別名]
def delete_flow(env_id, flow_id, user_id):
""" Deletes one flow by id using the async task """
eqpts = get_controller_by_envid(env_id)
plugins = []
for eqpt in eqpts:
plugins.append(PluginFactory.factory(eqpt, env_id=env_id))
try:
return async_delete_flow.apply_async(
args=[plugins, user_id, flow_id], queue='napi.odl_flow'
)
except Exception as err:
log.error(err)
raise NetworkAPIException('Failed to delete flow with error: %s' % err)
示例15: create_v3
# 需要導入模塊: from networkapi.plugins.factory import PluginFactory [as 別名]
# 或者: from networkapi.plugins.factory.PluginFactory import factory [as 別名]
def create_v3(self, vip_port_map):
# save port
facade_eqpt = get_app('api_equipment', 'facade')
self.vip_request = VipRequest.get_by_pk(
vip_port_map.get('vip_request'))
self.port = vip_port_map.get('port')
eqpts = facade_eqpt.get_eqpt_by_envvip(
self.vip_request.environmentvip.id)
if eqpts:
plugin = PluginFactory.factory(eqpts[0])
identifier = plugin.get_name_eqpt(
self.vip_request, vip_port_map['port'])
self.identifier = identifier
self.save()
# L4 Protocol
opt = VipRequestPortOptionVip()
opt_map = {
'vip_request_port': self.id,
'optionvip': vip_port_map['options']['l4_protocol']
}
opt.create_v3(opt_map)
# L7 Protocol
opt = VipRequestPortOptionVip()
opt_map = {
'vip_request_port': self.id,
'optionvip': vip_port_map['options']['l7_protocol']
}
opt.create_v3(opt_map)
# Pools
for pool in vip_port_map.get('pools'):
pool_map = {
'vip_request_port': self.id,
'server_pool': pool.get('server_pool'),
'optionvip': pool.get('l7_rule'),
'val_optionvip': pool.get('l7_value'),
'order': pool.get('order')
}
pl = VipRequestPortPool()
pl.create_v3(pool_map)