'openstack port list' should display ports only from current project
Affects | Status | Importance | Assigned to | Milestone | |
---|---|---|---|---|---|
neutron |
Opinion
|
Low
|
Unassigned |
Bug Description
When a network is shared between multiple projects, "openstack port list" command shows ports from all projects which have access to that network. This is a problem because each port actually has a “project_id“ property, and the port cannot be used for any instance outside of that project. When a user attempts to start an instance with a port from a different project, it fails like this: nova.exception.
Steps to reproduce in horizon :-
=======
1. create network and share network between 2 projects
2. from Project A, manually create a port “Test Port“ on the network
note that the port will have the project_id for Project A
3. from Project B, open the Launch Instance workflow navigate to
“Network Ports”
4. At this point, you will see “Test Port” in the list. If you use it
for the instance from Project B, the instance will fail
Currently, User can use --project-id="xxxx" as option to "openstack port list" command to get desired result. But this needs to be taken care at every neutron client e.g. nova or manila or openstackclient or horizon.
Instead, ff we modify neutron itself to return only ports belonging to current project in 'openstack port list' command response (without specifying --project-id) (at least for non-admin users), it would be good improvement.
Fix proposed to branch: master /review. opendev. org/c/openstack /neutron/ +/864303
Review: https:/