public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
From: "Robin H. Johnson" <robbat2@gentoo.org>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] repo/gentoo:master commit in: dev-ruby/httpclient/
Date: Thu, 14 Oct 2021 20:07:48 +0000 (UTC)	[thread overview]
Message-ID: <1634242065.95813829db1b5ed24e91076a36f43d9c34392c7d.robbat2@gentoo> (raw)

commit:     95813829db1b5ed24e91076a36f43d9c34392c7d
Author:     Robin H. Johnson <robbat2 <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 14 19:59:15 2021 +0000
Commit:     Robin H. Johnson <robbat2 <AT> gentoo <DOT> org>
CommitDate: Thu Oct 14 20:07:45 2021 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=95813829

dev-ruby/httpclient: revbump w/ to use system certificates

httpclient bundled really old CA certificates: 6-year & 11-year old, and
used them by default, which broke LetsEncrypt consumers. Replace the
bundles with symlink to the system copy, which is kept up to date.

Closes: https://bugs.gentoo.org/818025
Signed-off-by: Robin H. Johnson <robbat2 <AT> gentoo.org>

 dev-ruby/httpclient/httpclient-2.8.3-r1.ebuild | 78 ++++++++++++++++++++++++++
 1 file changed, 78 insertions(+)

diff --git a/dev-ruby/httpclient/httpclient-2.8.3-r1.ebuild b/dev-ruby/httpclient/httpclient-2.8.3-r1.ebuild
new file mode 100644
index 00000000000..36a0fd386fb
--- /dev/null
+++ b/dev-ruby/httpclient/httpclient-2.8.3-r1.ebuild
@@ -0,0 +1,78 @@
+# Copyright 1999-2021 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=5
+
+USE_RUBY="ruby26 ruby27 ruby30"
+
+RUBY_FAKEGEM_TASK_TEST="-Ilib test"
+RUBY_FAKEGEM_TASK_DOC="doc"
+
+RUBY_FAKEGEM_DOCDIR="doc"
+
+RUBY_FAKEGEM_EXTRADOC="CHANGELOG.md README.md"
+
+RUBY_FAKEGEM_GEMSPEC="httpclient.gemspec"
+
+inherit ruby-fakegem eapi8-dosym
+
+DESCRIPTION="'httpclient' gives something like the functionality of libwww-perl (LWP) in Ruby"
+HOMEPAGE="https://github.com/nahi/httpclient"
+SRC_URI="https://github.com/nahi/httpclient/archive/v${PV}.tar.gz -> ${P}.tgz"
+
+LICENSE="Ruby"
+SLOT="0"
+
+KEYWORDS="~amd64 ~arm ~arm64 ~hppa ~ppc ~ppc64 ~sparc ~x86 ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x64-solaris ~x86-solaris"
+IUSE=""
+
+ruby_add_rdepend "virtual/ruby-ssl"
+
+ruby_add_bdepend "doc? ( dev-ruby/rdoc )"
+ruby_add_bdepend "test? ( dev-ruby/test-unit dev-ruby/http-cookie )"
+
+all_ruby_prepare() {
+	rm Gemfile || die
+	sed -i -e '/[bB]undler/s:^:#:' Rakefile || die
+
+	# Fix documentation task
+	sed -i -e 's/README.txt/README.md/' Rakefile || die
+
+	# Remove mandatory CI reports since we don't need this for testing.
+	sed -i -e '/reporter/s:^:#:' Rakefile || die
+
+	# Remove mandatory simplecov dependency
+	sed -i -e '/[Ss]imple[Cc]ov/ s:^:#:' test/helper.rb || die
+
+	# Comment out test requiring network access that makes assumptions
+	# about the environment, bug 395155
+	sed -i -e '/test_async_error/,/^  end/ s:^:#:' test/test_httpclient.rb || die
+
+	# Skip tests using rack-ntlm which is not packaged. Weirdly these
+	# only fail on jruby.
+	rm test/test_auth.rb || die
+
+	# Skip test failing due to hard-coded expired certificate
+	sed -i -e '/test_verification_without_httpclient/,/^  end/ s:^:#:' test/test_ssl.rb || die
+
+	# Skip test depending on obsolete and vulnerable SSLv3
+	sed -i -e '/test_no_sslv3/,/^  end/ s:^:#:' test/test_ssl.rb || die
+
+	# Do not use 11-year-old bundled certificates!
+	# fix this copy so it doesn't fail tests
+	ln -sf "${EPREFIX}"/etc/ssl/certs/ca-certificates.crt ./dist_key/cacerts.pem
+	ln -sf "${EPREFIX}"/etc/ssl/certs/ca-certificates.crt ./lib/httpclient/cacert.pem
+}
+
+each_ruby_test() {
+	${RUBY} -Ilib:test:. -e 'gem "test-unit"; Dir["test/test_*.rb"].each{|f| require f}' || die
+}
+
+each_ruby_install() {
+	each_fakegem_install
+	# Do not use 11-year-old bundled certificates!
+	# fix this copy for production systems
+	# do not ship the cacert1024.pem at all anymore, nobody should use RSA1024 certs!
+	rm -f "${ED}/$(ruby_fakegem_gemsdir)/gems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}/lib/httpclient/"{cacert.pem,cacert1024}.pem
+	dosym8 -r /etc/ssl/certs/ca-certificates.crt $(ruby_fakegem_gemsdir)/gems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}/lib/httpclient/cacert.pem
+}


             reply	other threads:[~2021-10-14 20:07 UTC|newest]

