mirror of
https://github.com/aria2/aria2.git
synced 2025-04-04 21:17:41 +03:00
Update the docs regardings TLS support
This commit is contained in:
parent
a476fb352e
commit
4ce8c4021d
2 changed files with 76 additions and 33 deletions
72
README.rst
72
README.rst
|
@ -44,8 +44,8 @@ Here is a list of features:
|
||||||
* HTTP Proxy support
|
* HTTP Proxy support
|
||||||
* HTTP BASIC authentication support
|
* HTTP BASIC authentication support
|
||||||
* HTTP Proxy authentication support
|
* HTTP Proxy authentication support
|
||||||
* Well-known environment variables for proxy: ``http_proxy``, ``https_proxy``,
|
* Well-known environment variables for proxy: ``http_proxy``,
|
||||||
``ftp_proxy``, ``all_proxy`` and ``no_proxy``
|
``https_proxy``, ``ftp_proxy``, ``all_proxy`` and ``no_proxy``
|
||||||
* HTTP gzip, deflate content encoding support
|
* HTTP gzip, deflate content encoding support
|
||||||
* Verify peer using given trusted CA certificate in HTTPS
|
* Verify peer using given trusted CA certificate in HTTPS
|
||||||
* Client certificate authentication in HTTPS
|
* Client certificate authentication in HTTPS
|
||||||
|
@ -60,8 +60,8 @@ Here is a list of features:
|
||||||
* Download/Upload speed throttling
|
* Download/Upload speed throttling
|
||||||
* BitTorrent extensions: Fast extension, DHT, PEX, MSE/PSE,
|
* BitTorrent extensions: Fast extension, DHT, PEX, MSE/PSE,
|
||||||
Multi-Tracker, UDP tracker
|
Multi-Tracker, UDP tracker
|
||||||
* BitTorrent `WEB-Seeding <http://getright.com/seedtorrent.html>`_. aria2
|
* BitTorrent `WEB-Seeding <http://getright.com/seedtorrent.html>`_.
|
||||||
requests chunks more than piece size to reduce the request
|
aria2 requests chunks more than piece size to reduce the request
|
||||||
overhead. It also supports pipelined requests with piece size.
|
overhead. It also supports pipelined requests with piece size.
|
||||||
* BitTorrent Local Peer Discovery
|
* BitTorrent Local Peer Discovery
|
||||||
* Rename/change the directory structure of BitTorrent downloads
|
* Rename/change the directory structure of BitTorrent downloads
|
||||||
|
@ -73,8 +73,8 @@ Here is a list of features:
|
||||||
* Can disable segmented downloading in Metalink
|
* Can disable segmented downloading in Metalink
|
||||||
* Netrc support
|
* Netrc support
|
||||||
* Configuration file support
|
* Configuration file support
|
||||||
* Download URIs found in a text file or stdin and the destination directory and
|
* Download URIs found in a text file or stdin and the destination
|
||||||
output filename can be specified optionally
|
directory and output filename can be specified optionally
|
||||||
* Parameterized URI support
|
* Parameterized URI support
|
||||||
* IPv6 support with Happy Eyeballs
|
* IPv6 support with Happy Eyeballs
|
||||||
* Disk cache to reduce disk activity
|
* Disk cache to reduce disk activity
|
||||||
|
@ -99,11 +99,12 @@ Dependency
|
||||||
======================== ========================================
|
======================== ========================================
|
||||||
features dependency
|
features dependency
|
||||||
======================== ========================================
|
======================== ========================================
|
||||||
HTTPS OSX or GnuTLS or OpenSSL
|
HTTPS OSX or GnuTLS or OpenSSL or Windows
|
||||||
BitTorrent libnettle+libgmp or libgcrypt or OpenSSL
|
BitTorrent None. Optional: libnettle+libgmp or libgcrypt
|
||||||
|
or OpenSSL (see note)
|
||||||
Metalink libxml2 or Expat.
|
Metalink libxml2 or Expat.
|
||||||
Checksum None. Optional: OSX or libnettle or libgcrypt
|
Checksum None. Optional: OSX or libnettle or libgcrypt
|
||||||
or OpenSSL (see note)
|
or OpenSSL or Windows (see note)
|
||||||
gzip, deflate in HTTP zlib
|
gzip, deflate in HTTP zlib
|
||||||
Async DNS C-Ares
|
Async DNS C-Ares
|
||||||
Firefox3/Chromium cookie libsqlite3
|
Firefox3/Chromium cookie libsqlite3
|
||||||
|
@ -120,13 +121,18 @@ JSON-RPC over WebSocket libnettle or libgcrypt or OpenSSL
|
||||||
.. note::
|
.. note::
|
||||||
|
|
||||||
On Apple OSX the OS-level SSL/TLS support will be preferred. Hence
|
On Apple OSX the OS-level SSL/TLS support will be preferred. Hence
|
||||||
neither GnuTLS nor OpenSSL are required on that platform. If you'd like
|
neither GnuTLS nor OpenSSL are required on that platform. If you'd
|
||||||
to disable this behavior, run configure with ``--without-appletls``.
|
like to disable this behavior, run configure with
|
||||||
|
``--without-appletls``.
|
||||||
|
|
||||||
GnuTLS has precedence over OpenSSL if both libraries are installed.
|
GnuTLS has precedence over OpenSSL if both libraries are installed.
|
||||||
If you prefer OpenSSL, run configure with ``--without-gnutls``
|
If you prefer OpenSSL, run configure with ``--without-gnutls``
|
||||||
``--with-openssl``.
|
``--with-openssl``.
|
||||||
|
|
||||||
|
On Windows there is an experimental SSL implementation available that
|
||||||
|
is based on the native Windows SSL capabilities (Schannel). Run
|
||||||
|
configure with ``--with-wintls`` to use.
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
|
|
||||||
On Apple OSX the OS-level checksumming support will be preferred,
|
On Apple OSX the OS-level checksumming support will be preferred,
|
||||||
|
@ -140,6 +146,10 @@ JSON-RPC over WebSocket libnettle or libgcrypt or OpenSSL
|
||||||
If none of the optional dependencies are installed, an internal
|
If none of the optional dependencies are installed, an internal
|
||||||
implementation that only supports md5 and sha1 will be used.
|
implementation that only supports md5 and sha1 will be used.
|
||||||
|
|
||||||
|
On Windows there is an experimental implementation available that is
|
||||||
|
based on the native Windows capabilities. Run configure with
|
||||||
|
``--with-wintls`` to use.
|
||||||
|
|
||||||
A user can have one of the following configurations for SSL and crypto
|
A user can have one of the following configurations for SSL and crypto
|
||||||
libraries:
|
libraries:
|
||||||
|
|
||||||
|
@ -163,8 +173,8 @@ How to build
|
||||||
aria2 is primarily written in C++. Initially it was written based on
|
aria2 is primarily written in C++. Initially it was written based on
|
||||||
C++98/C++03 standard features. We are now migrating aria2 to C++11
|
C++98/C++03 standard features. We are now migrating aria2 to C++11
|
||||||
standard. The current source code requires C++11 aware compiler. For
|
standard. The current source code requires C++11 aware compiler. For
|
||||||
well-known compilers, such as g++ and clang, flag ``-std=c++11`` or
|
well-known compilers, such as g++ and clang, the ``-std=c++11`` or
|
||||||
``-std=c++0x`` must be supported.
|
``-std=c++0x`` flag must be supported.
|
||||||
|
|
||||||
In order to build aria2 from the source package, you need following
|
In order to build aria2 from the source package, you need following
|
||||||
development packages(package name may vary depending on the
|
development packages(package name may vary depending on the
|
||||||
|
@ -205,7 +215,7 @@ necessary to build the program::
|
||||||
Also you need `Sphinx <http://sphinx.pocoo.org/>`_ to build man page.
|
Also you need `Sphinx <http://sphinx.pocoo.org/>`_ to build man page.
|
||||||
|
|
||||||
If you are building aria2 for Mac OS X, take a look at
|
If you are building aria2 for Mac OS X, take a look at
|
||||||
build_osx_release.sh, which builds OSX universal binary DMG.
|
build_osx_release.sh, which builds an OSX universal binary DMG.
|
||||||
|
|
||||||
The quickest way to build aria2 is first run configure script::
|
The quickest way to build aria2 is first run configure script::
|
||||||
|
|
||||||
|
@ -220,11 +230,12 @@ After configuration is done, run ``make`` to compile the program::
|
||||||
|
|
||||||
$ make
|
$ make
|
||||||
|
|
||||||
See `Cross-compiling Windows binary`_ to create Windows binary. See
|
See `Cross-compiling Windows binary`_ to create a Windows binary.
|
||||||
`Cross-compiling Android binary`_ to create Android binary.
|
See `Cross-compiling Android binary`_ to create an Android binary.
|
||||||
|
|
||||||
The configure script checks available libraries and enables the features
|
The configure script checks available libraries and enables as many
|
||||||
as much as possible because all the features are enabled by default.
|
features as possible execept for experimental features not enabled by
|
||||||
|
default.
|
||||||
|
|
||||||
Since 1.1.0, aria2 checks the certificate of HTTPS servers by default.
|
Since 1.1.0, aria2 checks the certificate of HTTPS servers by default.
|
||||||
If you build with OpenSSL or the recent version of GnuTLS which has
|
If you build with OpenSSL or the recent version of GnuTLS which has
|
||||||
|
@ -247,12 +258,17 @@ using aria2's ``--ca-certificate`` option. If you don't have CA bundle
|
||||||
file installed, then the last resort is disable the certificate
|
file installed, then the last resort is disable the certificate
|
||||||
validation using ``--check-certificate=false``.
|
validation using ``--check-certificate=false``.
|
||||||
|
|
||||||
By default, bash_completion file named ``aria2c`` is installed to the
|
Using the native OSX (AppleTLS) and/or Windows (WinTLS) implementation
|
||||||
directory ``$prefix/share/doc/aria2/bash_completion``. To change the
|
will automatically use the system certificate store, so
|
||||||
install directory of the file, use ``--with-bashcompletiondir``
|
``--with-ca-bundle`` is not necessary and will be ignored when using
|
||||||
|
these implementations.
|
||||||
|
|
||||||
|
By default, the bash_completion file named ``aria2c`` is installed to
|
||||||
|
the directory ``$prefix/share/doc/aria2/bash_completion``. To change
|
||||||
|
the install directory of the file, use ``--with-bashcompletiondir``
|
||||||
option.
|
option.
|
||||||
|
|
||||||
The executable is 'aria2c' in src directory.
|
After a ``make`` the executable is located at ``src/aria2c``.
|
||||||
|
|
||||||
aria2 uses CppUnit for automated unit testing. To run the unit test::
|
aria2 uses CppUnit for automated unit testing. To run the unit test::
|
||||||
|
|
||||||
|
@ -261,8 +277,8 @@ aria2 uses CppUnit for automated unit testing. To run the unit test::
|
||||||
Cross-compiling Windows binary
|
Cross-compiling Windows binary
|
||||||
------------------------------
|
------------------------------
|
||||||
|
|
||||||
In this section, we describe how to build Windows binary using
|
In this section, we describe how to build a Windows binary using
|
||||||
mingw-w64 cross-compiler on Debian Linux.
|
a mingw-w64 cross-compiler on Debian Linux.
|
||||||
|
|
||||||
Basically, after compiling and installing depended libraries, you can
|
Basically, after compiling and installing depended libraries, you can
|
||||||
do cross-compile just passing appropriate ``--host`` option and
|
do cross-compile just passing appropriate ``--host`` option and
|
||||||
|
@ -368,8 +384,8 @@ translation <http://aria2.sourceforge.net/manual/ru/html/>`_,
|
||||||
BitTorrrent
|
BitTorrrent
|
||||||
-----------
|
-----------
|
||||||
|
|
||||||
About filename
|
About filenames
|
||||||
~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~
|
||||||
The filename of the downloaded file is determined as follows:
|
The filename of the downloaded file is determined as follows:
|
||||||
|
|
||||||
single-file mode
|
single-file mode
|
||||||
|
@ -426,8 +442,8 @@ Metalink
|
||||||
--------
|
--------
|
||||||
|
|
||||||
The current implementation supports HTTP(S)/FTP/BitTorrent. The other
|
The current implementation supports HTTP(S)/FTP/BitTorrent. The other
|
||||||
P2P protocols are ignored. Both Metalink4 and Metalink version 3.0
|
P2P protocols are ignored. Both Metalink4 (RFC 5854) and Metalink
|
||||||
documents are supported.
|
version 3.0 documents are supported.
|
||||||
|
|
||||||
For checksum verification, md5, sha-1, sha-224, sha-256, sha-384 and
|
For checksum verification, md5, sha-1, sha-224, sha-256, sha-384 and
|
||||||
sha-512 are supported. If multiple hash algorithms are provided, aria2
|
sha-512 are supported. If multiple hash algorithms are provided, aria2
|
||||||
|
|
|
@ -372,8 +372,9 @@ HTTP Specific Options
|
||||||
*AppleTLS* users should use the Keychain Access utility to import the client
|
*AppleTLS* users should use the Keychain Access utility to import the client
|
||||||
certificate and get the SHA-1 fingerprint from the Information dialog
|
certificate and get the SHA-1 fingerprint from the Information dialog
|
||||||
corresponding to that certificate.
|
corresponding to that certificate.
|
||||||
To start aria2c use `--certificate=<SHA-1>` and just omit the
|
To start aria2c use `--certificate=<SHA-1>`.
|
||||||
:option:`--private-key` option.
|
Alternatively PKCS12 files are also supported. PEM files, however, are not
|
||||||
|
supported.
|
||||||
|
|
||||||
.. option:: --check-certificate[=true|false]
|
.. option:: --check-certificate[=true|false]
|
||||||
|
|
||||||
|
@ -964,8 +965,9 @@ RPC Options
|
||||||
SHA-1 fingerprint from the Information dialog corresponding to that new
|
SHA-1 fingerprint from the Information dialog corresponding to that new
|
||||||
certificate.
|
certificate.
|
||||||
To start aria2c with :option:`--rpc-secure` use
|
To start aria2c with :option:`--rpc-secure` use
|
||||||
`--rpc-certificate=<SHA-1>` and just omit the :option:`--rpc-private-key`
|
`--rpc-certificate=<SHA-1>`.
|
||||||
option.
|
Alternatively PKCS12 files are also supported. PEM files, however, are not
|
||||||
|
supported.
|
||||||
|
|
||||||
.. option:: --rpc-listen-all[=true|false]
|
.. option:: --rpc-listen-all[=true|false]
|
||||||
|
|
||||||
|
@ -3796,6 +3798,20 @@ Resume download started by web browsers or another programs
|
||||||
|
|
||||||
Client certificate authorization for SSL/TLS
|
Client certificate authorization for SSL/TLS
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
Specify a PKCS12 file as follows:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ aria2c --certificate=/path/to/mycert.p12
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
The file specified in :option:`--certificate` must be contain one PKCS12 encoded
|
||||||
|
certificate and key. The password must be blank.
|
||||||
|
|
||||||
|
Alternatively, if PEM files are supported, use a command like the following:
|
||||||
|
|
||||||
.. code-block:: console
|
.. code-block:: console
|
||||||
|
|
||||||
$ aria2c --certificate=/path/to/mycert.pem --private-key=/path/to/mykey.pem https://host/file
|
$ aria2c --certificate=/path/to/mycert.pem --private-key=/path/to/mykey.pem https://host/file
|
||||||
|
@ -3817,7 +3833,18 @@ RPC
|
||||||
Encrypt RPC transport by SSL/TLS
|
Encrypt RPC transport by SSL/TLS
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
Specify server certificate file and private key file as follows:
|
Specify server PKC12 file:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ aria2c --enable-rpc --rpc-certificate=/path/to/server.p12 --rpc-secure
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
The file specified in :option:`--rpc-certificate` must be contain one PKCS12 encoded
|
||||||
|
certificate and key. The password must be blank.
|
||||||
|
|
||||||
|
Alternatively when PEM files are supported, specify the server certificate file and private key file as follows:
|
||||||
|
|
||||||
.. code-block:: console
|
.. code-block:: console
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue