mirror of
https://github.com/servalproject/serval-dna.git
synced 2025-01-01 19:06:43 +00:00
301 lines
13 KiB
Markdown
301 lines
13 KiB
Markdown
Notes for Serval DNA Developers
|
|
===============================
|
|
[Serval Project][], September 2016
|
|
|
|
Introduction
|
|
------------
|
|
|
|
This document is intended for all developers of [Serval DNA][], and also for
|
|
non-developers who are experiencing errors in the [build][] process.
|
|
|
|
Autoconf
|
|
--------
|
|
|
|
The [configure.ac](../configure.ac) file is an [autoconf][] script that
|
|
contains instructions for adapting the build of Serval DNA to different
|
|
platforms and CPU architectures. This script makes use of many [GNU M4][]
|
|
macros, each of which tests an aspect of the build environment, such as the
|
|
make and version of the C compiler (eg, [GCC][], [Clang][]), the availability
|
|
of headers, functions and system calls in the standard library, and so forth.
|
|
|
|
Most of these M4 macros are standard, either supplied with [autoconf][] or from
|
|
the [autoconf macro archive][]. Some macros are specific to Serval DNA, either
|
|
to improve on a standard macro or perform a test for which no standard macro
|
|
exists. These extra macros are locally defined in files within the [m4](../m4)
|
|
sub-directory.
|
|
|
|
The [autoreconf][] command used in the [build][] instructions generates an
|
|
`aclocal.m4` file that includes all the necessary files from the [m4](../m4)
|
|
directory. In turn, it then includes this `aclocal.m4` file when invoking [GNU
|
|
M4][] to convert the [configure.ac](../configure.ac) file into the
|
|
`./configure` script.
|
|
|
|
Internally, [autoconf][] generates the `aclocal.m4` file by invoking the
|
|
[aclocal][] utility. Used without arguments, [aclocal][] may emit some warning
|
|
messages that look like this:
|
|
|
|
$ cd serval-dna
|
|
$ aclocal
|
|
configure.ac:18: warning: Unsupported attribute section, the test may fail
|
|
../../lib/autoconf/lang.m4:224: AC_LANG_SOURCE is expanded from...
|
|
../../lib/autoconf/lang.m4:241: AC_LANG_PROGRAM is expanded from...
|
|
../../lib/autoconf/lang.m4:193: AC_LANG_CONFTEST is expanded from...
|
|
../../lib/autoconf/general.m4:2672: _AC_LINK_IFELSE is expanded from...
|
|
../../lib/autoconf/general.m4:2689: AC_LINK_IFELSE is expanded from...
|
|
../../lib/m4sugar/m4sh.m4:639: AS_IF is expanded from...
|
|
../../lib/autoconf/general.m4:2042: AC_CACHE_VAL is expanded from...
|
|
../../lib/autoconf/general.m4:2063: AC_CACHE_CHECK is expanded from...
|
|
/usr/share/aclocal/ax_gcc_var_attribute.m4:57: AX_GCC_VAR_ATTRIBUTE is expanded from...
|
|
configure.ac:18: the top level
|
|
$
|
|
|
|
These messages are harmless; the correct `aclocal.m4` is still generated. To
|
|
suppress most of these messages from the output of [aclocal][] and
|
|
[autoreconf][], give the `-I m4` option:
|
|
|
|
$ cd serval-dna
|
|
$ autoreconf -f -i -I m4
|
|
$
|
|
|
|
libsodium
|
|
---------
|
|
|
|
**Libsodium** is the cryptographic library that [Serval DNA][] uses for all its
|
|
encryption, authentication and secure hashing.
|
|
|
|
[libsodium][] is a portable, cross-compilable fork of [NaCl][], with a
|
|
compatible API. The design choices in NaCl-libsodium, particularly in regard
|
|
to the [Curve25519][] Diffie-Hellman function, emphasise security, and the
|
|
“magic constants" in NaCl-libsodium have clear rationales. By contrast, the
|
|
[NIST][] standard curves emphasise “performance" at the cost of security and do
|
|
not describe the specific origins of certain constants. Despite the emphasis
|
|
on higher security, NaCl-libsodium primitives are faster across-the-board than
|
|
most implementations of the NIST standards.
|
|
|
|
* In order to [build][] Serval DNA, the libsodium development files must be
|
|
available, such as the source header file `<sodium.h>` and the static
|
|
library `libsodium.a`.
|
|
|
|
* In order to **run** Serval DNA, the libsodium run-time files must be
|
|
available, such as the dynamic library `libsodium.so`.
|
|
|
|
### libsodium-dev
|
|
|
|
On systems that provide a libsodium development package, simply install that
|
|
package. For example, on [Debian][] and [Ubuntu][]:
|
|
|
|
$ sudo apt-get install libsodium-dev
|
|
Reading package lists... Done
|
|
Building dependency tree
|
|
Reading state information... Done
|
|
The following NEW packages will be installed:
|
|
libsodium-dev
|
|
0 upgraded, 1 newly installed, 0 to remove and 0 not upgraded.
|
|
Selecting previously unselected package libsodium-dev:amd64.
|
|
(Reading database ... 223406 files and directories currently installed.)
|
|
Preparing to unpack .../libsodium-dev_1.0.11-1_amd64.deb ...
|
|
Unpacking libsodium-dev:amd64 (1.0.11-1) ...
|
|
Setting up libsodium-dev:amd64 (1.0.11-1) ...
|
|
$
|
|
|
|
### build-libsodium.sh
|
|
|
|
On systems that do not provide a libsodium development package (even though
|
|
they may provide a run-time package), such as [Mac OS X](#apple-mac-os-x), the
|
|
libsodium development files can be locally installed by downloading the
|
|
[libsodium source code][] and building it. The
|
|
[build-libsodium.sh](../build-libsodium.sh) script will do this:
|
|
|
|
$ ./build-libsodium.sh
|
|
...
|
|
The libsodium run-time and development files have been installed in:
|
|
/absolute/path/name/serval-dna/libsodium
|
|
|
|
To use this installation of libsodium, set up the environment using the
|
|
shell's "dot" command to source its settings.sh script, for example:
|
|
|
|
. libsodium/settings.sh ; ./configure
|
|
|
|
$
|
|
|
|
In the event of failure, check that:
|
|
|
|
* the [github.com][libsodium source code] web site can be reached
|
|
* there is at least 60 MB of available disk space
|
|
* there is no other libsodium development package already installed
|
|
|
|
For more information, refer to the [libsodium installation documentation][]
|
|
and the script's help message:
|
|
|
|
$ ./build-libsodium.sh --help
|
|
...
|
|
$
|
|
|
|
Debian/Ubuntu
|
|
-------------
|
|
|
|
A single [apt-get][] command will install all mandatory and testing
|
|
dependencies before building on [Debian][] and [Ubuntu][] systems:
|
|
|
|
$ sudo apt-get --yes install libc6-dev libsodium-dev jq curl
|
|
Reading package lists... Done
|
|
Building dependency tree
|
|
Reading state information... Done
|
|
libc6-dev is already the newest version (2.23-5).
|
|
The following NEW packages will be installed:
|
|
curl jq libsodium-dev
|
|
0 upgraded, 3 newly installed, 0 to remove and 0 not upgraded.
|
|
Need to get 544 kB of archives.
|
|
After this operation, 1,683 kB of additional disk space will be used.
|
|
Get:1 http://ftp.us.debian.org/debian testing/main amd64 curl amd64 7.50.1-1 [218 kB]
|
|
Get:2 http://ftp.us.debian.org/debian testing/main amd64 jq amd64 1.5+dfsg-1 [156 kB]
|
|
Get:3 http://ftp.us.debian.org/debian testing/main amd64 libsodium-dev amd64 1.0.11-1 [170 kB]
|
|
Fetched 544 kB in 1s (304 kB/s)
|
|
Selecting previously unselected package curl.
|
|
(Reading database ... 205089 files and directories currently installed.)
|
|
Preparing to unpack .../0-curl_7.50.1-1_amd64.deb ...
|
|
Unpacking curl (7.50.1-1) ...
|
|
Selecting previously unselected package jq.
|
|
Preparing to unpack .../1-jq_1.5+dfsg-1_amd64.deb ...
|
|
Unpacking jq (1.5+dfsg-1) ...
|
|
Selecting previously unselected package libsodium-dev:amd64.
|
|
Preparing to unpack .../2-libsodium-dev_1.0.11-1_amd64.deb ...
|
|
Unpacking libsodium-dev:amd64 (1.0.11-1) ...
|
|
Setting up jq (1.5+dfsg-1) ...
|
|
Setting up curl (7.50.1-1) ...
|
|
Setting up libsodium-dev:amd64 (1.0.11-1) ...
|
|
Processing triggers for man-db (2.7.5-1) ...
|
|
$
|
|
|
|
Apple Mac OS X
|
|
--------------
|
|
|
|
### libsodium for OS X
|
|
|
|
Although the [libsodium][] package is available for Mac OS X using the
|
|
[homebrew][] package manager, that package only provides the run-time library,
|
|
not the development files; for example, it does not provide the `#include
|
|
<sodium.h>` header.
|
|
|
|
The libsodium development files can be installed locally on Mac OS X using the
|
|
[build-libsodium.sh](#build-libsodiumsh) script.
|
|
|
|
### Test utilities
|
|
|
|
The [OS X grep(1)][] , [OS X sed(1)][] and [OS X awk(1)][] tools provided by
|
|
Apple Mac OS X are the BSD variants. The test scripts require the GNU variants
|
|
with the names *ggrep*, *gsed* and *gawk*, which can be installed on Mac OS X
|
|
using the [homebrew][] package manager:
|
|
|
|
$ brew tap homebrew/dupes
|
|
==> Tapping homebrew/dupes
|
|
Cloning into '/usr/local/Library/Taps/homebrew/homebrew-dupes'...
|
|
remote: Counting objects: 42, done.
|
|
remote: Compressing objects: 100% (42/42), done.
|
|
remote: Total 42 (delta 0), reused 3 (delta 0), pack-reused 0
|
|
Unpacking objects: 100% (42/42), done.
|
|
Checking connectivity... done.
|
|
Tapped 38 formulae (103 files, 120.0K)
|
|
|
|
$ brew install grep
|
|
==> Installing grep from homebrew/dupes
|
|
==> Installing dependencies for homebrew/dupes/grep: pcre
|
|
==> Installing homebrew/dupes/grep dependency: pcre
|
|
==> Downloading https://homebrew.bintray.com/bottles/pcre-8.38.el_capitan.bottle.tar.gz
|
|
==> Pouring pcre-8.38.el_capitan.bottle.tar.gz
|
|
/usr/local/Cellar/pcre/8.38: 146 files, 5.4M
|
|
==> Installing homebrew/dupes/grep
|
|
==> Downloading https://homebrew.bintray.com/bottles-dupes/grep-2.22.el_capitan.bottle.tar.gz
|
|
==> Pouring grep-2.22.el_capitan.bottle.tar.gz
|
|
==> Caveats
|
|
The command has been installed with the prefix "g".
|
|
If you do not want the prefix, install using the "with-default-names" option.
|
|
==> Summary
|
|
/usr/local/Cellar/grep/2.22: 14 files, 756.5K
|
|
|
|
$ brew install gnu-sed
|
|
==> Downloading https://homebrew.bintray.com/bottles/gnu-sed-4.2.2.el_capitan.bottle.2.tar.gz
|
|
==> Pouring gnu-sed-4.2.2.el_capitan.bottle.2.tar.gz
|
|
tar: Failed to set default locale
|
|
==> Caveats
|
|
The command has been installed with the prefix "g".
|
|
If you do not want the prefix, install using the "with-default-names" option.
|
|
If you need to use these commands with their normal names, you
|
|
can add a "gnubin" directory to your PATH from your bashrc like:
|
|
PATH="/usr/local/opt/gnu-sed/libexec/gnubin:$PATH"
|
|
Additionally, you can access their man pages with normal names if you add
|
|
the "gnuman" directory to your MANPATH from your bashrc as well:
|
|
MANPATH="/usr/local/opt/gnu-sed/libexec/gnuman:$MANPATH"
|
|
==> Summary
|
|
/usr/local/Cellar/gnu-sed/4.2.2: 9 files, 452K
|
|
|
|
$ brew install gawk
|
|
==> Downloading https://homebrew.bintray.com/bottles/gawk-4.1.3.el_capitan.bottle.tar.gz
|
|
==> Pouring gawk-4.1.3.el_capitan.bottle.tar.gz
|
|
/usr/local/Cellar/gawk/4.1.3: 63 files, 3.2M
|
|
|
|
$
|
|
|
|
The [jq(1)][] tool is not provided by Apple Mac OS X, so it must be installed
|
|
using the [homebrew][] package manager:
|
|
|
|
$ brew install jq
|
|
==> Installing dependencies for jq: oniguruma
|
|
==> Installing jq dependency: oniguruma
|
|
==> Downloading https://homebrew.bintray.com/bottles/oniguruma-6.1.1.el_capitan.bottle.tag.gz
|
|
==> Pouring oniguruma-6.1.1.el_capitan.bottle.tag.gz
|
|
/usr/local/Cellar/oniguruma/6.1.1: 16 files, 1.3M
|
|
==> Installing jq
|
|
==> Downloading https://homebrew.bintray.com/bottles/jq-1.5_2.el_capitan.bottle.tag.gz
|
|
==> Pouring jq-1.5_2.el_capitan.bottle.tag.gz
|
|
/usr/local/Cellar/jq/1.5_2: 18 files, 958K
|
|
$
|
|
|
|
About the examples
|
|
------------------
|
|
|
|
The examples in this document are [Bourne shell][] commands, using standard
|
|
quoting and variable expansion. Commands issued by the user are prefixed with
|
|
the shell prompt `$` to distinguish them from the output of the command.
|
|
Single and double quotes around arguments are part of the shell syntax, so are
|
|
not seen by the command. Lines ending in backslash `\` continue the command on
|
|
the next line.
|
|
|
|
The directory paths used in the examples are for illustrative purposes only,
|
|
and may need to be changed for your particular circumstances.
|
|
|
|
-----
|
|
**Copyright 2015 Serval Project Inc.**
|
|
**Copyright 2016 Flinders University**
|
|
![CC-BY-4.0](./cc-by-4.0.png)
|
|
Available under the [Creative Commons Attribution 4.0 International licence][CC BY 4.0].
|
|
|
|
|
|
[Serval Project]: http://www.servalproject.org/
|
|
[CC BY 4.0]: ../LICENSE-DOCUMENTATION.md
|
|
[Serval DNA]: ../README.md
|
|
[build]: ../INSTALL.md
|
|
[autoconf]: http://www.gnu.org/software/autoconf/autoconf.html
|
|
[autoconf macro archive]: http://www.gnu.org/software/autoconf-archive/
|
|
[GNU M4]: http://www.gnu.org/software/m4/m4.html
|
|
[GCC]: https://gcc.gnu.org/
|
|
[Clang]: http://clang.llvm.org/
|
|
[NaCl]: https://nacl.cr.yp.to/
|
|
[NIST]: https://en.wikipedia.org/wiki/National_Institute_of_Standards_and_Technology
|
|
[Curve25519]: https://en.wikipedia.org/wiki/Curve25519
|
|
[build]: ../INSTALL.md
|
|
[aclocal]: https://www.gnu.org/software/automake/manual/html_node/aclocal-Invocation.html
|
|
[autoreconf]: https://www.gnu.org/savannah-checkouts/gnu/autoconf/manual/autoconf.html#autoreconf-Invocation
|
|
[Debian]: http://www.debian.org/
|
|
[Ubuntu]: http://www.ubuntu.com/
|
|
[libsodium]: https://download.libsodium.org/doc/
|
|
[libsodium source code]: https://github.com/jedisct1/libsodium
|
|
[libsodium installation documentation]: https://download.libsodium.org/libsodium/content/installation/
|
|
[apt-get]: https://www.debian.org/doc/manuals/apt-guide/ch2.en.html
|
|
[OS X grep(1)]: https://developer.apple.com/library/mac/documentation/Darwin/Reference/ManPages/man1/grep.1.html
|
|
[OS X sed(1)]: https://developer.apple.com/library/mac/documentation/Darwin/Reference/ManPages/man1/sed.1.html
|
|
[OS X awk(1)]: https://developer.apple.com/library/mac/documentation/Darwin/Reference/ManPages/man1/awk.1.html
|
|
[jq(1)]: https://stedolan.github.io/jq/
|
|
[homebrew]: http://brew.sh/
|
|
[Bourne shell]: http://en.wikipedia.org/wiki/Bourne_shell
|