-
Notifications
You must be signed in to change notification settings - Fork 528
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
Add ros2 action client capability #813
Conversation
@nakai-omer you are using actionclient in roslibjs which only works for ros1 as it simply subscribes to feedback and result and publish goal topics. for ROS 2 action client is not added yet . you can use the code in the folder ros2action on my fork https://github.com/sathak93/roslibjs/tree/ros2actionclient. once this PR is finalized and added to rosbridge_server . pr for client side implementation can be added. |
@sathak93 Got it thanks a lot! |
@sathak93 Your rosbridge_suite code and roslibjs code was a lifesaver! Looking forward to this being incorporated into the official releases. 🙌 |
Is this PR still active? It's been a while and seems like it'd be a good addition |
@ahoenerBE and @amalnanavati it is still in good condition i think. rosbridge doesn't have action capability in ros 2 only. Most of the current users of rosbridge are using ROS 1 i think thats why they doesn't know they miss out important feature in ros2 . This PR will increase code base. if it is okay with maintainers then we can review and merge
|
I need this capability as well. @defunctzombie Can we get another review of this? |
+1 -- we are looking to add ROS 2 Action Server support soon and would love for this PR to be in first as well. |
I appreciate and understand the desire to keep the codebase maintainable, as too many changes can create unneeded bloat, but I don't understand the pushback for supporting a core feature of ROS2. Sure, it's publishers and service calls under the hood, but that way of thinking requires each library in different languages to write some sort of adapter for ROS2 actions themselves. And for that matter, if actions are ever changed, then each of those projects will have to update their implementation to restore functionality, instead of the base rosbridge being updated and having the spec maintain functionality for all libraries that interact with it automatically. I think it makes much more sense to add something that can natively interact with the ROS2 action server, and provide the standard for other libraries to accept, rather than making each different library do their own thing |
I think it stems from this. In ROS 1 you could interact with actions using their underlying topics, but as far as I know that is not the case in ROS 2 and we do need to use the action interface. |
Yup, ROS2 implements actions using hidden services/topics, and the service/message types are not easily introspectable (relevant design doc). Both those factors prevented me from being able to interact with ROS2 actions using topic/service calls in roslibjs, which is why I think we need functionality on the rosbridge level directly. |
+1 to supporting ROS2 actions in rosbridge and getting this patch forward. Not being able to use actions in the front-end is currently a major blocker in our project, and as @amalnanavati pointed out, actions are not easily doable in ROS2 using topic/service calls. |
BTW I am going to work on action server functionality fairly soon (in the next few weeks), so it would be fantastic if this got merged in. I'm happy to also help write unit tests for this action client functionality as it's something we'll likely want at some point too. |
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.
Looks good, though I didn't test.
Would be great if you also got to work on some unit tests (I just ported all the pub/sub ones to ROS 2 in #882 if you want a reference)... but I'm also happy to help do this after this one is merged.
BTW I am only reviewing as an interested party, sadly I don't have merging power here.
rosbridge_library/src/rosbridge_library/capabilities/action_client.py
Outdated
Show resolved
Hide resolved
from rosbridge_library.internal.message_conversion import extract_values | ||
|
||
|
||
class ActionClientRequests(Capability): |
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.
This doesn't seem like it's named consistently as a "capability" compared to the others.
I think maybe this should be called SendActionGoal
or something?
@sea-bass 👋 Good seeing you at roscon. Since Foxglove doesn't leverage rosbridge anymore, our support of this package has waned. You mentioned that PickNik relies on rosbridge for some products so I am open to adding you as a maintainer in Github to let you all carry the torch forward. |
This would be great, thank you for the offer -- could we also add my colleague @EzraBrooks, who is also a contributor to this repo? |
@sea-bass @defunctzombie Is the recommended bridge node now the foxglove ws-protocol if support here is waning? I want to make sure our projects are using something that will be updated in the future |
I'd defer to Foxglove's answer, but from what I heard at ROSCon Foxglove uses a different protocol which means you can definitely use it on your end -- it is open-source -- but you'll need to modify/rewrite your own client libraries. At least for the foreseeable future, PickNik plans to continue using this protocol (just the ROS 2 branch though), and we're happy to help maintain. |
@sea-bass That's good to know. I'm maintaining rosreact, which is a react hooks wrapper around roslibJS and it'd be unfortunate to have to rewrite it all for a new comms protocol. I'm also open to helping support, if people are wanting to keep this package alive. |
@sea-bass @EzraBrooks I sent you both invites to this github org. As for the ROS-Foxglove Bridge, we designed it to avoid performance and other issues we were seeing with rosbridge. It's open source, but we don't recommend it for general purpose (i.e. non-Foxglove related) use. |
@sathak93 I didn't want to make you write a ton of unit tests, so wanted to share that I'm taking pieces from the great work you've done here and implementing them a little different + with tests + also adding action servers in #886 If you have any inputs please let me know. Also, my plan is to try do the Thank you! |
Public API Changes
3.3.10 Send Goal
This command creates an action client with the specified action name and type if not already created; sends the goal msg to the action server and returns the feedback and result of the goal.
provided, though an empty list is equally acceptable. goal msg should be a list of json objects representing the arguments to the action
3.3.11 Cancel Goal
This command cancels all the executing and pending goals of the specified action and return the result of cancel call.
3.3.12 Destroy Client
This command destroys the action client if the action client was created on earlier send_goal calls.
Description
This pr adds ros2 action client capability using the direct approach. now clients can create action clients, send goal to get result and feedback, cancel goal, destroy client.
this address #697