-
Notifications
You must be signed in to change notification settings - Fork 20
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
How do we add more transport mechanisms? #52
Comments
I forgot to mention that if the maintainers think a custom Transport is a reasonable way forward, I'm happy to help and create a PR to get things rolling. |
I don't think there's a way for Drush to register a transport from a hook, but I don't quite recall. There's definitely nothing in this project to discover and register transports automatically e.g. from the autoloader.
This is essentially the purpose of a Transport. If you are envisioning a generic transport that is fully configurable from the fields in the alias record, that seems reasonable. It'd also be fine to submit individual transports for all of the systems mentioned above. |
Yeah, Drush just calls the static The Drush redispatch hook is just an ordinary annotated command init hook, so you could write a command file with a pre-init hook that added more transports, and that should work. The command file would have to be in a global location, or perhaps in SITE/drush/Commands. A module commandfile definitely would not work, though. |
A PR adding this approach to the README would be appreciated. |
|
A |
Awesome. Will put it on my TODO list. Will be able to take a look at this in February. |
Ah, I completely forgot about this and was occasionally reminded I need this. :) Thanks, @rudolfbyker for picking this up. I'll see if I can do it in the coming week as this is something I want as well. |
I looked into this and it was more challenging as I have lost the context I had then. @greg-1-anderson, can you share an example of working with the RedispatchHook. My search only turned up the documentation page (and the source) so I am not sure how to work with it. Besides, I am thinking of extending the
|
Working on kubectl transport now. It's working already :) See draft PR #60
|
@hussainweb It sounds reasonable to add an attribute to the SshTransport class to specify a wrapper command to use in place of ssh @rudolfbyker You could put "Unreleased" instead of a version number if you update the CHANGELOG. Changelog updates are appreciated, but I don't think anyone has done it before. Specific questions about your PR should be addressed on the PR itself. |
Done. This is quite urgent for our workflow. Is there anything else I can do to help? |
I have submitted a similar PR #61 for wrapping drush with any command. Since this is my first PR, it needs the maintainer's approval to run. |
@greg-1-anderson will you please take a look at my PR #60 and let the workflow run so we can see if the tests pass? |
FWIW, I got the tests to pass. I'm looking forward to the review now. |
This is a support request.
I know a transport manager was added in #20 but I can't figure out a way to add more transports at runtime (per site). I was looking for something I could add with configuration on a per-site basis or by including a package in composer.json or by some other such mechanism. Something like "contrib modules".
I'm trying to add different ways to invoke drush in containers which are not docker-compose (or some other wrapper). For example, I want to add a site alias that runs drush in an OpenShift cluster for a specific project.
If adding a
Transport
in this project is the only way, how about adding a custom Transport that lets you wrap drush calls to a different command. So,drush @stage status
could becomeoc rsh ... drush status
. This would be very similar to the existing Docker Transport but would work for various wrappers such asoc
,kubectl
, or evenddev
andlando
.I know there's a
drush-alias
setting but last I checked, there was a limitation that it only runs on aremote-host
. That wouldn't make sense in these cases.The text was updated successfully, but these errors were encountered: