-
Notifications
You must be signed in to change notification settings - Fork 1.8k
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
Add support for cpr 1.6.2 #5353
Changes from 5 commits
1214a12
01e2448
ea0f20a
c72da76
0c6ba8b
4cdb5a6
2505699
8d7b600
c660f6c
9509496
b99b4f6
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,9 +1,13 @@ | ||
from typing import no_type_check | ||
from conans import ConanFile, CMake, tools | ||
from conans.errors import ConanInvalidConfiguration | ||
import os | ||
|
||
|
||
class CprConan(ConanFile): | ||
_AUTO_SSL = "auto" | ||
_NO_SSL = "off" | ||
|
||
name = "cpr" | ||
description = "C++ Requests: Curl for People, a spiritual port of Python Requests" | ||
url = "https://github.com/conan-io/conan-center-index" | ||
|
@@ -16,14 +20,16 @@ class CprConan(ConanFile): | |
options = { | ||
"shared": [True, False], | ||
"fPIC": [True, False], | ||
"with_openssl": [True, False], | ||
"with_winssl": [True, False], | ||
"with_openssl": [True, False, "deprecated"], | ||
"with_winssl": [True, False, "deprecated"], | ||
"with_ssl": ["openssl", "darwinssl", "winssl", _AUTO_SSL, _NO_SSL] | ||
} | ||
default_options = { | ||
"shared": False, | ||
"fPIC": True, | ||
"with_openssl": True, | ||
"with_winssl": False, | ||
"with_openssl": "deprecated", | ||
"with_winssl": "deprecated", | ||
"with_ssl": _AUTO_SSL | ||
} | ||
|
||
_cmake = None | ||
|
@@ -40,13 +46,23 @@ def _build_subfolder(self): | |
def _supports_openssl(self): | ||
# https://github.com/whoshuu/cpr/commit/b036a3279ba62720d1e43362d32202bf412ea152 | ||
# https://github.com/whoshuu/cpr/releases/tag/1.5.0 | ||
return tools.Version(self.version) >= "1.5.0" | ||
return tools.Version(self.version) >= "1.5.0" and not tools.is_apple_os(self.settings.os) | ||
|
||
@property | ||
def _supports_winssl(self): | ||
# https://github.com/whoshuu/cpr/commit/18e1fc5c3fc0ffc07695f1d78897fb69e7474ea9 | ||
# https://github.com/whoshuu/cpr/releases/tag/1.5.1 | ||
return tools.Version(self.version) >= "1.5.1" | ||
return tools.Version(self.version) >= "1.5.1" and self.settings.os == "Windows" | ||
|
||
@property | ||
def _supports_darwinssl(self): | ||
# https://github.com/whoshuu/cpr/releases/tag/1.6.1 | ||
return tools.Version(self.version) >= "1.6.1" and tools.is_apple_os(self.settings.os) | ||
|
||
@property | ||
def _can_auto_ssl(self): | ||
# https://github.com/whoshuu/cpr/releases/tag/1.6.0 | ||
return not self._uses_old_cmake_options | ||
|
||
@property | ||
def _uses_old_cmake_options(self): | ||
|
@@ -68,20 +84,24 @@ def config_options(self): | |
del self.options.fPIC | ||
|
||
def configure(self): | ||
SSL_CURL_LIBS = { | ||
"openssl": "openssl", | ||
"darwinssl": "darwinssl", | ||
"winssl": "schannel" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Would it be easier if we used the name value? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Sorry, not sure what you're referring to here. Could you clarify? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There's a bit of complexity from the CPR values being different from the curl recipe... But looking at it again, it's just combinatorics hell, since the options and support have changed a lot it's very complicated |
||
} | ||
|
||
if self.options.shared: | ||
del self.options.fPIC | ||
if not self._supports_openssl: | ||
del self.options.with_openssl | ||
if not self._supports_winssl: | ||
del self.options.with_winssl | ||
|
||
ssl_library = self._get_ssl_library() | ||
# Make sure libcurl uses the same SSL implementation | ||
if self.options.get_safe("with_openssl", False): | ||
# self.options["libcurl"].with_openssl = True # deprecated in https://github.com/conan-io/conan-center-index/pull/2880 | ||
self.options["libcurl"].with_ssl = "openssl" | ||
if self.options.get_safe("with_winssl", False): | ||
# self.options["libcurl"].with_winssl = True # deprecated in https://github.com/conan-io/conan-center-index/pull/2880 | ||
self.options["libcurl"].with_ssl = "schannel" | ||
# "auto" will be handled by cpr | ||
if self._supports_ssl_library(ssl_library) and ssl_library in SSL_CURL_LIBS: | ||
self.options["libcurl"].with_ssl = SSL_CURL_LIBS[ssl_library] | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I would instead raise in There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Okey doke. I did this primarily to mirror what was already there but I'll give this a fiddle and see how it works out. |
||
|
||
|
||
def source(self): | ||
|
@@ -120,42 +140,98 @@ def _configure_cmake(self): | |
self._cmake.definitions[self._get_cmake_option("CPR_BUILD_TESTS")] = False | ||
self._cmake.definitions[self._get_cmake_option("CPR_GENERATE_COVERAGE")] = False | ||
self._cmake.definitions[self._get_cmake_option("CPR_USE_SYSTEM_GTEST")] = False | ||
if self._supports_openssl: | ||
self._cmake.definitions["CMAKE_USE_OPENSSL"] = self.options.get_safe("with_openssl", False) | ||
if self._supports_winssl: # The CMake options changed | ||
# https://github.com/whoshuu/cpr/commit/18e1fc5c3fc0ffc07695f1d78897fb69e7474ea9#diff-1e7de1ae2d059d21e1dd75d5812d5a34b0222cef273b7c3a2af62eb747f9d20aR39-R40 | ||
self._cmake.definitions[self._get_cmake_option("CPR_FORCE_OPENSSL_BACKEND")] = self.options.get_safe("with_openssl", False) | ||
self._cmake.definitions[self._get_cmake_option("CPR_FORCE_WINSSL_BACKEND")] = self.options.get_safe("with_winssl", False) | ||
|
||
supports_any_ssl = self.options.get_safe("with_openssl", False) or self.options.get_safe("with_winssl", False) | ||
if not self._uses_old_cmake_options and not supports_any_ssl: | ||
|
||
ssl_value = self._get_ssl_library() | ||
SSL_OPTIONS = { | ||
"CPR_FORCE_DARWINSSL_BACKEND": ssl_value == "darwinssl", | ||
"CPR_FORCE_OPENSSL_BACKEND": ssl_value == "openssl", | ||
"CPR_FORCE_WINSSL_BACKEND": ssl_value == "winssl", | ||
"CMAKE_USE_OPENSSL": ssl_value == "openssl" | ||
} | ||
|
||
for cmake_option, value in SSL_OPTIONS.items(): | ||
self._cmake.definitions[self._get_cmake_option(cmake_option)] = value | ||
|
||
# If we are on a version where disabling SSL requires a cmake option, disable it | ||
if not self._uses_old_cmake_options and self._get_ssl_library() == CprConan._NO_SSL: | ||
self._cmake.definitions["CPR_ENABLE_SSL"] = False | ||
|
||
self._cmake.configure(build_folder=self._build_subfolder) | ||
return self._cmake | ||
|
||
# Check if the system supports the given ssl library | ||
def _supports_ssl_library(self, library): | ||
if library == CprConan._NO_SSL: | ||
return True | ||
elif library == CprConan._AUTO_SSL: | ||
return self._can_auto_ssl | ||
|
||
validators = { | ||
"openssl": self._supports_openssl, | ||
"darwinssl": self._supports_darwinssl, | ||
"winssl": self._supports_winssl | ||
} | ||
|
||
if library not in validators: | ||
# This should never happen, as the options are validated by conan. | ||
raise ValueError(f"Unknown SSL library: {library}") | ||
|
||
return validators[library] | ||
|
||
def _print_deprecation_messages(self): | ||
if self.options.get_safe("with_openssl") != "deprecated": | ||
self.output.warn("with_openssl is deprecated. Please use the with_ssl option.") | ||
elif self.options.get_safe("with_winssl") != "deprecated": | ||
self.output.warn("with_winssl is deprecated. Please use the with_ssl option.") | ||
|
||
# Get the configured ssl library | ||
def _get_ssl_library(self): | ||
ssl_library = str(self.options.get_safe("with_ssl")) | ||
# These must check for True so that we don't take "deprecated" to be truthy | ||
if self.options.get_safe("with_openssl") == True: | ||
return "openssl" | ||
elif self.options.get_safe("with_winssl") == True: | ||
return "winssl" | ||
elif not self._can_auto_ssl and ssl_library == CprConan._AUTO_SSL: | ||
if self._supports_openssl: | ||
self.output.info("Auto SSL is not available below version 1.6.0. Falling back to openssl") | ||
return "openssl" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Perhaps this should be moved to such that the default is sensibly configured. We also try to no shock the user by override their explicit input and a minimum this should be a There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Makes total sense. Will fix this up later today. |
||
elif not self._supports_openssl: | ||
self.output.info("Auto SSL is not available below version 1.6.0, and openssl not supported. Disabling SSL") | ||
return CprConan._NO_SSL | ||
elif ssl_library == CprConan._AUTO_SSL and tools.Version(self.version) in ["1.6.0", "1.6.1"] and tools.is_apple_os(self.settings.os): | ||
# https://github.com/whoshuu/cpr/issues/546 | ||
self.output.info("Auto SSL is not available on macOS with version 1.6.0/1.6.1, and openssl not supported. Disabling SSL") | ||
return CprConan._NO_SSL | ||
|
||
return ssl_library | ||
|
||
def validate(self): | ||
if not self._uses_valid_abi_and_compiler: | ||
raise ConanInvalidConfiguration("Cannot compile CPR/1.6.0 with libstdc++ on clang < 9") | ||
SSL_FAILURE_MESSAGES = { | ||
"openssl": "OpenSSL is not supported on macOS or on CPR versions < 1.5.0", | ||
"darwinssl": "DarwinSSL is only supported on macOS and on CPR versions >= 1.6.1", | ||
"winssl": "WinSSL is only on Windows and on CPR versions >= 1.5.1", | ||
CprConan._AUTO_SSL: "Automatic SSL selection is only available on CPR versions >= 1.6.0" | ||
} | ||
|
||
if self.options.get_safe("with_openssl", False) and tools.is_apple_os(self.settings.os): | ||
# https://github.com/whoshuu/cpr/issues/546 | ||
raise ConanInvalidConfiguration("cpr cannot be built on macOS with openssl") | ||
self._print_deprecation_messages() | ||
if not self._uses_valid_abi_and_compiler: | ||
raise ConanInvalidConfiguration("Cannot compile cpr/1.6.0 with libstdc++ on clang < 9") | ||
|
||
if self.options.get_safe("with_winssl", False) and self.settings.os != "Windows": | ||
raise ConanInvalidConfiguration("cpr only supports winssl on Windows") | ||
ssl_library = self._get_ssl_library() | ||
if not self._supports_ssl_library(ssl_library): | ||
raise ConanInvalidConfiguration( | ||
f"Invalid SSL selection for the given configuration: {SSL_FAILURE_MESSAGES[ssl_library]}" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We are trying typing to maintain support for older python versions, could you please use There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Ah shoot - wasn't thinking about that. I've been in the |
||
if ssl_library not in (CprConan._AUTO_SSL, CprConan._NO_SSL) | ||
else f"Invalid value of ssl option, {ssl_library}" | ||
) | ||
|
||
if self.options.get_safe("with_openssl", False) and self.options.get_safe("with_winssl", False): | ||
raise ConanInvalidConfiguration("cpr can not be built with both openssl and winssl") | ||
if ssl_library not in (CprConan._AUTO_SSL, CprConan._NO_SSL) and ssl_library != self.options["libcurl"].with_ssl: | ||
raise ConanInvalidConfiguration(f"cpr requires libcurl to be built with the option with_ssl='{self.options.get_safe('ssl')}'.") | ||
|
||
if self.settings.compiler == "Visual Studio" and self.options.shared and "MT" in self.settings.compiler.runtime: | ||
raise ConanInvalidConfiguration("Visual Studio build for shared library with MT runtime is not supported") | ||
|
||
if self.options.get_safe("with_openssl", False) and self.options["libcurl"].with_ssl != "openssl": | ||
raise ConanInvalidConfiguration("cpr requires libcurl to be built with the option with_ssl='openssl'.") | ||
|
||
if self.options.get_safe("with_winssl", False) and self.options["libcurl"].with_ssl != "schannel": | ||
raise ConanInvalidConfiguration("cpr requires libcurl to be built with the option with_ssl='schannel'.") | ||
|
||
|
||
def build(self): | ||
self._patch_sources() | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
--- a/CMakeLists.txt | ||
+++ b/CMakeLists.txt | ||
@@ -120,29 +120,11 @@ endif() | ||
|
||
# Curl configuration | ||
if(CPR_FORCE_USE_SYSTEM_CURL) | ||
- if(CPR_ENABLE_SSL) | ||
- find_package(CURL COMPONENTS HTTP HTTPS SSL) | ||
- if(CURL_FOUND) | ||
- message(STATUS "Curl ${CURL_VERSION_STRING} found on this system.") | ||
- # To be able to load certificates under Windows when using OpenSSL: | ||
- if(CMAKE_USE_OPENSSL AND WIN32 AND (NOT (CURL_VERSION_STRING VERSION_GREATER_EQUAL "7.71.0"))) | ||
- message(FATAL_ERROR "Your system curl version (${CURL_VERSION_STRING}) is too old to support OpenSSL on Windows which requires curl >= 7.71.0. Update your curl version, use WinSSL, disable SSL or use the build in version of curl.") | ||
- endif() | ||
- else() | ||
- find_package(CURL COMPONENTS HTTP) | ||
- if(CURL_FOUND) | ||
- message(FATAL_ERROR "Curl found on this system but WITHOUT HTTPS/SSL support. Either disable SSL by setting CPR_ENABLE_SSL to OFF or use the build in version of curl by setting CPR_FORCE_USE_SYSTEM_CURL to OFF.") | ||
- else() | ||
- message(FATAL_ERROR "Curl not found on this system. To use the build in version set CPR_FORCE_USE_SYSTEM_CURL to OFF.") | ||
- endif() | ||
- endif() | ||
+ find_package(CURL) | ||
+ if(CURL_FOUND) | ||
+ message(STATUS "Curl found on this system.") | ||
else() | ||
- find_package(CURL COMPONENTS HTTP) | ||
- if(CURL_FOUND) | ||
- message(STATUS "Curl found on this system.") | ||
- else() | ||
- message(FATAL_ERROR "Curl not found on this system. To use the build in version set CPR_FORCE_USE_SYSTEM_CURL to OFF.") | ||
- endif() | ||
+ message(FATAL_ERROR "Curl not found on this system. To use the build in version set CPR_FORCE_USE_SYSTEM_CURL to OFF.") | ||
endif() | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Can we use find_package(REQUIRED) here? |
||
else() | ||
message(STATUS "Configuring build in curl...") |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -9,3 +9,5 @@ versions: | |
folder: all | ||
"1.6.0": | ||
folder: all | ||
"1.6.2": | ||
folder: all |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Because this will break python2 and there is no typing in conanfiles at all.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Bleh, I think my editor added this in and I didn't catch it. Thanks.