Thread overview: 54+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-10-14 20:07 Robin H. Johnson [this message]
  -- strict thread matches above, loose matches on Subject: below --
2024-02-23  7:39 [gentoo-commits] repo/gentoo:master commit in: dev-ruby/httpclient/ Hans de Graaff
2024-02-20 20:59 Ionen Wolkens
2024-02-20 20:59 Ionen Wolkens
2024-02-18  7:29 Hans de Graaff
2024-02-17  7:34 Hans de Graaff
2023-07-15 11:52 Arthur Zamarin
2023-04-13  3:03 Sam James
2022-12-24  6:35 Sam James
2022-07-30  7:46 Hans de Graaff
2022-06-28 16:59 Arthur Zamarin
2022-06-28 16:47 Arthur Zamarin
2022-05-08 15:00 WANG Xuerui
2022-04-26 14:38 Sam James
2022-04-09 12:42 Hans de Graaff
2022-04-09 12:42 Hans de Graaff
2022-04-08  9:15 Hans de Graaff
2022-04-01  5:15 Arthur Zamarin
2021-10-09 15:24 Naohiro Aota
2020-12-22  5:30 Hans de Graaff
2019-05-01 19:36 Hans de Graaff
2018-07-08  4:06 Hans de Graaff
2018-07-07  9:02 Sergei Trofimovich
2018-07-02  5:29 Hans de Graaff
2018-07-02  0:49 Thomas Deutschmann
2018-06-27 21:54 Sergei Trofimovich
2018-06-25 18:24 Hans de Graaff
2018-06-05  4:06 Hans de Graaff
2018-05-22  6:12 Hans de Graaff
2018-03-22 20:23 Jeroen Roovers
2017-12-29 17:41 Sergei Trofimovich
2017-10-01  6:44 Hans de Graaff
2017-07-15  5:22 Hans de Graaff
2016-12-21  6:37 Hans de Graaff
2016-12-13  6:53 Hans de Graaff
2016-12-13  6:53 Hans de Graaff
2016-12-09  8:35 Hans de Graaff
2016-09-28  8:17 Tobias Klausmann
2016-09-13  4:36 Hans de Graaff
2016-09-13  4:36 Hans de Graaff
2016-08-19  6:00 Hans de Graaff
2016-08-09  5:02 Hans de Graaff
2016-05-29  5:26 Hans de Graaff
2016-05-16  5:29 Hans de Graaff
2016-04-23  5:24 Hans de Graaff
2016-04-23  5:24 Hans de Graaff
2016-01-02  6:50 Hans de Graaff
2015-12-12  7:35 Hans de Graaff
2015-11-12 10:15 Agostino Sarubbo
2015-11-11  9:54 Agostino Sarubbo
2015-11-11  6:05 Jeroen Roovers
2015-11-10  6:37 Hans de Graaff
2015-11-09 11:24 Agostino Sarubbo
2015-11-06  7:31 Hans de Graaff

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1634242065.95813829db1b5ed24e91076a36f43d9c34392c7d.robbat2@gentoo \
    --to=robbat2@gentoo.org \
    --cc=gentoo-commits@lists.gentoo.org \
    --cc=gentoo-dev@lists.gentoo.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox