Skip to content
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

Adding cURL if no wget on the box #9

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

roguepullrequest
Copy link

Added the ability to use cURL if wget is not found on the box. Saw #5 and agree that that was a poor implementation but this allows for handling of either wget or cURL.

If the options for cURL aren't the ones that would give the desired output feel free to change them.

Added the ability to use cURL if wget is not found on the box. Saw NullArray#5 and agree that that was a poor implementation but this allows for handling of either wget or cURL. 

If the options for cURL aren't the ones that would give the desired output feel free to change them.
@NullArray
Copy link
Owner

NullArray commented Sep 7, 2021

Thank you for the PR @roguepullrequest , i am not opposed to including this functionality as a failsafe for when permissions on target don't allow the use of wget, however in order to get the script on target remotely git, wget, and/or cURL have to be available in the first place. Unless there is an underlying vulnerability on the box you are targeting such as an RCE that can be leveraged to download and execute RootHelper.

Perhaps in a scenario where you have a limited shell on target which forces you to echo RootHelper over it would stand to reason to first echo my SBD script over and execute that since it is designed to provide the user with access to static binaries and busybox which has both cURL and wget out of the box as it were.

What would also be a possibility is to encode a static wget binary, Base64 the results, include it in the main script and have a function write it out on target should it be determined we don't have access to or permissions to run wget. We would automate the decoding process and make the wget we brought along executable in order to use that to bypass any limitations imposed on the proper operation of RootHelper.

Implementing such a solution would be a matter of adding a conditional to check availability, and invoking a function to perform the operations i just mentioned. in my opinion that would be a more robust solution than simply hoping cURL will work if wget won't.

I would very much like to hear your thoughts on this, before i merge or request changes to the PR to the extent that we have a more robust failsafe mechanism.

@roguepullrequest
Copy link
Author

roguepullrequest commented May 19, 2022

This does make sense. If you want to have another fallback option it can be TCP sockets. Let me see what I can cobble together to handle all the scenarios.

@NullArray
Copy link
Owner

This does make sense. If you want to have another fallback option it can be TCP sockets. Let me see what I can cobble together to handle all the scenarios.

Any updates on any potential improvements you had in mind?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants