Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ido/macosx-bash-92-shellshock-patched

Apple Mac OS X bash-92 updated to 3.2.54 (shellshock patched)
https://github.com/ido/macosx-bash-92-shellshock-patched

Last synced: about 2 months ago
JSON representation

Apple Mac OS X bash-92 updated to 3.2.54 (shellshock patched)

Awesome Lists containing this project

README

        

**This repository is deprecated since Apple released an official hotfix**, referred to as the [OS X bash Update 1.0](http://support.apple.com/kb/DL1769), which updates bash to 3.2.53 (although not 3.2.54, a.k.a. Florian's patch). That update does seem to apply portions of Florian's patch. The [updated bash-92.1.2 code](http://opensource.apple.com/tarballs/bash/bash-92.1.2.tar.gz) is also available from Apple, and I've created a branch containing that source code

**Apparently 3.2.54 is not enough...3.2 is up to 3.2.57 now, so it's possible that additional patches are required and the Apple hotfix mentioned above may provide incomplete protection.** I do not have time to update this repository at the moment, so pull requests are welcome for 3.2.55-57 patches.

Shellshock hotfix for Mac OS X 10.9 Mavericks
=============================================

This is the Apple Mac OS X 10.9 Mavericks bash-92 with 3.2.52, 3.2.53, and 3.2.54 patches applied (shellshock patches).
This should work on most other versions of Mac OS X as well.

For more information about the original shellshock vulnerability, see [CVE-2014-6271](http://web.nvd.nist.gov/view/vuln/detail?vulnId=CVE-2014-6271) and the follow-up vulnerability described in [CVE-2014-7169](http://web.nvd.nist.gov/view/vuln/detail?vulnId=CVE-2014-7169) and [CVE-2014-6277](http://web.nvd.nist.gov/view/vuln/detail?vulnId=CVE-2014-6277) (also [here](http://lcamtuf.blogspot.com/2014/09/bash-bug-apply-unofficial-patch-now.html)).

For completeness, there is additional information about the vulnerability in [US-CERT Alert TA14-268A](https://www.us-cert.gov/ncas/alerts/TA14-268A) and [CERT Vulnerability Note VU#252743](http://www.kb.cert.org/vuls/id/252743).

There were two proposed patches to CVE-2014-7169: [Chet Ramey's patch](http://www.openwall.com/lists/oss-security/2014/09/25/10) and [Florian Weimer's patch](http://www.openwall.com/lists/oss-security/2014/09/25/13). Chet Ramey released bash 3.2.53 in a mailing list post [here](http://seclists.org/oss-sec/2014/q3/734), which was applied to this repository. [Florian Weimer's patch](http://www.openwall.com/lists/oss-security/2014/09/25/13) which addresses [CVE-2014-6277](http://lcamtuf.blogspot.com/2014/09/bash-bug-apply-unofficial-patch-now.html) as well was modified and released as the bash 3.2.54 patch, and is applied to this repository.

Disclaimer
----------

```
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
```

Usage
-----

You have four options, in descending order of how much you trust me (and increasing order of work):

* Option 1: Use the PGP signed binaries in the latest GitHub release of this repository.
* Option 2: Build the binaries from the patched source provided in this repository.
* Option 3: Reproduce the work I have done in this repository from upstream sources.
* Option 4: Wait for Apple to release an official software update.

Option 1: Use the installer package or my PGP-signed binaries.
--------------------------------------------------------------

Do you trust me not to root your box? If so, you can just grab and double-click the `macosx-bash-92-shellshock-patched.pkg` file from the [releases](https://github.com/ido/macosx-bash-92-shellshock-patched/releases/) section of this repository, or if you prefer not to use the installer package:

1. Go to https://github.com/ido/macosx-bash-92-shellshock-patched/releases/
2. Once there, download the binaries (`bash` and `sh`) and the PGP signatures (`bash.asc` and `sh.asc`) in the release.
3. Verify the PGP signatures with `gpg --verify bash.asc` and `gpg --verify sh.asc`
4. Move the binaries into place with `sudo mv bash sh /bin/`
5. Set their permissions with `sudo chown root: /bin/{bash,sh}` and `sudo chmod 555 /bin/{bash,sh}`
6. Verify that it worked with `bash --version`. You should see the following output:
```
GNU bash, version 3.2.54(1)-release (x86_64-apple-darwin13)
```

(Note: the `package.sh` file was used to generate the installer `pkg`.)

Option 2: Build the patched binaries from this repository.
----------------------------------------------------------

You'll need Xcode for this.

```
git clone https://github.com/ido/macosx-bash-92-shellshock-patched bash-92
cd bash-92
xcodebuild
sudo mv build/Release/{bash,sh} /bin/
sudo chown root: /bin/{bash,sh}
sudo chmod 555 /bin/{bash,sh}
bash --version
```
You should see the following output:
```
GNU bash, version 3.2.54(1)-release (x86_64-apple-darwin13)
```

Option 3: Don't trust me, trust upstream instead.
=================================================

Steps to reproduce my work from upstream...

You'll need Xcode for this.

If you want to do it yourself/not from this Git repository, you could wait for Apple to release a software update, or:

1. Download the Mac OS X bash source from Apple here:

http://opensource.apple.com/tarballs/bash/bash-92.1.2.tar.gz

2. Then, download the patches from here:

http://ftp.gnu.org/gnu/bash/bash-3.2-patches/bash32-054

3. Then, verify the PGP signature with these files:

http://ftp.gnu.org/gnu/bash/bash-3.2-patches/bash32-054.sig

4. Then, apply the patch to the bash-3.2 folder in the tarball:

```
tar xvzf bash-92.tar.gz
cd bash-92/bash-3.2
patch -p0 < ../../bash32-054
cd ../..
```

5. Then, build it as above with xcodebuild from the bash-92 folder.

```
cd bash-92
xcodebuild
```

7. Finally, move it into place:

```
sudo mv build/Release/{bash,sh} /bin/
sudo chown root: /bin/{bash,sh}
sudo chmod 555 /bin/{bash,sh}
```

Option 4: Wait for Apple to release an official software update.
----------------------------------------------------------------

You should apply Apple's software updates when they're released regardless of whether you apply this fix.

Contribute
----------

Please feel free to submit pull requests.