Remove unused files
Change-Id: I9edbd9a8d24129a36ee201ccb6afa44ae0e66532 Closes-Bug: #1468632 Closes-Bug: #1469350 Closes-Bug: #1469353
This commit is contained in:
@@ -1,16 +0,0 @@
|
|||||||
This directory contains files that are required for the XenAPI support.
|
|
||||||
They should be installed in the XenServer / Xen Cloud Platform dom0.
|
|
||||||
|
|
||||||
If you install them manually, you will need to ensure that the newly
|
|
||||||
added files are executable. You can do this by running the following
|
|
||||||
command (from dom0):
|
|
||||||
|
|
||||||
chmod a+x /etc/xapi.d/plugins/*
|
|
||||||
|
|
||||||
Otherwise, you can build an rpm by running the following command:
|
|
||||||
|
|
||||||
./contrib/build-rpm.sh
|
|
||||||
|
|
||||||
and install the rpm by running the following command (from dom0):
|
|
||||||
|
|
||||||
rpm -i openstack-neutron-xen-plugins.rpm
|
|
||||||
@@ -1,34 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
set -eux
|
|
||||||
|
|
||||||
thisdir=$(dirname $(readlink -f "$0"))
|
|
||||||
export NEUTRON_ROOT="$thisdir/../../../../../../"
|
|
||||||
export PYTHONPATH=$NEUTRON_ROOT
|
|
||||||
|
|
||||||
cd $NEUTRON_ROOT
|
|
||||||
VERSION=$(sh -c "(cat $NEUTRON_ROOT/neutron/version.py; \
|
|
||||||
echo 'print version_info.release_string()') | \
|
|
||||||
python")
|
|
||||||
cd -
|
|
||||||
|
|
||||||
PACKAGE=openstack-neutron-xen-plugins
|
|
||||||
RPMBUILD_DIR=$PWD/rpmbuild
|
|
||||||
if [ ! -d $RPMBUILD_DIR ]; then
|
|
||||||
echo $RPMBUILD_DIR is missing
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
for dir in BUILD BUILDROOT SRPMS RPMS SOURCES; do
|
|
||||||
rm -rf $RPMBUILD_DIR/$dir
|
|
||||||
mkdir -p $RPMBUILD_DIR/$dir
|
|
||||||
done
|
|
||||||
|
|
||||||
rm -rf /tmp/$PACKAGE
|
|
||||||
mkdir /tmp/$PACKAGE
|
|
||||||
cp -r ../etc/xapi.d /tmp/$PACKAGE
|
|
||||||
tar czf $RPMBUILD_DIR/SOURCES/$PACKAGE.tar.gz -C /tmp $PACKAGE
|
|
||||||
|
|
||||||
rpmbuild -ba --nodeps --define "_topdir $RPMBUILD_DIR" \
|
|
||||||
--define "version $VERSION" \
|
|
||||||
$RPMBUILD_DIR/SPECS/$PACKAGE.spec
|
|
||||||
@@ -1,30 +0,0 @@
|
|||||||
Name: openstack-neutron-xen-plugins
|
|
||||||
Version: %{version}
|
|
||||||
Release: 1
|
|
||||||
Summary: Files for XenAPI support.
|
|
||||||
License: ASL 2.0
|
|
||||||
Group: Applications/Utilities
|
|
||||||
Source0: openstack-neutron-xen-plugins.tar.gz
|
|
||||||
BuildArch: noarch
|
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
|
||||||
|
|
||||||
%define debug_package %{nil}
|
|
||||||
|
|
||||||
%description
|
|
||||||
This package contains files that are required for XenAPI support for Neutron.
|
|
||||||
|
|
||||||
%prep
|
|
||||||
%setup -q -n openstack-neutron-xen-plugins
|
|
||||||
|
|
||||||
%install
|
|
||||||
rm -rf $RPM_BUILD_ROOT
|
|
||||||
mkdir -p $RPM_BUILD_ROOT/etc
|
|
||||||
cp -r xapi.d $RPM_BUILD_ROOT/etc
|
|
||||||
chmod a+x $RPM_BUILD_ROOT/etc/xapi.d/plugins/*
|
|
||||||
|
|
||||||
%clean
|
|
||||||
rm -rf $RPM_BUILD_ROOT
|
|
||||||
|
|
||||||
%files
|
|
||||||
%defattr(-,root,root,-)
|
|
||||||
/etc/xapi.d/plugins/*
|
|
||||||
@@ -1,72 +0,0 @@
|
|||||||
#!/usr/bin/env python
|
|
||||||
|
|
||||||
# Copyright 2012 OpenStack Foundation
|
|
||||||
# Copyright 2012 United States Government as represented by the
|
|
||||||
# Administrator of the National Aeronautics and Space Administration.
|
|
||||||
# All Rights Reserved.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
||||||
# not use this file except in compliance with the License. You may obtain
|
|
||||||
# a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
||||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
||||||
# License for the specific language governing permissions and limitations
|
|
||||||
# under the License.
|
|
||||||
|
|
||||||
#
|
|
||||||
# XenAPI plugin for executing network commands (ovs, iptables, etc) on dom0
|
|
||||||
#
|
|
||||||
|
|
||||||
import gettext
|
|
||||||
gettext.install('neutron', unicode=1)
|
|
||||||
try:
|
|
||||||
import json
|
|
||||||
except ImportError:
|
|
||||||
import simplejson as json
|
|
||||||
import subprocess
|
|
||||||
|
|
||||||
import XenAPIPlugin
|
|
||||||
|
|
||||||
|
|
||||||
ALLOWED_CMDS = [
|
|
||||||
'ip',
|
|
||||||
'ovs-ofctl',
|
|
||||||
'ovs-vsctl',
|
|
||||||
]
|
|
||||||
|
|
||||||
|
|
||||||
class PluginError(Exception):
|
|
||||||
"""Base Exception class for all plugin errors."""
|
|
||||||
def __init__(self, *args):
|
|
||||||
Exception.__init__(self, *args)
|
|
||||||
|
|
||||||
def _run_command(cmd, cmd_input):
|
|
||||||
"""Abstracts out the basics of issuing system commands. If the command
|
|
||||||
returns anything in stderr, a PluginError is raised with that information.
|
|
||||||
Otherwise, the output from stdout is returned.
|
|
||||||
"""
|
|
||||||
pipe = subprocess.PIPE
|
|
||||||
proc = subprocess.Popen(cmd, shell=False, stdin=pipe, stdout=pipe,
|
|
||||||
stderr=pipe, close_fds=True)
|
|
||||||
(out, err) = proc.communicate(cmd_input)
|
|
||||||
|
|
||||||
if err:
|
|
||||||
raise PluginError(err)
|
|
||||||
return out
|
|
||||||
|
|
||||||
|
|
||||||
def run_command(session, args):
|
|
||||||
cmd = json.loads(args.get('cmd'))
|
|
||||||
if cmd and cmd[0] not in ALLOWED_CMDS:
|
|
||||||
msg = _("Dom0 execution of '%s' is not permitted") % cmd[0]
|
|
||||||
raise PluginError(msg)
|
|
||||||
result = _run_command(cmd, json.loads(args.get('cmd_input', 'null')))
|
|
||||||
return json.dumps(result)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
|
||||||
XenAPIPlugin.dispatch({"run_command": run_command})
|
|
||||||
@@ -1,107 +0,0 @@
|
|||||||
# Copyright 2011 VMware, Inc.
|
|
||||||
# All Rights Reserved.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
||||||
# not use this file except in compliance with the License. You may obtain
|
|
||||||
# a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
||||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
||||||
# License for the specific language governing permissions and limitations
|
|
||||||
# under the License.
|
|
||||||
|
|
||||||
|
|
||||||
from sqlalchemy import Boolean, Column, ForeignKey, Integer, String
|
|
||||||
from sqlalchemy.schema import UniqueConstraint
|
|
||||||
|
|
||||||
from neutron.db import model_base
|
|
||||||
from neutron.db import models_v2
|
|
||||||
from sqlalchemy import orm
|
|
||||||
|
|
||||||
|
|
||||||
class VlanAllocation(model_base.BASEV2):
|
|
||||||
"""Represents allocation state of vlan_id on physical network."""
|
|
||||||
__tablename__ = 'ovs_vlan_allocations'
|
|
||||||
|
|
||||||
physical_network = Column(String(64), nullable=False, primary_key=True)
|
|
||||||
vlan_id = Column(Integer, nullable=False, primary_key=True,
|
|
||||||
autoincrement=False)
|
|
||||||
allocated = Column(Boolean, nullable=False)
|
|
||||||
|
|
||||||
def __init__(self, physical_network, vlan_id):
|
|
||||||
self.physical_network = physical_network
|
|
||||||
self.vlan_id = vlan_id
|
|
||||||
self.allocated = False
|
|
||||||
|
|
||||||
def __repr__(self):
|
|
||||||
return "<VlanAllocation(%s,%d,%s)>" % (self.physical_network,
|
|
||||||
self.vlan_id, self.allocated)
|
|
||||||
|
|
||||||
|
|
||||||
class TunnelAllocation(model_base.BASEV2):
|
|
||||||
"""Represents allocation state of tunnel_id."""
|
|
||||||
__tablename__ = 'ovs_tunnel_allocations'
|
|
||||||
|
|
||||||
tunnel_id = Column(Integer, nullable=False, primary_key=True,
|
|
||||||
autoincrement=False)
|
|
||||||
allocated = Column(Boolean, nullable=False)
|
|
||||||
|
|
||||||
def __init__(self, tunnel_id):
|
|
||||||
self.tunnel_id = tunnel_id
|
|
||||||
self.allocated = False
|
|
||||||
|
|
||||||
def __repr__(self):
|
|
||||||
return "<TunnelAllocation(%d,%s)>" % (self.tunnel_id, self.allocated)
|
|
||||||
|
|
||||||
|
|
||||||
class NetworkBinding(model_base.BASEV2):
|
|
||||||
"""Represents binding of virtual network to physical realization."""
|
|
||||||
__tablename__ = 'ovs_network_bindings'
|
|
||||||
|
|
||||||
network_id = Column(String(36),
|
|
||||||
ForeignKey('networks.id', ondelete="CASCADE"),
|
|
||||||
primary_key=True)
|
|
||||||
# 'gre', 'vlan', 'flat', 'local'
|
|
||||||
network_type = Column(String(32), nullable=False)
|
|
||||||
physical_network = Column(String(64))
|
|
||||||
segmentation_id = Column(Integer) # tunnel_id or vlan_id
|
|
||||||
|
|
||||||
network = orm.relationship(
|
|
||||||
models_v2.Network,
|
|
||||||
backref=orm.backref("binding", lazy='joined',
|
|
||||||
uselist=False, cascade='delete'))
|
|
||||||
|
|
||||||
def __init__(self, network_id, network_type, physical_network,
|
|
||||||
segmentation_id):
|
|
||||||
self.network_id = network_id
|
|
||||||
self.network_type = network_type
|
|
||||||
self.physical_network = physical_network
|
|
||||||
self.segmentation_id = segmentation_id
|
|
||||||
|
|
||||||
def __repr__(self):
|
|
||||||
return "<NetworkBinding(%s,%s,%s,%d)>" % (self.network_id,
|
|
||||||
self.network_type,
|
|
||||||
self.physical_network,
|
|
||||||
self.segmentation_id)
|
|
||||||
|
|
||||||
|
|
||||||
class TunnelEndpoint(model_base.BASEV2):
|
|
||||||
"""Represents tunnel endpoint in RPC mode."""
|
|
||||||
__tablename__ = 'ovs_tunnel_endpoints'
|
|
||||||
__table_args__ = (
|
|
||||||
UniqueConstraint('id', name='uniq_ovs_tunnel_endpoints0id'),
|
|
||||||
model_base.BASEV2.__table_args__,
|
|
||||||
)
|
|
||||||
|
|
||||||
ip_address = Column(String(64), primary_key=True)
|
|
||||||
id = Column(Integer, nullable=False)
|
|
||||||
|
|
||||||
def __init__(self, ip_address, id):
|
|
||||||
self.ip_address = ip_address
|
|
||||||
self.id = id
|
|
||||||
|
|
||||||
def __repr__(self):
|
|
||||||
return "<TunnelEndpoint(%s,%s)>" % (self.ip_address, self.id)
|
|
||||||
Binary file not shown.
|
Before Width: | Height: | Size: 43 KiB |
Binary file not shown.
|
Before Width: | Height: | Size: 75 KiB |
Reference in New Issue
Block a user