QCA: Difference between revisions

From KDE UserBase Wiki
m (Make it translatable)
m (Link to toplevel download folder instead of some (outdated) tarball)
 
(3 intermediate revisions by 2 users not shown)
Line 1: Line 1:
<languages/>
<languages/>
<translate>
<translate>
= QCA =
= QCA = <!--T:1-->


<!--T:2-->
[[File:Kde_password_icon.png]]
[[File:Kde_password_icon.png]]


== What is it? ==
== What is it? == <!--T:3-->


<!--T:4-->
Taking a hint from the similarly-named [http://java.sun.com/j2se/1.3/docs/guide/security/CryptoSpec.html Java Cryptography Architecture], QCA aims to provide a straightforward and cross-platform crypto API, using Qt datatypes and conventions. QCA separates the API from the implementation, using plugins known as Providers. The advantage of this model is to allow applications to avoid linking to or explicitly depending on any particular cryptographic library. This allows one to easily change or upgrade crypto implementations without even needing to recompile the application! QCA should work everywhere Qt does, including Windows/Unix/MacOSX.
Taking a hint from the similarly-named [http://java.sun.com/j2se/1.3/docs/guide/security/CryptoSpec.html Java Cryptography Architecture], QCA aims to provide a straightforward and cross-platform crypto API, using Qt datatypes and conventions. QCA separates the API from the implementation, using plugins known as Providers. The advantage of this model is to allow applications to avoid linking to or explicitly depending on any particular cryptographic library. This allows one to easily change or upgrade crypto implementations without even needing to recompile the application! QCA should work everywhere Qt does, including Windows/Unix/MacOSX.


== What do I need to be able to use it? ==
== What do I need to be able to use it? == <!--T:5-->


<!--T:6-->
Latest QCA depends on [https://doc.qt.io/qt-5/ Qt 5.6+].
Latest QCA depends on [https://doc.qt.io/qt-5/ Qt 5.6+].


== What features are supported? ==
== What features are supported? == <!--T:7-->


<!--T:8-->
* SSL/TLS
* SSL/TLS


<!--T:9-->
* X.509
* X.509


<!--T:10-->
* OpenPGP
* OpenPGP


<!--T:11-->
* Cryptographic Message Syntax (for S/MIME)
* Cryptographic Message Syntax (for S/MIME)


<!--T:12-->
* SASL
* SASL


<!--T:13-->
* PKCS#12
* PKCS#12


<!--T:14-->
* Smart cards and other key storage
* Smart cards and other key storage


<!--T:15-->
* Secure memory
* Secure memory


<!--T:16-->
* Secure random
* Secure random


<!--T:17-->
* RSA/DSA/Diffie-Hellman
* RSA/DSA/Diffie-Hellman


<!--T:18-->
* Hash/Cipher/MAC algorithms
* Hash/Cipher/MAC algorithms


<!--T:19-->
* Threading considerations
* Threading considerations


<!--T:20-->
* Access operating system root certificates
* Access operating system root certificates


== How does it work? ==
== How does it work? == <!--T:21-->


<!--T:22-->
The application includes <QtCrypto> and links to libqca, which provides the 'wrapper API' and plugin loader. Crypto functionality is determined during runtime, and plugins are loaded from the 'crypto' subfolder of the Qt Library Paths.
The application includes <QtCrypto> and links to libqca, which provides the 'wrapper API' and plugin loader. Crypto functionality is determined during runtime, and plugins are loaded from the 'crypto' subfolder of the Qt Library Paths.


== What is the development plan? ==
== What is the development plan? == <!--T:23-->


<!--T:24-->
The base QCA library is considered mostly complete. Future development may include OCSP, shared certificate management, and improving the plugin API. However, there is no development plan for the base library at this time. Work will continue on the various plugins though, in order to get them into a release-quality state.
The base QCA library is considered mostly complete. Future development may include OCSP, shared certificate management, and improving the plugin API. However, there is no development plan for the base library at this time. Work will continue on the various plugins though, in order to get them into a release-quality state.


== Compatibility ==
== Compatibility == <!--T:25-->


<!--T:26-->
QCA follows a typical API/ABI compatibility scheme. Versions use the "major.minor.patch" format. Major versions of QCA may be incompatible with each other, minor versions are backwards compatible within the same major version, and patch versions are forwards and backwards compatible within the same minor version. This is the same scheme that Qt itself uses.
QCA follows a typical API/ABI compatibility scheme. Versions use the "major.minor.patch" format. Major versions of QCA may be incompatible with each other, minor versions are backwards compatible within the same major version, and patch versions are forwards and backwards compatible within the same minor version. This is the same scheme that Qt itself uses.


== Documentation ==
== Documentation == <!--T:27-->


<!--T:28-->
API documentation in HTML format is included in the source distribution.
API documentation in HTML format is included in the source distribution.
The documentation for the current version is also [https://api.kde.org/qca/html available online].


== Where can I get it? ==
== Where can I get it? == <!--T:29-->


Source: [http://download.kde.org/stable/qca/2.1.3/src/qca-2.1.3.tar.xz qca-2.1.3.tar.gz]
<!--T:30-->
The latest release packages can be found in the [http://download.kde.org/stable/qca QCA 2.x download area].


<!--T:31-->
QCA has built-in support for the SHA1 and MD5 hash algorithms, and a weak random number source. To perform any other crypto operations (or to utilize improved versions of the built-in ones), an appropriate provider plugin is needed. There are several available so far, and you could always write your own, too.
QCA has built-in support for the SHA1 and MD5 hash algorithms, and a weak random number source. To perform any other crypto operations (or to utilize improved versions of the built-in ones), an appropriate provider plugin is needed. There are several available so far, and you could always write your own, too.


<!--T:32-->
As of QCA 2.1, the latest plugins are included in the main tarball and don’t need to be downloaded separately.
As of QCA 2.1, the latest plugins are included in the main tarball and don’t need to be downloaded separately.


<!--T:33-->
<table border="1">
<table border="1">
<tr>
<tr>
Line 103: Line 128:
</table>
</table>


The latest source can be found in the 'qca' module of the KDE Git.  The code can also be browsed [https://cgit.kde.org/qca.git/ on the web].
<!--T:34-->
The latest source can be found in the 'qca' module of the KDE Git.  The code can also be browsed [https://commits.kde.org/qca on the web].


<!--T:35-->
''"keys" icon from KDE.''
''"keys" icon from KDE.''
</translate>
</translate>

Latest revision as of 11:34, 20 September 2020

Other languages:

QCA

What is it?

Taking a hint from the similarly-named Java Cryptography Architecture, QCA aims to provide a straightforward and cross-platform crypto API, using Qt datatypes and conventions. QCA separates the API from the implementation, using plugins known as Providers. The advantage of this model is to allow applications to avoid linking to or explicitly depending on any particular cryptographic library. This allows one to easily change or upgrade crypto implementations without even needing to recompile the application! QCA should work everywhere Qt does, including Windows/Unix/MacOSX.

What do I need to be able to use it?

Latest QCA depends on Qt 5.6+.

What features are supported?

  • SSL/TLS
  • X.509
  • OpenPGP
  • Cryptographic Message Syntax (for S/MIME)
  • SASL
  • PKCS#12
  • Smart cards and other key storage
  • Secure memory
  • Secure random
  • RSA/DSA/Diffie-Hellman
  • Hash/Cipher/MAC algorithms
  • Threading considerations
  • Access operating system root certificates

How does it work?

The application includes <QtCrypto> and links to libqca, which provides the 'wrapper API' and plugin loader. Crypto functionality is determined during runtime, and plugins are loaded from the 'crypto' subfolder of the Qt Library Paths.

What is the development plan?

The base QCA library is considered mostly complete. Future development may include OCSP, shared certificate management, and improving the plugin API. However, there is no development plan for the base library at this time. Work will continue on the various plugins though, in order to get them into a release-quality state.

Compatibility

QCA follows a typical API/ABI compatibility scheme. Versions use the "major.minor.patch" format. Major versions of QCA may be incompatible with each other, minor versions are backwards compatible within the same major version, and patch versions are forwards and backwards compatible within the same minor version. This is the same scheme that Qt itself uses.

Documentation

API documentation in HTML format is included in the source distribution. The documentation for the current version is also available online.

Where can I get it?

The latest release packages can be found in the QCA 2.x download area.

QCA has built-in support for the SHA1 and MD5 hash algorithms, and a weak random number source. To perform any other crypto operations (or to utilize improved versions of the built-in ones), an appropriate provider plugin is needed. There are several available so far, and you could always write your own, too.

As of QCA 2.1, the latest plugins are included in the main tarball and don’t need to be downloaded separately.

Provider Capabilities Depends on
qca-ossl TLS, CMS, X.509, RSA, DSA, Diffie-Hellman, PKCS#7, PKCS#12, SHA0, SHA1, SHA224, SHA256, SHA384, SHA512, MD2, MD4, MD5, RIPEMD160, Blowfish, DES, 3DES, AES128, AES192, AES256, CAST5, HMAC(SHA1, MD5, RIPEMD160), PBKDF1(MD2, SHA1), PBKDF2(SHA1) OpenSSL 0.9.6+
qca-cyrus-sasl SASL Cyrus SASL2
qca-gnupg OpenPGP GnuPG 1.x or 2.x (runtime dependency only)
qca-pkcs11 PKCS#11 (for smart cards) pkcs11-helper 1.02+
qca-wingss SASL GSSAPI (for Kerberos) Windows only (uses SSPI)
qca-logger Internal module logging (for debug purposes) None

The latest source can be found in the 'qca' module of the KDE Git. The code can also be browsed on the web.

"keys" icon from KDE.