aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGuido Falsi <madpilot@FreeBSD.org>2023-09-25 12:59:29 +0000
committerGuido Falsi <madpilot@FreeBSD.org>2023-09-25 12:59:29 +0000
commit7453fb413ae68f256c4848ad642bee04293f3c28 (patch)
tree7dde3482755f710b07549ca35d31df2850470409
parent2781931b6ffda70f3f1dc8123d06444d8a39f054 (diff)
downloadports-7453fb413ae68f256c4848ad642bee04293f3c28.tar.gz
ports-7453fb413ae68f256c4848ad642bee04293f3c28.zip
security/xca: Update to 2.5.0
- Flavorize and add qt6 flavor
-rw-r--r--security/xca/Makefile45
-rw-r--r--security/xca/distinfo6
-rw-r--r--security/xca/files/patch-doc_CMakeLists.txt11
-rw-r--r--security/xca/files/patch-lib_pkcs11.cpp32
-rw-r--r--security/xca/files/patch-lib_pki__evp.cpp33
-rw-r--r--security/xca/files/patch-lib_pki__key.cpp65
-rw-r--r--security/xca/files/patch-lib_pki__scard.cpp30
-rw-r--r--security/xca/pkg-plist92
8 files changed, 115 insertions, 199 deletions
diff --git a/security/xca/Makefile b/security/xca/Makefile
index fce533e9e296..80c4213c5ce4 100644
--- a/security/xca/Makefile
+++ b/security/xca/Makefile
@@ -1,5 +1,5 @@
PORTNAME= xca
-PORTVERSION= 2.4.0
+PORTVERSION= 2.5.0
CATEGORIES= security
MASTER_SITES= https://github.com/${GH_ACCOUNT}/xca/releases/download/RELEASE.${PORTVERSION}/
@@ -10,21 +10,30 @@ WWW= https://hohnstaedt.de/xca
LICENSE= BSD3CLAUSE
LICENSE_FILE= ${WRKSRC}/COPYRIGHT
-BUILD_DEPENDS= gsed:textproc/gsed
-LIB_DEPENDS= libltdl.so:devel/libltdl
-
-USES= compiler:c++11-lang desktop-file-utils gmake localbase \
- pkgconfig qt:5 shared-mime-info ssl
-BROKEN_SSL= openssl30 openssl31
-BROKEN_SSL_REASON= Uses deprecated and removed OpenSSL routines
-USE_QT= buildtools:build core gui help linguist:build sql widgets
-USE_CXXSTD= c++11
-
-GNU_CONFIGURE= yes
-BINARY_ALIAS= sed=${LOCALBASE}/bin/gsed
-CONFIGURE_ARGS= --with-openssl=${OPENSSLDIR} \
- --with-qt=${PREFIX} \
- --with-qt-version=5
+FLAVORS= qt5 qt6
+FLAVOR?= ${FLAVORS:[1]}
+FLAVORS_SUB= yes
+qt5_PKGNAMESUFFIX=
+qt6_PKGNAMESUFFIX= -qt6
+qt5_CONFLICTS_INSTALL= ${PORTNAME}-qt6
+qt6_CONFLICTS_INSTALL= ${PORTNAME}
+
+USES= cmake compiler:c++17-lang desktop-file-utils localbase \
+ pkgconfig shared-mime-info ssl
+USE_LOCALE= en_US.UTF-8
+
+.if ${FLAVOR} == qt5
+USES+= qt:5
+USE_QT= core gui help qmake sql widgets buildtools:build linguist:build
+RCCREGEXP= \/lib\/qt5\/bin\/rcc
+CMAKE_ARG= -DQTFIXEDVERSION:STRING=qt5
+.else
+USES+= gl qt:6
+USE_GL= opengl
+USE_QT= base sqldriver-sqlite tools
+RCCREGEXP= \/libexec\/qt6\/rcc
+CMAKE_ARG= -DQTFIXEDVERSION:STRING=qt6
+.endif
GH_ACCOUNT= chris2511
@@ -32,8 +41,4 @@ OPTIONS_DEFINE= DOCS
DOCS_BUILD_DEPENDS= sphinx-build:textproc/py-sphinx
-post-patch:
- @${REINPLACE_CMD} -e '/^CFLAGS/s|-O2 ||' \
- ${WRKSRC}/Local.mak.in
-
.include <bsd.port.mk>
diff --git a/security/xca/distinfo b/security/xca/distinfo
index 008f7e85b5d3..2666b1dd0520 100644
--- a/security/xca/distinfo
+++ b/security/xca/distinfo
@@ -1,3 +1,3 @@
-TIMESTAMP = 1620426109
-SHA256 (xca-2.4.0.tar.gz) = 66da8954fe9709ace965c6fcb1cfbb7b08ce75b7222988acb9e2b8b5fac7cf10
-SIZE (xca-2.4.0.tar.gz) = 1778572
+TIMESTAMP = 1695589720
+SHA256 (xca-2.5.0.tar.gz) = b50ef50c4850a1c1d20fce41971783cb0a2fb9155caa05300029b28b53311d37
+SIZE (xca-2.5.0.tar.gz) = 1846478
diff --git a/security/xca/files/patch-doc_CMakeLists.txt b/security/xca/files/patch-doc_CMakeLists.txt
new file mode 100644
index 000000000000..ea57e11c23eb
--- /dev/null
+++ b/security/xca/files/patch-doc_CMakeLists.txt
@@ -0,0 +1,11 @@
+--- doc/CMakeLists.txt.orig 2023-09-24 18:22:03 UTC
++++ doc/CMakeLists.txt
+@@ -129,7 +129,7 @@ if(SPHINX)
+
+ if (UNIX AND NOT APPLE)
+ install(FILES ${QTHELP_DEST} ${QTHELP_IDX}
+- DESTINATION ${CMAKE_INSTALL_DATADIR}/${CMAKE_PROJECT_NAME}/html
++ DESTINATION ${CMAKE_INSTALL_DOCDIR}/html
+ )
+ elseif (WIN32)
+ install(FILES ${QTHELP_DEST} ${QTHELP_IDX}
diff --git a/security/xca/files/patch-lib_pkcs11.cpp b/security/xca/files/patch-lib_pkcs11.cpp
deleted file mode 100644
index caba1dcc1f47..000000000000
--- a/security/xca/files/patch-lib_pkcs11.cpp
+++ /dev/null
@@ -1,32 +0,0 @@
---- lib/pkcs11.cpp.orig 2021-05-07 20:40:29 UTC
-+++ lib/pkcs11.cpp
-@@ -840,8 +840,7 @@ EVP_PKEY *pkcs11::getPrivateKey(EVP_PKEY *pub, CK_OBJE
-
- switch (EVP_PKEY_type(keytype)) {
- case EVP_PKEY_RSA:
-- rsa = EVP_PKEY_get0_RSA(pub);
-- rsa = RSAPublicKey_dup(rsa);
-+ rsa = RSAPublicKey_dup(EVP_PKEY_get0_RSA(pub));
- openssl_error();
- if (!rsa_meth) {
- #if OPENSSL_VERSION_NUMBER >= 0x1010000L
-@@ -865,8 +864,7 @@ EVP_PKEY *pkcs11::getPrivateKey(EVP_PKEY *pub, CK_OBJE
- EVP_PKEY_assign_RSA(evp, rsa);
- break;
- case EVP_PKEY_DSA:
-- dsa = EVP_PKEY_get0_DSA(pub);
-- dsa = DSAparams_dup(dsa);
-+ dsa = DSAparams_dup(EVP_PKEY_get0_DSA(pub));
- openssl_error();
- if (!dsa_meth) {
- #if OPENSSL_VERSION_NUMBER >= 0x10100000L
-@@ -889,8 +887,7 @@ EVP_PKEY *pkcs11::getPrivateKey(EVP_PKEY *pub, CK_OBJE
- break;
- #if !defined(OPENSSL_NO_EC) && OPENSSL_VERSION_NUMBER >= 0x10100000L
- case EVP_PKEY_EC:
-- ec = EVP_PKEY_get0_EC_KEY(pub);
-- ec = EC_KEY_dup(ec);
-+ ec = EC_KEY_dup(EVP_PKEY_get0_EC_KEY(pub));
- openssl_error();
- if (!ec_key_meth) {
- ec_key_meth = setup_ec_key_meth();
diff --git a/security/xca/files/patch-lib_pki__evp.cpp b/security/xca/files/patch-lib_pki__evp.cpp
deleted file mode 100644
index 28fdc74c6690..000000000000
--- a/security/xca/files/patch-lib_pki__evp.cpp
+++ /dev/null
@@ -1,33 +0,0 @@
---- lib/pki_evp.cpp.orig 2021-05-07 20:40:29 UTC
-+++ lib/pki_evp.cpp
-@@ -282,8 +282,8 @@ static void search_ec_oid(EVP_PKEY *pkey)
- static void search_ec_oid(EVP_PKEY *pkey)
- {
- #ifndef OPENSSL_NO_EC
-- EC_KEY *ec;
- EC_GROUP *builtin;
-+ const EC_KEY *ec;
- const EC_GROUP *ec_group;
-
- int keytype = EVP_PKEY_id(pkey);
-@@ -621,8 +621,10 @@ EVP_PKEY *pki_evp::legacyDecryptKey(QByteArray &myencK
-
- pki_openssl_error();
- if (EVP_PKEY_type(getKeyType()) == EVP_PKEY_RSA) {
-- RSA *rsa = EVP_PKEY_get0_RSA(tmpkey);
-+ RSA *rsa = (RSA *)EVP_PKEY_get0_RSA(tmpkey);
-+#if OPENSSL_VERSION_MAJOR < 3
- RSA_blinding_on(rsa, NULL);
-+#endif
- }
- myencKey.fill(0);
- return tmpkey;
-@@ -930,7 +932,7 @@ bool pki_evp::verify_priv(EVP_PKEY *pkey) const
- EVP_MD_CTX_free(ctx);
- #endif
- if (EVP_PKEY_id(pkey) == EVP_PKEY_RSA && EVP_PKEY_isPrivKey(pkey)) {
-- RSA *rsa = EVP_PKEY_get0_RSA(pkey);
-+ const RSA *rsa = EVP_PKEY_get0_RSA(pkey);
- if (RSA_check_key(rsa) != 1)
- verify = false;
- }
diff --git a/security/xca/files/patch-lib_pki__key.cpp b/security/xca/files/patch-lib_pki__key.cpp
deleted file mode 100644
index a7a834548ca6..000000000000
--- a/security/xca/files/patch-lib_pki__key.cpp
+++ /dev/null
@@ -1,65 +0,0 @@
---- lib/pki_key.cpp.orig 2021-05-07 20:40:29 UTC
-+++ lib/pki_key.cpp
-@@ -197,7 +197,7 @@ QString pki_key::length() const
-
- if (EVP_PKEY_id(key) == EVP_PKEY_DSA) {
- const BIGNUM *p = NULL;
-- DSA *dsa = EVP_PKEY_get0_DSA(key);
-+ const DSA *dsa = EVP_PKEY_get0_DSA(key);
- if (dsa)
- DSA_get0_pqg(dsa, &p, NULL, NULL);
- dsa_unset = p == NULL;
-@@ -299,7 +299,7 @@ QString pki_key::modulus() const
- if (getKeyType() == EVP_PKEY_RSA) {
- const BIGNUM *n = NULL;
-
-- RSA *rsa = EVP_PKEY_get0_RSA(key);
-+ const RSA *rsa = EVP_PKEY_get0_RSA(key);
- RSA_get0_key(rsa, &n, NULL, NULL);
- return BN2QString(n);
- }
-@@ -310,7 +310,7 @@ QString pki_key::pubEx() const
- {
- if (getKeyType() == EVP_PKEY_RSA) {
- const BIGNUM *e = NULL;
-- RSA *rsa = EVP_PKEY_get0_RSA(key);
-+ const RSA *rsa = EVP_PKEY_get0_RSA(key);
- RSA_get0_key(rsa, NULL, &e, NULL);
- return BN2QString(e);
- }
-@@ -321,7 +321,7 @@ QString pki_key::subprime() const
- {
- if (getKeyType() == EVP_PKEY_DSA) {
- const BIGNUM *q = NULL;
-- DSA *dsa = EVP_PKEY_get0_DSA(key);
-+ const DSA *dsa = EVP_PKEY_get0_DSA(key);
- if (dsa)
- DSA_get0_pqg(dsa, NULL, &q, NULL);
- return BN2QString(q);
-@@ -333,7 +333,7 @@ QString pki_key::pubkey() const
- {
- if (getKeyType() == EVP_PKEY_DSA) {
- const BIGNUM *pubkey = NULL;
-- DSA *dsa = EVP_PKEY_get0_DSA(key);
-+ const DSA *dsa = EVP_PKEY_get0_DSA(key);
- if (dsa)
- DSA_get0_key(dsa, &pubkey, NULL);
- return BN2QString(pubkey);
-@@ -766,7 +766,7 @@ QByteArray pki_key::SSH2publicQByteArray(bool raw) con
- txt = "ssh-rsa";
- ssh_key_QBA2data(txt, &data);
- {
-- RSA *rsa = EVP_PKEY_get0_RSA(key);
-+ const RSA *rsa = EVP_PKEY_get0_RSA(key);
- const BIGNUM *n, *e;
- RSA_get0_key(rsa, &n, &e, NULL);
- ssh_key_bn2data(e, &data);
-@@ -777,7 +777,7 @@ QByteArray pki_key::SSH2publicQByteArray(bool raw) con
- txt = "ssh-dss";
- ssh_key_QBA2data(txt, &data);
- {
-- DSA *dsa = EVP_PKEY_get0_DSA(key);
-+ const DSA *dsa = EVP_PKEY_get0_DSA(key);
- const BIGNUM *p, *q, *g, *pubkey;
- DSA_get0_pqg(dsa, &p, &q, &g);
- DSA_get0_key(dsa, &pubkey, NULL);
diff --git a/security/xca/files/patch-lib_pki__scard.cpp b/security/xca/files/patch-lib_pki__scard.cpp
deleted file mode 100644
index e8335511da7f..000000000000
--- a/security/xca/files/patch-lib_pki__scard.cpp
+++ /dev/null
@@ -1,30 +0,0 @@
---- lib/pki_scard.cpp.orig 2021-05-07 20:40:29 UTC
-+++ lib/pki_scard.cpp
-@@ -293,10 +293,10 @@ pk11_attlist pki_scard::objectAttributesNoId(EVP_PKEY
- pk11_attlist pki_scard::objectAttributesNoId(EVP_PKEY *pk, bool priv) const
- {
- QByteArray ba;
-- RSA *rsa;
-- DSA *dsa;
-+ const RSA *rsa;
-+ const DSA *dsa;
- #ifndef OPENSSL_NO_EC
-- EC_KEY *ec;
-+ const EC_KEY *ec;
- #endif
- const BIGNUM *n = NULL;
- const BIGNUM *e = NULL;
-@@ -401,10 +401,10 @@ void pki_scard::store_token(const slotid &slot, EVP_PK
- void pki_scard::store_token(const slotid &slot, EVP_PKEY *pkey)
- {
- QByteArray ba;
-- RSA *rsa;
-- DSA *dsa;
-+ const RSA *rsa;
-+ const DSA *dsa;
- #ifndef OPENSSL_NO_EC
-- EC_KEY *ec;
-+ const EC_KEY *ec;
- #endif
- pk11_attlist pub_atts;
- pk11_attlist priv_atts;
diff --git a/security/xca/pkg-plist b/security/xca/pkg-plist
index c5f3a5e8f74e..64ccaafc0976 100644
--- a/security/xca/pkg-plist
+++ b/security/xca/pkg-plist
@@ -1,7 +1,42 @@
bin/xca
-man/man1/xca.1.gz
share/applications/xca.desktop
share/bash-completion/completions/xca
+%%PORTDOCS%%%%DOCSDIR%%/_sources/arguments.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/certificate-input.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/certificates.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/changelog.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/commandline.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/common-actions.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/database.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/index.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/introduction.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/miscellaneous.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/object-ids.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/options.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/privatekey.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/requests.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/revocationlist.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/smartcard.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/step-by-step.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_sources/template.rst.txt
+%%PORTDOCS%%%%DOCSDIR%%/_static/_sphinx_javascript_frameworks_compat.js
+%%PORTDOCS%%%%DOCSDIR%%/_static/alabaster.css
+%%PORTDOCS%%%%DOCSDIR%%/_static/basic.css
+%%PORTDOCS%%%%DOCSDIR%%/_static/bigcert.png
+%%PORTDOCS%%%%DOCSDIR%%/_static/custom.css
+%%PORTDOCS%%%%DOCSDIR%%/_static/doctools.js
+%%PORTDOCS%%%%DOCSDIR%%/_static/documentation_options.js
+%%PORTDOCS%%%%DOCSDIR%%/_static/file.png
+%%PORTDOCS%%%%DOCSDIR%%/_static/jquery-3.6.0.js
+%%PORTDOCS%%%%DOCSDIR%%/_static/jquery.js
+%%PORTDOCS%%%%DOCSDIR%%/_static/language_data.js
+%%PORTDOCS%%%%DOCSDIR%%/_static/minus.png
+%%PORTDOCS%%%%DOCSDIR%%/_static/plus.png
+%%PORTDOCS%%%%DOCSDIR%%/_static/pygments.css
+%%PORTDOCS%%%%DOCSDIR%%/_static/searchtools.js
+%%PORTDOCS%%%%DOCSDIR%%/_static/sphinx_highlight.js
+%%PORTDOCS%%%%DOCSDIR%%/_static/underscore-1.13.1.js
+%%PORTDOCS%%%%DOCSDIR%%/_static/underscore.js
%%PORTDOCS%%%%DOCSDIR%%/arguments.html
%%PORTDOCS%%%%DOCSDIR%%/certificate-input.html
%%PORTDOCS%%%%DOCSDIR%%/certificates.html
@@ -10,19 +45,40 @@ share/bash-completion/completions/xca
%%PORTDOCS%%%%DOCSDIR%%/common-actions.html
%%PORTDOCS%%%%DOCSDIR%%/database.html
%%PORTDOCS%%%%DOCSDIR%%/genindex.html
+%%PORTDOCS%%%%DOCSDIR%%/html/certificate-input.html
+%%PORTDOCS%%%%DOCSDIR%%/html/certificates.html
+%%PORTDOCS%%%%DOCSDIR%%/html/changelog.html
+%%PORTDOCS%%%%DOCSDIR%%/html/commandline.html
+%%PORTDOCS%%%%DOCSDIR%%/html/common-actions.html
+%%PORTDOCS%%%%DOCSDIR%%/html/database.html
+%%PORTDOCS%%%%DOCSDIR%%/html/index.html
+%%PORTDOCS%%%%DOCSDIR%%/html/introduction.html
+%%PORTDOCS%%%%DOCSDIR%%/html/miscellaneous.html
+%%PORTDOCS%%%%DOCSDIR%%/html/object-ids.html
+%%PORTDOCS%%%%DOCSDIR%%/html/options.html
+%%PORTDOCS%%%%DOCSDIR%%/html/privatekey.html
+%%PORTDOCS%%%%DOCSDIR%%/html/requests.html
+%%PORTDOCS%%%%DOCSDIR%%/html/revocationlist.html
+%%PORTDOCS%%%%DOCSDIR%%/html/smartcard.html
+%%PORTDOCS%%%%DOCSDIR%%/html/step-by-step.html
+%%PORTDOCS%%%%DOCSDIR%%/html/template.html
+%%PORTDOCS%%%%DOCSDIR%%/html/xca.qch
+%%PORTDOCS%%%%DOCSDIR%%/html/xca.qhc
%%PORTDOCS%%%%DOCSDIR%%/index.html
%%PORTDOCS%%%%DOCSDIR%%/introduction.html
%%PORTDOCS%%%%DOCSDIR%%/miscellaneous.html
%%PORTDOCS%%%%DOCSDIR%%/object-ids.html
+%%PORTDOCS%%%%DOCSDIR%%/objects.inv
%%PORTDOCS%%%%DOCSDIR%%/options.html
%%PORTDOCS%%%%DOCSDIR%%/privatekey.html
%%PORTDOCS%%%%DOCSDIR%%/requests.html
%%PORTDOCS%%%%DOCSDIR%%/revocationlist.html
+%%PORTDOCS%%%%DOCSDIR%%/search.html
+%%PORTDOCS%%%%DOCSDIR%%/searchindex.js
%%PORTDOCS%%%%DOCSDIR%%/smartcard.html
%%PORTDOCS%%%%DOCSDIR%%/step-by-step.html
%%PORTDOCS%%%%DOCSDIR%%/template.html
-%%PORTDOCS%%%%DOCSDIR%%/xca.qch
-%%PORTDOCS%%%%DOCSDIR%%/xca.qhc
+share/man/man1/xca.1.gz
share/mime/packages/xca.xml
share/icons/hicolor/16x16/apps/xca.png
share/icons/hicolor/16x16/mimetypes/x-xca-database.png
@@ -42,17 +98,21 @@ share/pixmaps/xca-32x32.xpm
%%DATADIR%%/TLS_server.xca
%%DATADIR%%/dn.txt
%%DATADIR%%/eku.txt
+%%QT6%%%%DATADIR%%/i18n/xca.qm
+%%DATADIR%%/i18n/xca_bg.qm
+%%DATADIR%%/i18n/xca_de.qm
+%%DATADIR%%/i18n/xca_es.qm
+%%DATADIR%%/i18n/xca_fa.qm
+%%DATADIR%%/i18n/xca_fr.qm
+%%DATADIR%%/i18n/xca_hr.qm
+%%DATADIR%%/i18n/xca_id.qm
+%%DATADIR%%/i18n/xca_it.qm
+%%DATADIR%%/i18n/xca_ja.qm
+%%DATADIR%%/i18n/xca_nl.qm
+%%DATADIR%%/i18n/xca_pl.qm
+%%DATADIR%%/i18n/xca_pt_BR.qm
+%%DATADIR%%/i18n/xca_ru.qm
+%%DATADIR%%/i18n/xca_sk.qm
+%%DATADIR%%/i18n/xca_tr.qm
+%%DATADIR%%/i18n/xca_zh_CN.qm
%%DATADIR%%/oids.txt
-%%DATADIR%%/xca_de.qm
-%%DATADIR%%/xca_es.qm
-%%DATADIR%%/xca_fr.qm
-%%DATADIR%%/xca_hr.qm
-%%DATADIR%%/xca_it.qm
-%%DATADIR%%/xca_ja.qm
-%%DATADIR%%/xca_nl.qm
-%%DATADIR%%/xca_pl.qm
-%%DATADIR%%/xca_pt_BR.qm
-%%DATADIR%%/xca_ru.qm
-%%DATADIR%%/xca_sk.qm
-%%DATADIR%%/xca_tr.qm
-%%DATADIR%%/xca_zh_CN.qm