-
Notifications
You must be signed in to change notification settings - Fork 693
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
Backport rubyzip fix to 2.0.2 #536
Comments
Oh please do this, there's a ton of other problems with the 1.0.0 version of rubyzip. |
We've been using 7cf7476 for a long time. For now, this is your best (= least bad) bet: gem 'axlsx', git: 'https://github.com/randym/axlsx.git',
ref: '7cf747675097be13df633f1b2a5c45391df52b33' # 2.0.1 + updated version of rubyzip |
Ah, what a pity: I looked more carefully, rubyzip/rubyzip#315 is only included in v1.2.1 of Rubyzip. And the referred-to commit still pins rubyzip to Note to all people reading this maintaining/developing rubygems: Don't peg a dependency like that. It means your consumers cannot ever upgrade to version 1.2, 1.3, 1.4 etc of (If everyone would just read the Semantic Versioning specification and try to follow it, the above would be more-or-less foolproof. Reality is however that sometimes expected-to-be-compatible versions are not so compatible. Still, I believe the approach I suggest here is the "lesser evil", and the Rubygems do explicitly encourage people to stick to Semantic Versioning: http://guides.rubygems.org/patterns/#semantic-versioning) More details on Rubygems version pinning: http://guides.rubygems.org/patterns/#declaring-dependencies |
@randym bump! |
@sandstrom That's pretty great. It serves my purposes as well and have replaced AXLSX with it. Thanks for the pointer! |
@sandstrom We meet again, hope you're doing great with Skovik. 😉 Thanks for the suggestion. Unfortunately, it's not that easy for us since we have a whole ecosystem of our own (not just an app or two). So just removing a dependency and replacing it with another is not always trivial. So for us, the safe (and boring!) approach is to peg towards the known-good commit of this repo. The rest of you can surely go ahead and use a better gem. Newer versions of our ecosystem do not depend on the |
You can also update your Gemfile this way:
Thanks to @michaelglass from @NoRedInk |
release-3.0.0 branch will be the next alfa release. |
@randym After 13 months, every stable release of I provided such a backport above. You can review and release it thusly: git remote add mdavidn [email protected]:mdavidn/axlsx.git
git fetch mdavidn release-2.0
## Review and test
git checkout -B release-2.0 mdavidn/release-2.0
# I believe 46a17e4 was the basis for v2.0.1.
git log -p 46a17e4b3fe0531ac6b2e48f818a982a86f538e4..HEAD
rake test
## Release
rake release
git tag v2.0.2
git push -u origin v2.0.2 release-2.0 Alternatively, I will open a PR against a git tag v2.0.1 46a17e4b3fe0531ac6b2e48f818a982a86f538e4
git branch -f release-2.0 v2.0.1
git push -u origin v2.0.1 release-2.0 |
release-3.0.0 (pre-released on rubygems
<https://rubygems.org/gems/axlsx/versions/>) is where we want to be.
…On Fri, Jul 6, 2018 at 9:21 AM Matthew Nelson ***@***.***> wrote:
@randym <https://github.com/randym> After 13 months, every stable release
of axlsx remains vulnerable to CVE-2017-5946. While you test the next
major release, I urge you to backport the fix and release a stable 2.0.2.
I provided such a backport above. You can very review and release it
thusly:
git remote add mdavidn ***@***.***:mdavidn/axlsx.git
git fetch mdavidn release-2.0
## Review and test
git checkout -B release-2.0 mdavidn/release-2.0
git log -p 46a17e4..HEAD # I believe 46a17e4 was the basis for v2.0.1
rake test
## Release
rake release
git tag v2.0.2
git push -u origin v2.0.2 release-2.0
Alternatively, I'm happy to open a PR against a release-2.0 branch if you
create one.
git tag v2.0.1 46a17e4
git branch release-2.0 v2.0.1
git push -u origin v2.0.1 release-2.0
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#536 (comment)>, or mute
the thread
<https://github.com/notifications/unsubscribe-auth/AA1JnLAIYEeQdGkJCvbUNVV-g1_VuhHeks5uDq1ugaJpZM4N32tw>
.
|
Sure, thanks for that. We all appreciate it as the long-term fix. Does this mean there will be no backport of the fix like the one @mdavidn provided? Not all users might be happy to jump on a new major version to get a security bug fix. If time does not permit you to work on |
I’m too totally in favor of getting out a 2.0.2 release containing the RubyZip fix (only). It can be done quickly (I’ll volunteer in preparing the releasing, if necessary), it won’t cause any harm at all, and it will help a lot of folks using this great gem. |
@randym Nudge on this issue. After 19 months, we're still waiting for a (non-prerelease) release that fixes a remote code execution vulnerability. I'm happy to help with maintenance if you're short on time. |
@mdavidn Looks like maintaining version 2 isn't a priority. What advantage do you get from the mainline gem if it's not actively maintained? I'd suggest you fork and release a new gem if you want, or just use the one we host (see comment above). |
I have been using a fork, but I would prefer not to. |
We couldn't upgrade to 2.1 or 3.0 due to breaking changes, so I created a fork of 2.0.1 with Rubyzip 1.2 support. Maybe somebody finds it useful: gem "axlsx", "~> 2.0.1", git: "https://github.com/semaperepelitsa/axlsx", branch: "2.0-rubyzip" Diff: semaperepelitsa/axlsx@v2.0.1...semaperepelitsa:2.0-rubyzip |
2.0.2 version released for new Community Axlsx (https://github.com/caxlsx/caxlsx) |
spreadsheet_architect already pulls-in a newer version of axlsx that does not have the security vulnerability[1] in it. Ideally we should keep an eye on the imminent release[2] of spreadsheet_architect that moves away from axlsx in favour of the community-maintained caxlsx[3]. [1]: randym/axlsx#536 [2]: westonganger/spreadsheet_architect#28 (comment) [3]: westonganger/spreadsheet_architect@3a6f02d#diff-4ac32a78649ca5bdd8e0ba38b7006a1e
spreadsheet_architect will soon be released[1] with the axlsx dependency removed, in favour of the community-maintained caxlsx[2] that does not have the security vulnerability of the former[3]. Ideally we should keep an eye on that release and pin it down in our Gemfile but until then roll with the master branch as it seems to be working just fine. [1]: westonganger/spreadsheet_architect#28 (comment) [2]: westonganger/spreadsheet_architect@3a6f02d#diff-4ac32a78649ca5bdd8e0ba38b7006a1e [3]: randym/axlsx#536
I'm looking to add Axlsx to one of my projects without downgrading
rubyzip
to a vulnerable version. It's not clear to me why a critical fix for remote code execution is blocked by new functionality in #501. @randym, please backport therubyzip
constraint and release 2.0.2 to RubyGems.org.I'm happy to help. There's no tag for 2.0.1 (see #535), so I'm not certain which commit to use as base. Here's my best guess. I had to backport a commit from #304 to make tests pass. I definitely don't understand the full context around
rubyzip
updates, so let me know if I overlooked something.I'm happy to open a PR against a 2.x major-version branch if you'd create one.
The text was updated successfully, but these errors were encountered: