-
Notifications
You must be signed in to change notification settings - Fork 47
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Ros2 service crystal #71
Conversation
Generate an sros2 yaml permissions file with the permissions of every visible node on the dds network. Add custom service security to sros2 Example: run the minimal_publisher_lambda node Execute: `ros2 security generate_permissions node_policies.yaml` It will create the following file in the current directory: ``` /minimal_publisher: services: /minimal_publisher/describe_parameters: allows: - request - reply . . . topics: /parameter_events: allows: - publish - subscribe /topic: allows: - publish ``` cr https://code.amazon.com/reviews/CR-3943967
Issue: services and actions are not considered in the policy yaml definition. Solution: Add ipc types (services and actions) Issue: access values are strings with p, s, or ps in order. This is not descriptive and difficult to scale should more permissions become necessary. Solution: Either change the parsing of the string or change the yaml to be more flexible and descriptive for users. The proposed changes include: * Access value is a list, not a string * Add ipc types such as actions and services * Access values are no longer shorthand p or s, but publish/subscribe Amend policy definition with verbose ROS ipc types
Add security macro for automagically generating public and private keys for authentication and encryption. custom macro use `ros2_secure_node(NODES node_name_1 node_name_2 ...)` cr https://code.amazon.com/reviews/CR-3517594
@ross-desmond I think that we need to get the underlying pull requests in for the node graph API before we can considering getting this merged in to sros2. Did you make any progress on the other implementations outlined in this comment? ros2/rcl#333 (comment) |
They are on the way and will be available at the latest friday. Ill ensure
all our pr's are at the top of master. Would it be best to ping out at that
time?
…On Wed, Nov 28, 2018, 10:56 AM Michael Carroll ***@***.*** wrote:
@ross-desmond <https://github.com/ross-desmond> I think that we need to
get the underlying pull requests in for the node graph API before we can
considering getting this merged in to sros2. Did you make any progress on
the other implementations outlined in this comment? ros2/rcl#333 (comment)
<ros2/rcl#333 (comment)>
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#71 (comment)>, or mute
the thread
<https://github.com/notifications/unsubscribe-auth/AqOeTBztDphCBiM1xsOjkcm270ciDdFoks5uztxcgaJpZM4Y3HnL>
.
|
Yes please!
On Wed, Nov 28, 2018 at 1:14 PM Ross Desmond <notifications@github.com>
wrote:
… They are on the way and will be available at the latest friday. Ill ensure
all our pr's are at the top of master. Would it be best to ping out at that
time?
On Wed, Nov 28, 2018, 10:56 AM Michael Carroll ***@***.***
wrote:
> @ross-desmond <https://github.com/ross-desmond> I think that we need to
> get the underlying pull requests in for the node graph API before we can
> considering getting this merged in to sros2. Did you make any progress on
> the other implementations outlined in this comment? ros2/rcl#333
(comment)
> <ros2/rcl#333 (comment)>
>
> —
> You are receiving this because you were mentioned.
> Reply to this email directly, view it on GitHub
> <#71 (comment)>, or mute
> the thread
> <
https://github.com/notifications/unsubscribe-auth/AqOeTBztDphCBiM1xsOjkcm270ciDdFoks5uztxcgaJpZM4Y3HnL
>
> .
>
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub
<#71 (comment)>, or mute
the thread
<https://github.com/notifications/unsubscribe-auth/AARElVP0C8w5iDnlm8MG6TeZYouA3zllks5uzuCogaJpZM4Y3HnL>
.
|
@ruffsl I'm just now getting up to speed on sros2 stuff after transitioning it from Mikael, would you mind putting a second set of eyes on this for me? |
General comment: In the future, is anyone opposed to using jinja for templates? |
As opposed to? Or for which task? |
sros2 has all the xml code in the api.py, it would be nice to have template files that python inserts the correct data to. This is just a though, it will not change this PR |
I won't go too far down this road here, but my concerns would be whether a) jinja is supported on macOS, Windows, and Linux, and b) adding in yet another templating system. We already have empy (which is non-specific to XML), and I find templating systems difficult to master. Adding more of them doesn't seem like a recipe for maintainable code down the road. |
That would be fine with me. We do already have a dependency on |
+1 for not adding yet another PL specific templating library. I'd suggest we formalize the permission transform to be agnostic of any programming implementation, to be more formally typed, and transparent to promote standardization of how ROS2 permissions are generated for DDS, or any other transport implementation in the future for that matter. I've created a branch that gives an example using program language agnostic transform for converting ROS2 permission profile markup into transport specific permission XML file. Users could then ecopertate the eXtensible Stylesheet into their own tools to consistently translate the permissions as a known finite transformation. I just spent an hour or so on it, but its relatively simple to support, and I can extend it into this PR if there is interest. See #72 for current diff. |
Is this planned for a merge at some point? Is there any help I can provide? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@ross-desmond Since this doesn't appear to break any existing API, it is okay for this to be merged and released post Crystal launch (which is why it hasn't received much attention yet). I've left a preliminary review, but since I'm not up-to-speed with sros2
, it would be better to get more eyes on.
# we have some policies to add ! | ||
for topic_name, policy in topic_dict.items(): | ||
tags = [] | ||
if policy['allow'] == 'ps': |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this change necessary? I think it would be better not include it to help keep the PR succinct.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It would help keep the PR succinct, but then there would be different ways of describing the security for services(-request, -response) vs topics (ps). It makes the parsing and description of the elements more verbose and robust.
Thank you for the review @jacobperron. Just a reminder the security_helpers folder in sros2 may want to be split out to another package as it does not build under the current sros2 package structure. If we believe this helper macro should stay in sros2 then I'll need to restructure to build sros2 python modules and the helper macro, thoughts? |
IMO, the cmake package can remain in this repo (but remain a separate package) as it matches the repo description. However, I would consider remaining the package to something like
I'd like to get some other thoughts on this proposal. If we go this approach, I think it would be better if the cmake package is added in a separate PR as it is distinct from the CLI changes and is a larger change. |
* Adds check to allow "/" or no "/" in permissions file * Renames policy definition file to markdown
513f0b3
to
81189cf
Compare
Fixing flake8 errors, incoming |
I'm in for this, I'll remove it from this package, @ruffsl how does that sound? |
I'd be fine with that restructuring. I'd still like to recommend the use of stylesheets to compile the xml permissions, rather than a yaml implementation specific approach. I'd welcome feedback on #72 , and could rebase if the repo is restructured as above. |
Awesome, I'm happy to move to XML as well. In the meantime, using generate_permissions with create_permission will have the same result as with json and xml. Let's get the xml in for the next patch release? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Added generate_permissions file based on node graph api. Enables security of services through sros policy yaml and definition file of how the policy yaml is constructed.
ros2_security_helper enables cmake macro to generate security files through colcon build for development and deployment. Note, this does not get built due to the structure of sros 2. OSRF please let me know where this macro should live to enable security by default when developing on ROS2
e.g:
find_package(ros2_security_helper REQUIRED)
ros2_secure_node(NODES minimal_publisher minimal_subscriber minimal_service)