Download and Release Information
DACS software is available at no cost.
It is officially distributed in source form only - you must build it,
although in most cases this is not difficult.
A Debian GNU/Linux release of DACS is
available, however.
DSS does not prepare or manage that distribution.
Please refer to the license for details and
copyright notices.
Starting with version 1.4.26, DACS is
not available on SourceForge - get it from the links in the
table below.
Releases prior to 1.4.26 may be available as
tarballs
on
SourceForge.net.
Important release notes, change summaries,
and post-release notifications are posted on this page,
and when a significant bug is found after release, we will
post a notice here, sometimes with a solution.
Please review this information before installing
DACS or if you are
experiencing any problems with DACS.
We apologize for any inconvenience and try to fix all known bugs
in the next release.
Patches and bug fix releases are sometimes available - please inquire.
Information that appears here about older releases may be superseded
by changes made in newer releases; this also applies to such things as the
renaming of programs and files.
A bug reported for a specific release may also be present in earlier releases.
As mentioned elsewhere,
we like to think that development of DACS
is guided largely by the needs of its users,
so we need your input
to do a good job!
Your requests and suggestions are important for us to continue to focus
our efforts on solving problems that are important to you.
We do not require you to register your copy of
DACS, but we would appreciate
hearing from you
if you decide to use it.
The anonymous information you provide can help us to focus development and
will be taken into account when we consider making changes,
particularly changes that are incompatible with earlier releases.
IMPORTANT
DACS MAY USE AND IMPLEMENT CRYPTOGRAPHIC FUNCTIONALITY.
Although DACS is developed, maintained,
and distributed from Canada, it may
fall under certain import, export, and/or use restrictions in other parts of
the world.
DACS may implement or adapt ad hoc,
enhanced, standardized,
or published cryptographic algorithms, or use cryptographic functionality
provided by OpenSSL,
other third-party software, or
operating system libraries and system calls.
Export and/or import and/or use of strong cryptography software, providing
cryptography hooks, or merely communicating technical details about
cryptographic software is illegal in some parts of the world.
YOU ARE STRONGLY ADVISED
to pay close attention to any laws that may apply when you import,
export, or use DACS,
or even communicate about it.
We are not liable for any violations you make - it is your responsibility.
For additional information, see the
Crypto Law Survey.
What You Need
To build DACS, at minimum you will need the
following:
- A recent release of one of the officially supported platforms:
FreeBSD, GNU/Linux, or macOS
- GNU make (gmake) and GCC (or Clang)
- Third-party software: Apache 2.4, OpenSSL, and Expat
If you require certain optional features,
you may need to obtain additional (open source licensed) third-party software,
such as OpenLDAP or Berkeley DB.
Sometimes this software is already installed on your system.
Please see
dacs.install(7) for details.
Bugs and Support
If you are having a problem with DACS,
after first reviewing the release notes and post-release notes for your version,
the next thing to do is check your DACS log files
and Apache log files (you may need to bump up your logging level to get
additional information as to what is happening).
You should also consult the FAQ
and Tips.
Whenever possible, you should always run the latest release of
DACS and check that you are compiling with
the correct version of third-party software.
Please see the support area
for information on reporting bugs and other assistance.
Technical support and maintenance packages are available.
Downloads and Release History
To unpack a tarball into a subdirectory named after the tarball file
with the extension removed,
- For a .tgz tarball, (e.g., dacs-1.4.52.tgz):
% gunzip < dacs-1.4.52.tgz | tar -xf -
- For a .tbz tarball (e.g., dacs-1.4.52.tbz):
% bunzip2 < dacs-1.4.52.tbz | tar -xf -
- For a .txz tarball, (e.g., dacs-1.4.52.txz):
% unxz < dacs-1.4.52.txz | tar -xf -
The decompression commands should be available on practically all platforms
that are suitable for building DACS.
To generate checksums for your downloaded tarball to compare against the
values published here, the following commands are either already available
on your system or can be easily obtained:
- For MD5: "openssl dgst -md5", md5, md5sum, "rhash --md5"
- For SHA-1: "openssl dgst -sha1", sha1, sha1sum, "rhash --sha1"
- For SHA3-256: "openssl dgst -sha3-256", "sha3sum -a 256", "rhash --sha3-256"
For instance:
% openssl dgst -sha1 dacs-1.4.52.tbz
SHA1(dacs-1.4.52.tbz)= cda55e1b691e3d7210c9cbf18eaf1337f96c0b2b
If your system does not have a utility for computing SHA3 digests,
the functionality is provided by the latest release of OpenSSL.
Also, the Perl Digest::SHA3 module provides the sha3sum
command
(which you may be able to install using the cpan command):
% openssl dgst -sha3-256 dacs-1.4.52.tbz
SHA3-256(dacs-1.4.52.tbz)= df5156421ee41c2fa44fc7cc16e7cfea0e41d5e384d761a600ef688a25321eb7
% sha3sum -a 256 dacs-1.4.52.tbz
df5156421ee41c2fa44fc7cc16e7cfea0e41d5e384d761a600ef688a25321eb7 dacs-1.4.52.tbz
Release Name |
Release Date |
Release Info |
Tarballs
File Name |
Bytes |
|
Checksums |
|
1.4.52 |
24-Sep-2024 |
README,
Notes,
Changes,
Post-Release |
|
1.4.51 |
20-Jun-2024 |
README,
Notes,
Changes,
Post-Release |
|
1.4.50 |
22-Jul-2023 |
README,
Notes,
Changes,
Post-Release |
|
1.4.49 |
8-Feb-2023 |
README,
Notes,
Changes,
Post-Release |
|
1.4.48 |
20-Jul-2022 |
README,
Notes,
Changes,
Post-Release |
|
1.4.47 |
11-Jan-2022 |
README,
Notes,
Changes,
Post-Release |
|
1.4.46 |
8-Jun-2021 |
README,
Notes,
Changes,
Post-Release |
|
1.4.45 |
20-Jan-2021 |
README,
Notes,
Changes,
Post-Release |
|
1.4.44 |
28-May-2020 |
README,
Notes,
Changes,
Post-Release |
|
1.4.43 |
20-Sep-2019 |
README,
Notes,
Changes,
Post-Release |
|
1.4.42 |
29-Jan-2019 |
README,
Notes,
Changes,
Post-Release |
|
1.4.41 |
12-Sep-2018 |
README,
Notes,
Changes,
Post-Release |
|
1.4.40 |
1-Feb-2018 |
README,
Notes,
Changes,
Post-Release |
|
1.4.39 |
26-May-2017 |
README,
Notes,
Changes,
Post-Release |
|
1.4.38a |
23-Nov-2016 |
README,
Notes,
Changes,
Post-Release |
|
1.4.38 |
21-Oct-2016 |
README,
Notes,
Changes,
Post-Release |
|
1.4.37 |
18-May-2016 |
README,
Notes,
Changes,
Post-Release |
|
1.4.36 |
29-Dec-2015 |
README,
Notes,
Changes,
Post-Release |
|
1.4.35 |
26-Aug-2015 |
README,
Notes,
Changes,
Post-Release |
|
1.4.34 |
24-Jul-2015 |
README,
Notes,
Changes,
Post-Release |
|
1.4.33 |
4-Mar-2015 |
README,
Notes,
Changes,
Post-Release |
|
1.4.32 |
6-Jan-2015 |
README,
Notes,
Changes,
Post-Release |
|
1.4.31 |
15-Sept-2014 |
README,
Notes,
Changes,
Post-Release |
|
1.4.30 |
7-July-2014 |
README,
Notes,
Changes,
Post-Release |
|
1.4.29 |
30-Oct-2013 |
README,
Notes,
Changes,
Post-Release |
|
1.4.28b |
1-Mar-2013 |
README,
Notes,
Changes,
Post-Release |
|
1.4.28a |
29-Jan-2013 |
README,
Notes,
Changes,
Post-Release |
|
1.4.28 |
23-Oct-2012 |
README,
Notes,
Changes,
Post-Release |
|
1.4.27b |
19-Mar-2012 |
README,
Notes,
Changes,
Post-Release |
|
1.4.27 |
16-Jan-2012 |
README,
Notes,
Changes,
Post-Release |
|
1.4.26 |
30-Sep-2011 |
README,
Notes,
Changes,
Post-Release |
|
1.4.25 |
23-Jun-2010 |
Notes,
Changes,
Post-Release,
Patch |
|
1.4.24 |
7-Jan-2010 |
Notes,
Changes,
Post-Release |
|
1.4.23a |
16-Oct-09 |
Notes,
Changes,
Post-Release |
|
1.4.23 |
14-Sep-09 |
Notes,
Changes,
Post-Release |
|
1.4.22 |
13-Jan-09 |
Notes,
Changes,
Post-Release |
|
1.4.21 |
31-Mar-08 |
Notes,
Changes,
Post-Release |
|
1.4.20 |
15-Aug-07 |
Notes,
Changes,
Post-Release |
|
1.4.19* |
2-Jul-07 |
Notes,
Changes,
Post-Release |
|
1.4.18 |
4-Apr-07 |
Notes,
Changes,
Post-Release |
|
1.4.17 |
8-Feb-07 |
Notes,
Changes,
Post-Release |
|
1.4.16 |
4-Dec-06 |
Notes,
Changes,
Post-Release |
|
1.4.15 |
1-Oct-06 |
Notes,
Changes,
Post-Release |
|
1.4.14 |
1-Aug-06 |
Notes,
Changes,
Post-Release |
|
1.4.13a |
2-Jun-06 |
Notes,
Changes,
Post-Release |
|
1.4.13 |
1-Jun-06 |
Notes,
Changes,
Post-Release |
|
1.4.12 |
1-May-06 |
Notes,
Changes,
Post-Release |
|
1.4.11 |
9-Mar-06 |
Notes,
Changes,
Post-Release |
|
1.4.10 |
26-Jan-06 |
Notes,
Changes,
Post-Release |
|
1.4.9 |
24-Dec-05 |
Notes,
Changes,
Post-Release |
|
1.4.8 |
18-Nov-05 |
Notes,
Changes,
Post-Release |
|
1.4.7 |
20-Oct-05 |
Notes,
Changes,
Post-Release |
|
1.4.6 |
20-Sep-05 |
|
|
1.4.5 |
17-Aug-05 |
|
|
1.4.4 |
22-Jun-05 |
|
|
1.4.3 |
27-May-05 |
|
|
1.4.2 |
14-Apr-05 |
|
|
1.4.1 |
16-Mar-05 |
|
|
1.4.0 |
14-Feb-05 |
|
|
DACS Version 1.4.52
Release Notes
This release has upgrades for platforms and third-party support packages,
and minor bug fixes and improvements.
It also includes a beta version of jspr,
a JSON parser/validator/analyser library
("JSon ParseR" -- "Jaspar" -- jspr).
While it is being actively developed,
updated versions of jspr will be made available separately
and more frequently than DACS releases.
Change Summary
- Third-party supporting library upgrades:
apache-2.4.62 (with apr-1.7.5, apr-util-1.6.3), OpenSSL 3.2.3,
expat-2.6.3, libtasn1-4.19.0, libiconv-1.17,
openldap-2.6.8, sqlite-3.46.1
- Platform upgrades:
FreeBSD 14.1, macOS Sequoia 15.0
- In dacs.exprs, added "base64" and "base64url" algorithms, with tests
- Fixed ChaCha and Speck issues that might occur with certain
compiler optimizations enabled
Post-Release Notes
DACS Version 1.4.51
Release Notes
This release includes a few new minor features, upgrades for platforms
and third-party support packages, and minor bug fixes and improvements.
Change Summary
- Third-party supporting library upgrades:
apache-2.4.59 (with apr-1.7.4, apr-util-1.6.3), OpenSSL 3.2.2,
expat-2.6.2, libtasn1-4.19.0, libiconv-1.17,
openldap-2.6.8, sqlite-3.46.0
- Platform upgrades:
FreeBSD 14.0, CentOS kernel-3.10.0-1160.119.1.el7.x86_64, macOS 14.5
- Added Argon2_id memory-hard hash function, with tests
- Additional crypto algorithm tests
- new
ACS_CREDENTIALS_INVALID_BEFORE_DATETIME
and
ACS_CREDENTIALS_LIFETIME_SECS
configuration directives
- dacstoken(1) relaxes its base32
padding rules for decoding with -ignore-key-length.
This is useful when dealing with keys exported by some authenticator apps.
- Added
eprint()
and
eprintf()
functions for expressions to write to stderr
Post-Release Notes
DACS Version 1.4.50
Release Notes
This release contains upgrades for platforms and third-party support packages
and minor bug fixes and improvements.
Change Summary
- Third-party supporting library upgrades:
apache-2.4.57 (with apr-1.7.4, apr-util-1.6.3), OpenSSL 1.1.1u,
openldap-2.6.5, sqlite-3.42.0
- Platform upgrades:
CentOS 3.10.0-1160.80.1.el7.x86_64, macOS Ventura 13.4.1, FreeBSD 13.2
-
Initial support for OpenSSL 3.1 libraries (not well tested, should not
yet be used in production deployments)
Post-Release Notes
DACS Version 1.4.49
Release Notes
This release contains upgrades for platforms and third-party support packages
and minor bug fixes and improvements.
Change Summary
- Third-party supporting library upgrades:
expat-2.5.0, OpenLDAP 2.6.3, sqlite-3.40.1,
apache-2.4.55, openssl-1.1.1t
- Platform upgrades:
macOS Monterey 13.2 (Apple M1/arm64e architecture)
Post-Release Notes
- For the macOS/arm64 platform, when building DACS
it appears to be necessary to add
--build=arm64-apple-darwin
when running configure.
- Configuration issues may prevent dacs_glob.c from
compiling on macOS. These will be fixed in the next release but
until then patches are available upon request.
DACS Version 1.4.48
Release Notes
This release contains upgrades for platforms and third-party support packages
and minor bug fixes and improvements.
Change Summary
- Third-party supporting library upgrades:
expat-2.4.8, OpenLDAP 2.6.2, gdbm 1.23-pl0, sqlite-3.39.0,
apache-2.4.54, openssl-1.1.1q
- Platform upgrades:
FreeBSD 13.1,
macOS Monterey 12.4 (changed from Intel i7 to Apple M1/arm64e architecture),
CentOS Linux release 7.9.2009 (3.10.0-1160.66.1.el7.x86_64)
- Partial implementation of support for OpenSSL 3.X
- Modernized autoconf macros
Post-Release Notes
Unfortunately, some difficulties were encountered at the last minute
when building on the new macOS (Monterey) arm64/M1 platform.
Hopefully these issues will be resolved in the next release of DACS.
- Was unable to build openldap-2.4.56 for this release of DACS
- When building OpenSSL, use:
./Configure darwin64-arm64-cc ...
- When building Berkeley DB, use:
../dist/configure --enable-posixmutexes ...
- When building DACS,
the ac_cv_build variable in src/configure
may need to be forced to "arm64-apple-darwin21.5.0"
because the normal autoconf generated configuration failed
DACS Version 1.4.47
Release Notes
This release contains upgrades for platforms and third-party support packages
and minor bug fixes and improvements.
Change Summary
- Third-party supporting library upgrades:
Apache 2.4.52 (with apr-1.7.0 and apr-util-1.6.1), sqlite-3.37.0,
expat-2.4.2, openssl-1.1.1m, openldap-2.6.0, gdbm 1.22-pl0
- Platform upgrades:
CentOS Linux release 7.9.2009 (3.10.0-1160.45.1.el7.x86_64),
macOS Big Sur 12.1
Post-Release Notes
Nothing yet.
DACS Version 1.4.46
Release Notes
This release primarily upgrades platforms and
third-party support packages, but
it also includes a few important bug fixes.
Change Summary
- Third-party supporting library upgrades:
Apache 2.4.48 (with apr-1.7.0 and apr-util-1.6.1), sqlite-3.35.5,
expat-2.4.1, openssl-1.1.1k, openldap-2.5.4, libtasn1-4.17.0 (for libdsm)
- Bug fixes for the libradius library, including recent ones that address
message validation
(CVE-2021-29629)
- Honour COOKIE_NAME_TERMINATORS configuration in NAT cookies
- Fixed bug where notice URIs (argument to ack()) having a query component
were not encoded correctly
- Platform upgrades:
FreeBSD 13.0, macOS Big Sur 11.4
Post-Release Notes
Nothing yet.
DACS Version 1.4.45
Release Notes
This release primarily upgrades platforms and
third-party support packages.
Change Summary
- Third-party supporting library upgrades:
Apache 2.4.46 (with apr-1.7.0 and apr-util-1.6.1), OpenSSL 1.1.1i,
sqlite-3.34.0, openldap-2.4.56, expat-2.2.10, libtasn1-4.16.0 (for libdsm)
- Platform upgrades:
FreeBSD 12.2,
CentOS 7.9 (x86_64, Linux 3.10),
macOS Big Sur 11.1
- the local_ldap_authenticate module
now allows DACS OPTION directives to set or override OpenLDAP
configuration settings
- SSL/TLS peer verification can now be configured to use
OpenSSL's methods instead of DACS's method or being disabled
(see sslclient(1))
Post-Release Notes
In this release, and probably previous releases,
the argument to the ack() function
should not include a query argument.
The argument is a URI that is invoked to return the text of a notice
as part of the notice acknowledgment feature.
See dacs_notices(8).
DACS Version 1.4.44
Release Notes
This release primarily upgrades platforms and
third-party support packages.
Change Summary
- Third-party supporting library upgrades:
Apache 2.4.43 (with apr-1.7.0 and apr-util-1.6.1), OpenSSL 1.1.1g,
sqlite-3.31.1, openldap-2.4.49, expat-2.2.9
- Platform upgrades:
CentOS 7.8 (x86_64, Linux 3.10),
macOS Catalina 10.15.5
- Added generic compression API to support lzma, zstd, zlib, and bz2,
with possible future support for brotli and lz4
- Minor bug fixes and documentation improvements
Post-Release Notes
Nothing yet.
DACS Version 1.4.43
Release Notes
This release primarily upgrades platforms and
third-party support packages.
Change Summary
- Third-party supporting library upgrades:
Apache 2.4.41 (with apr-1.7.0 and apr-util-1.6.1), OpenSSL 1.1.1d,
sqlite-3.29.0, openldap-2.4.48, expat-2.2.8
- Platform upgrades:
CentOS 7.7 (x86_64, Linux 3.10),
macOS High Sierra 10.14.6
Switched to FreeBSD 12.x as the development platform,
removed FreeBSD 11.x as a development and test platform
- Fix for FreeBSD/Linux + OpenSSL 1.1.1 SSL connection timeout bug
- Improvements to the dynamic string library code
- Configuration fix for FreeBSD 12.0
Post-Release Notes
Nothing yet.
DACS Version 1.4.42
Release Notes
This release primarily upgrades platforms and
third-party support packages.
DACS is now using OpenSSL's 1.1.1 series.
Change Summary
- Third-party supporting library upgrades:
Apache 2.4.38 (with apr-1.6.5 and apr-util-1.6.1), OpenSSL 1.1.1a,
gdbm-1.18, sqlite-3.26.0, openldap-2.4.47, readline-8.0
- Platform upgrades:
CentOS 7.6 (x86_64, Linux 3.10),
macOS High Sierra 10.14.3, FreeBSD 11.2/12.0
- Added optional uri_host attribute to the
Jurisdiction configuration element
- Integrated implementations of MD5 and SHA1 secure hash functions
because they may not be provided by third-party libraries in some
environments; although these functions are known to be cryptographically
weak, they may be needed for backward compatibility reasons or in contexts
where their cryptographic strength is not a primary concern
- Added an initial framework for custom digests accessed through OpenSSL's
engine functionality (e.g., to allow DACS implementations of MD5 and SHA1
to be available if not provided by OpenSSL
Post-Release Notes
- If support for RADIUS authentication has been enabled
(--enable-radius-auth), a compilation error can occur
during the DACS build,
reporting that radlib.h is missing or that
"Neither the system libradius nor the portable DACS implementation is enabled".
To fix this, change to the DACS src directory and do:
% (cd libradius; make install)
Then retry the top-level make of DACS.
-
Considered cryptographically weak, the MD5 and SHA1 digest
functions may not be provided by a given build of OpenSSL (e.g., in FIPS mode).
They are still useful in some situations, however, and may be required
by DACS if particular capabilities are needed.
Starting with DACS 1.4.42,
internal versions of MD5 and SHA1 are used by default to ensure that these
functions are available.
If necessary, you can revert to OpenSSL's implementations by using
the configure flag
--enable-require-openssl-digests.
This causes the symbol
ENABLE_REQUIRE_OPENSSL_DIGESTS to be defined and the variable
require_openssl_digests in crypto.c to be non-zero
at runtime.
In this case, if either MD5 or SHA1 is absent from OpenSSL, DACS may
fail if one of these function is needed at runtime.
DACS Version 1.4.41
Release Notes
This release primarily upgrades platforms and
third-party support packages.
Apache 2.2 servers are officially deprecated and
starting with this release they are no longer officially supported by DACS.
Change Summary
- Third-party supporting library upgrades:
Apache 2.4.34 (with apr-1.6.3 and apr-util-1.6.1),
expat-2.2.6, sqlite-3.24.0, openldap-2.4.46, gdbm-1.17, openssl-1.0.2p
- Platform upgrades: FreeBSD 11.2, CentOS 7.4 (x86_64, Linux 3.10),
macOS High Sierra 10.13.6
-
Bug fix: build configuration for libradius shipped with DACS
- Samba support is now officially deprecated; use the libdsm implementation
shipped with DACS for NTLM authentication
- Bug fix: prevent sslclient from processing the config file
Post-Release Notes
Nothing yet.
DACS Version 1.4.40
Release Notes
This release primarily upgrades platforms and
third-party support packages,
but it also introduces basic RADIUS authentication
and improves integration of libdsm, the implementation
that will replace Samba for NTLM authentication.
Because Apache 2.2 servers are officially deprecated,
this is the final version of DACS to officially support the Apache 2.2 series.
Although they are likely to continue to interoperate with new releases
of DACS for a while,
future releases of DACS will not be maintained,
tested, or documented with Apache 2.2 series servers.
Change Summary
- Third-party supporting library upgrades:
Apache 2.4.29 and Apache 2.2.34
(both with apr-1.6.3 and apr-util-1.6.1),
expat-2.2.5, sqlite-3.22.0, openldap-2.4.45, openssl-1.0.2n
- Platform upgrades: FreeBSD 11.1/10.3, CentOS 7.4 (x86_64, Linux 3.10),
macOS High Sierra 10.13.3
-
Introduced support for RADIUS-based authentication via
local_radius_auth and dacsauth,
using the *BSD RADIUS client API.
- Added a partial implementation of a subset of the Speck block cipher
family (for test/evaluation/curiousity purposes only)
- Added "percent" encoding type to expressions, e.g. encode(percent, xxx).
- Improved configuration/build/documentation for libdsm (vs. Samba)
Post-Release Notes
To test that RADIUS authentication is basically working, here is
what we do. On a machine different from where we have built or
installed DACS, we configure a FreeRADIUS server (consult its
documentation for details) and then run it in the foreground with
debugging enabled:
% /sbin/radiusd -X -xxx -f -i 10.0.0.125 -p 1812
This server listens to port 1812 at IP address 10.0.0.125; your
values may differ. Then, on our build or install machine, we first
test authentication using a FreeRADIUS utility:
% radtest -x bob hello 10.0.0.125:1812 10 testing123
This RADIUS client tries to authenticate user "bob" using password
"hello", with debugging enabled, at the same IP address and port
listened to by our radiusd above. The "testing123" argument is the
shared secret (password) used to authenticate our client instance
to the server. The "10" argument (called "nas-port-number") is
required but unimportant. A zero exit status from radtest indicates
that authentication succeeded; any other value indicates failure.
Once the previous testing is successful, with the RADIUS server
running as above:
% dacsauth -m radius passwd required \
-ORADIUS_SERVER=10.0.0.125 -ORADIUS_SECRET=testing123 -u bob -p hello
A zero exit status from dacsauth indicates that authentication
succeeded; any other value indicates failure. If desired, continue
by configuring DACS for RADIUS authentication and testing using
local_radius_authenticate.
DACS Version 1.4.39
Release Notes
Apart from various third-party package and platform upgrades,
this release introduces new support for NTLM authentication using
a modified version of
libdsm
as a (mutually exclusive) alternative to the original
Samba-based implementation.
For a very long time, Samba 3.x has been used by DACS solely for its
implementation of NTLM authentication.
But because Samba 3.x has not been supported by the Samba team for
quite some time,
and Samba 4.x has proved to be difficult to build on DACS platforms
and is not a drop-in replacement for Samba 3.x in any case,
we want to use something much smaller, simpler, and easier to build than Samba.
Samba 3.x can still be used by this version of DACS.
But Samba dependencies will be deprecated and eventually removed from DACS.
Although it is currently functional and tested,
the new implementation using libdsm is not fully
integrated or documented within the main DACS build.
This will be improved in the next release.
The Windows/NTLM authentication method is completely optional, so the
following notes are probably only of interest to those who require it
and would prefer not to use the original implementation that depends
on Samba.
If you want to try the new implementation, do this before building DACS:
- Unpack the DACS tarfile
- Chdir to dacs-1.4.39/src/libdsm
- There are a few steps to follow but it is quite straightforward.
The README in that directory has detailed instructions.
Briefly:
- Obtain the source code for two GNU libraries:
libtasn1 and
libiconv.
No changes to those libraries are required.
- Build both libraries in place, then build the modified libdsm.
A program called ntlmauth will be built
and you should use it to test authentication against your Windows server.
- If all goes well,
build DACS as you normally would, except instead of configuring
it using --with-samba use --with-libdsm=./libdsm.
Then test authentication again, this time using dacsauth
(refer to
dacsauth(1)
and
local_ntlm_authenticate for examples).
- If you are satisfied with the results of your testing,
complete your installation of DACS and verify that
dacs_authenticate also works
correctly.
The only change you may need to make to dacs.conf is to
specify OPTION 'SAMBA_PORT="0"' in the appropriate
Auth clause.
The new implementation knows which port(s) to try.
- Please report any problems so that they can be addressed in the
next release.
Change Summary
- New NTLM authentication implementation, enabled by
--with-libdsm=...
- Minor functional improvements to the crypto test utility
(built by "make test" but not installed):
crypto ["list"]
crypto {"test" | "tests"} [test-name]
crypto {"digest" | "hash"} [digest-name|hash-name] [optional-args]
Examples:
crypto hash sha3-256 < dacs-1.4.39.tbz
echo -n "somestring" | crypto hash sha512t 24
- Third-party supporting library upgrades:
Apache 2.4.25, SQLite 3.19.2, OpenSSL 1.0.2l, gdbm-1.13
- Platform upgrades:
macOS Sierra 10.12.5, CentOS 7.3 (x86_64, Linux 3.10)
Post-Release Notes
- If this compile error occurs:
version.c:47:25: fatal error: apu_version.h: No such file or directory
#include <apu_version.h>
The quickest fix is to edit defs.mk and add the include paths needed
for Apache's apr-util library.
The changed line will look something like this (your paths may be a bit
different):
apache_apr1 = \
$(shell /usr/local/apache2-2.2.31/apr-httpd/bin/apr-1-config --includes) \
$(shell /usr/local/apache2-2.2.31/apr-util-httpd/bin/apu-1-config --includes)
- A compilation error may occur when building against the new NTLM
authentication code.
Edit defs.mk.in and find the line (approx. line 371) where
NTLM_LIBS is defined and a space incorrectly follows a -L
flag:
NTLM_LIBS=... -L $(DSMDIR)/libtasn1/install/lib ...
Delete the space and rerun configure
to regenerate defs.mk.
- A bug in configuration processing has been discovered whereby
the uri_expr attribute of a Jurisdiction element may
be incorrectly evaluated, leading to a runtime configuration error.
This bug appears to be present going back several earlier versions of DACS.
Here is a simple fix that you can safely make to any recent-ish
version of DACS provided it compiles after making the change.
In src/conf.c, look in process_conf() for this code at
approximately line 2034:
acs_new_env(&env);
conf_var_ns = var_ns_new(&env.namespaces, "Conf", site->kwv_conf);
Insert the middle assignment statement below, so that your code looks
like this:
acs_new_env(&env);
env.is_dacsexpr = 0;
conf_var_ns = var_ns_new(&env.namespaces, "Conf", site->kwv_conf);
Then 'make clean', 'make install', and test.
DACS Version 1.4.38a
Release Notes
This special release addresses some minor but long-standing issues.
Change Summary
- Third-party supporting library upgrades:
sqlite-3.15.1, gdbm-1.12
- For Linux, use _DEFAULT_SOURCE instead of _BSD_SOURCE.
- Avoid producing a duplicate error message in dacs_auth_transfer.
- Do not check/set mode of a log file that does not exist or is
not a regular file.
- Install the JSON .rnc schemas with the XML DTDs.
- Allow dacs_signout(8) to emit JSON documents.
- Added the DACS_SIGNOUT_RESULT parameter to a
SIGNOUT_HANDLER URL and extended SIGNOUT_HANDLER
to explicitly allow a user-specified signout handler URL to
override a default URL.
See
dacs_signout(8)
and
dacs.conf(5)
for details.
Post-Release Notes
Nothing yet.
DACS Version 1.4.38
Release Notes
This release primarily upgrades platforms and
third-party support packages,
but it also incorporates new cryptographic hashing capabilities.
Change Summary
- Platform upgrades: FreeBSD 11.0, macOS 10.12 (Sierra)
Current Linux platform is CentOS-7 (1511)
- Third-party supporting library upgrades:
OpenSSL 1.0.2j, expat 2.2.0, apache-2.4.23, sqlite-3.15.0, readline-7.0
- Addition of the Blake2 cryptographic hash function,
Argon2 password-based key derivation function,
ChaCha20 cipher (RFC 7539), and
hkdf HMAC-based key derivation function
Post-Release Notes
Nothing yet.
DACS Version 1.4.37
Release Notes
This release primarily upgrades platforms and
third-party support packages.
Additional HMAC digest algorithms are now provided.
A self-contained arbitrary precision integer arithmetic library
is now included in the distribution.
Change Summary
- Platform upgrades: CentOS 7.2 (x86_64, Linux 3.10), Mac OS X 10.11.4,
FreeBSD 10.3
- Third-party supporting library upgrades:
OpenSSL 1.0.2h, expat 2.1.1, apache-2.4.20
- Implemented HKDF (RFC 5869), which works with all HMAC-SHA digests.
Enabled the four HMAC-SHA3 functions.
- Added the -totp-time flag to
dacstoken(1).
Post-Release Notes
- A bug in authlib.c:passwd_check_digest() may cause
authentication to always fail if an account has changed its
password digest algorithm.
DACS Version 1.4.36
Release Notes
This release primarily fixes very minor bugs and upgrades platforms and
third-party support packages.
Change Summary
- Platform upgrades: Mac OS X 10.11.2
- Third-party supporting library upgrades: Apache 2.4.18, OpenSSL 1.0.2e,
OpenLDAP 2.4.43, SQLite 3.9.2
- Minor bug fixes, code improvements, and documentation updates
Post-Release Notes
Nothing yet.
DACS Version 1.4.35
Release Notes
This release addresses some bugs,
adds some new secure password digest algorithms
(such as the new SHA-3 digest algorithms),
changes the format of the DACS password file,
and platform upgrades.
There was an important bug fix to DACS_ACS processing.
The DTD/RNC for dacs_version has been modified.
Please refer to the distribution's README and manual pages
for additional details.
If you are a) upgrading from 1.4.34 and
b) were using DACS password files and
c) have accounts that use the new parameterized digest methods introduced
in 1.4.34,
there has been a format change to those account entries.
Simple manual editing of those accounts or a password reset is required,
otherwise sign-on to those accounts will fail.
See the
PASSWORD_DIGEST
directive for details.
Change Summary
- Platform upgrades: FreeBSD 10.2, CentOS 6.7 (x86_64), Mac OS X 10.10.5
- Fixes to mod_auth_dacs for bugs in DACS_ACS processing.
- Refactored cryptographic digest code, added new cryptographic hash
function specification syntax with flexible digest name matching
- Added support for SHA-3 digests (FIPS PUB 202, August, 2015), including
bit-length sized input messages, but excluding extendable-output functions
(SHAKE128 and SHAKE256), with test vectors; added to expressions,
password digests, not currently available with HMAC or PBKDF2.
Added support for SHA-512 digest variants (SHA-512/224, SHA-512/256,
SHA-512/t), FIPS 180-4 (March, 2012), with test vectors
- Added --digests and --checkdigest flags to dacs(1)
- Minor changes to DTD/RNC for dacs_version; dacsversion/dacs_version emits
list of available digests
- Changed DACS password file format to explicitly identify digest
algorithm plus any parameters; this is backward compatible except for
1.4.34 pbkdf2/scrypt, which will have to be adjusted manually
- Added hex character escapes within strings (e.g., "hi\xa" or "hi\x0A")
- Bug fix: CGI form data subtype parsing
- Bug fix: configure was not looking for gmake correctly
- Removal of support for InfoCards, previously announced as deprecated,
is in progress.
Related code will probably remain in distribution indefinitely
but is unlikely to build.
Post-Release Notes
- dacs_token(8) may function incorrectly
due to a bug in key initialization.
DACS Version 1.4.34
Release Notes
This release primarily addresses some minor bugs,
adds some new secure password digest algorithms,
and upgrades third-party support packages.
If you are upgrading,
please note that there have been a small number of important
changes to site.conf-std.
If you have not modified your site.conf (and you shouldn't have),
you should copy site.conf-std to it.
Change Summary
- Platform upgrades: Mac OS X 10.10.4, CentOS 6.6 (2.6.32-504)
- Third-party supporting library upgrades: OpenSSL 1.0.2d and 1.0.1p,
SQLite 3.8.10.2, Apache 2.4.16 and 2.2.31
- Added configuration option --with-default-cipher-list
to override the default OpenSSL cipher suite list used by
sslclient(1)
(and therefore also when DACS
makes internal SSL/TLS connections since it uses sslclient).
The usage message for sslclient prints the default cipher list.
- Added scrypt support with test cases, added to
dacs.exprs(5)
- InfoCard support formally deprecated, unfortunately
- Extended PBKDF2 to use non-formally approved HMAC-SHA2 constructions,
with test cases, added to
dacs.exprs(5)
- Added PBKDF2 algorithms and scrypt password digest methods;
see the
PASSWORD_DIGEST
directive
- Removed conditionally-compiled code for the ancient and obsolete
base-64 encoding table
- Changed default
PASSWORD_DIGEST
from SHA-1 to SHA-512
- Build using -Wl,--export-dynamic
instead of -export-dynamic
- Minor open source license clarifications, not changes (see LICENSE)
- Bug fixes:
- Bug in PBKDF2 resulted in reproducible but incorrect outputs
(notably, it had passed all standard test vectors)
- dacs_version(8) did not recognize
FORMAT=XMLSCHEMA
- default site config should use "dacshttp", not "http"
- need absolute build location in
defs.mk.in and dacsinit.in,
so use abs_top_srcdir not top_srcdir
- undef() function seems to have been broken
- dacsinit(1) could incorrectly
use invalid relative directory paths
Post-Release Notes
- DACS_ACS=-check_only does not work correctly sometimes,
apparently due to a subtle recent change in Apache's behaviour.
A fix has been developed for Apache 2.2/2.4 and is being tested.
- Using -lfetch in the build seems to be unnecessary
and can result in OpenSSL library conflicts.
This could sometimes result in sslclient
getting a SEGV in OPENSSL_ia32_cpuid immediately upon program
startup (which was initially very mysterious).
- The method of parameterizing scrypt and pbkdf2 introduced in this
release will be replaced with a more general and explicit method
(doing away with global defaults) in the upcoming bug fix release.
Because this may result in minor configuration and DACS password file
incompatibilities (only with respect to 1.4.34 and future releases),
consider waiting for the next release if you plan to use scrypt or pbkdf2.
DACS Version 1.4.33
Release Notes
This release primarily addresses some important bugs,
improves documentation, and upgrades third-party support packages.
Change Summary
- Third-party software upgrades:
OpenSSL 1.0.2, Apache 2.4.12, Samba 3.6.25
-
Eliminate calls to gethostbyname(3),
which is pseudo-deprecated and recently associated with
security-related bugs.
-
Fixes for mod_auth_dacs's handling of internal redirects to avoid
losing DACS HTTP cookies in some contexts
-
Enhancements to local_http_authentication to optionally
accept an auth_reply.dtd document from the web service it invokes.
This allows a generic web service to authenticate a username/password
and specify the username, lifetime of credentials, and role string if
authentication succeeds.
Post-Release Notes
DACS Version 1.4.32
Release Notes
This release includes some minor improvements, documentation updates,
and platform and third-party software upgrades.
Change Summary
- Platform upgrades: FreeBSD 10.1, Mac OS X 10.10, CentOS 6.6
- Third-party software upgrades:
OpenSSL 1.0.1j, OpenLDAP 2.4.40
-
Improvements and bug fixes for
dacstoken(1);
improved provisioning by exporting account information as URIs
(Google's KeyUriFormat) that can be converted into QR barcodes and
imported by several OTP client applications
-
Fix to Makefile.in
to use DESTDIR for
dacsinit(1)
[L. Gustafson]
-
Fixes and improvements to
cgiparse(8),
especially regarding multiple parameters with the same name
-
Minor improvements to
dacshttp(1)
and internal HTTP requests wrt
Authorization headers;
a userinfo field (username:password) is now
processed in URLs in conjunction with HTTP Basic authentication
(RFC 2617)
-
Corrections to
dacsauth(1) examples;
lines in -Of configuration files may now be continued
-
Fix to
dacs_acs(8)
to ignore Rname rules with a "status" of "disabled";
fixes to
dacsrlink(1)
for URI query parameters and empty Allow clause
(unspecified user); all rules must have a "status" attribute
-
Added an optional PAM-based algorithm to
local_unix_authenticate.
for Unix password validation, needed by systems that do not return an
account's encrypted password;
see dacs_authenticate(8).
-
All commands accept the --version flag
Post-Release Notes
- Going back at least to DACS 1.4.30,
when Apache resolves a URL with a trailing pathname component
(PATH_INFO) by processing a sub-request,
mod_auth_dacs can drop DACS HTTP cookies.
When this happens, DACS access control rule processing may determine that
there are no credentials accompanying a request,
and access will typically be (unexpectedly) denied.
This bug was first demonstrated by invoking a PHP script,
through a ScriptAlias directive, with a trailing pathname component
on the request URI.
This will be fixed in the next release of DACS.
-
Soon after release of DACS 1.4.32
an OpenSSL
Security Advisory
was dispatched.
Initial tests indicate that DACS will
work with OpenSSL 1.0.1k and 1.0.2.
-
After release of DACS 1.4.32,
a "very serious" security issue was identified with respect to the
gethostbyname(3) library function in
glibc
versions between glibc-2.2 and glibc-2.17, inclusive.
While DACS may use this implementation of
the function on some platforms,
in a typical deployment it is likely to be difficult to leverage
into a successful attack.
Use of gethostbyname() is pervasive, however,
including third-party software that is often used with
DACS,
so all sites should address this issue promptly.
Calls to gethostbyname() by DACS
will be replaced by
getaddrinfo(3)
in a future release.
For details, see
GHOST: critical glibc update (CVE-2015-0235),
Qualys Security Advisory CVE-2015-0235 - GHOST: glibc gethostbyname,
and
Critical "GHOST" Vulnerability Released.
-
While no incidents have been reported,
DACS releases may use versions of
OpenSSL
that may be
affected
by the
TLS heartbeat read overrun bug,
MITM vulnerability (C
VE-2014-0224),
or
Security Advisory [15
Oct 2014].
DACS installations are advised
to upgrade to OpenSSL 1.0.1i or newer.
Also see
this.
DACS Version 1.4.31
Release Notes
This release primarily addresses some important bugs,
improves documentation, and upgrades third-party support packages.
Change Summary
- Third-party software upgrades:
OpenSSL 1.0.1i, Apache 2.4.10, Apache 2.2.29, Berkeley DB 6.1.19
-
Important Apache interoperability fixes for Apache 2.4.10 and 2.2.29.
-
Incompatible changes to the external format of cached authorization tokens
(see dacs_acs(8)), which will void any old format tokens; deletion of
the old cache file is recommended
-
Adds configuration directive COOKIE_NAME_TERMINATORS; this can be
used to emit
RFC 2965
compliant HTTP cookies.
-
DACS now checks and requires the version of mod_auth_dacs to be
compatible with the version of DACS being used (this currently means
that the version numbers must match exactly).
-
Added base-32 encoder/decoder, self tests
-
Fixes JSON output bugs in
dacs_version(8),
dacs_list_jurisdictions(8)
-
Fixes HTML documentation table of contents generation bug on Mac OS X
-
Adds JSON output format to dacs_select_credentials
-
Fixes dacs_select_credentials(8) deselected all credentials instead
of doing nothing when given
non-matching arguments (OPERATION==DESELECT)
Post-Release Notes
Nothing yet.
DACS Version 1.4.30
Release Notes
This release primarily addresses configuration and build problems,
improves documentation, fixes some minor bugs,
and upgrades third-party support packages.
Change Summary
- Third-party software upgrades:
Apache 2.4.9 and 2.2.27, OpenSSL 1.0.1h, Samba 3.6.24, SQLite 3.8.5,
BerkeleyDB 6.0.30, OpenLDAP 2.4.39, xmlsec 1.2.20,
GNU Readline 6.3
- Platform upgrades: CentOS 6.5, Mac OS X 10.9.4, FreeBSD 10.0
-
Added SNI (Server Name Indication, RFC 6066) functionality
-
Addresses previous post-release problems and confirmed bug reports
Post-Release Notes
- During routine testing after an upgrade,
a particular Apache+DACS configuration that worked correctly
with Apache 2.2.22 did not work properly with Apache 2.2.27.
It did not seem that anything important had changed in either
the Apache or DACS configurations.
After much debugging, it turned out that certain URLs were
not being actually being DACS-wrapped on the new system.
No Apache change log entries suggest anything relevant to this.
A beta release of mod_auth_dacs for use with Apache 2.2.27
will be made available shortly.
As always, please ensure that your Apache+DACS system
is granting and denying access as you intend,
especially after making changes.
-
When installing mod_auth_dacs on some platforms
(notably FreeBSD 10.0), messages similar to the following may be seen:
Warning! dlname not found in /usr/local/apache2.2/modules/mod_auth_dacs.la.
Assuming installing a .so rather than a libtool archive.
chmod 755 /usr/local/apache2.2/modules/mod_auth_dacs.so
chmod: /usr/local/apache2.2/modules/mod_auth_dacs.so: No such file or directory
apxs:Error: Command failed with rc=65536
You should notice that a shared library (a .so file) has not been
created in the Apache modules directory.
This problem is apparently caused by a buggy version of libtool
that ships with Apache
(e.g., /usr/local/apache2.2/apr-httpd/build-1/libtool)
and is invoked by apxs from "make install".
To work around this, change the apxs command
(e.g., /usr/local/apache2.2/bin/apxs) that is run from the
Makefile in the DACS apache directory to execute the system's
libtool instead of Apache's.
For example:
#my $libtool = `$apr_config --apr-libtool`;
my $libtool = "/usr/local/bin/libtool";
-
After upgrading to Apache 2.2.27 on FreeBSD 10.0,
it was discovered that requests sent from most clients
(firefox, curl, wget, safari,
and telnet, but not lynx or dacshttp),
running on any system, were not being handled correctly
by httpd.
For most URLs,
the client would sometimes connect to Apache and sometimes not.
Apache would not service the request and it would eventually time out.
This was eventually traced to changes in FreeBSD 10.0 firewall rule processing
(ipfw) from the previous release of FreeBSD and
is not DACS related.
- The HTTP_AUTH directive appears to have been broken by
changes to recent releases of Apache.
DACS Version 1.4.29
Release Notes
This release primarily addresses configuration and build problems,
improves documentation, fixes some minor bugs,
and upgrades third-party support packages.
Change Summary
- Third-party software upgrades:
Apache 2.4.6 and 2.2.25, Samba 3.6.19, SQLite 3.8.0.2,
BerkeleyDB 5.3.28, OpenLDAP 2.4.36, libxml 2.9.1, xmlsec 1.2.19,
Expat 2.1.0
- Platform upgrades: CentOS 6.4, Mac OS X 10.8.5
-
Support for Google Authenticator
(see dacstoken(1))
- Addresses previous post-release problems and confirmed bug reports
Post-Release Notes
-
While no incidents have been reported, DACS
releases use
OpenSSL,
which may be affected by the
TLS heartbeat read ove
rrun bug.
DACS installations should recompile
OpenSSL with -DOPENSSL_NO_HEARTBEATS,
as instructed in the advisory,
or upgrade to OpenSSL 1.0.1g.
- Despite the addition of support for add-on modules,
there is no change to the open source license for DACS and
the DACS distribution does not include any code that is not
open source licensed.
- The README was not updated to version 1.4.29.
-
dacs.install(7) incorrectly states
that this release expects
libxml 2.9.0 and xmlsec 1.2.18;
libxml 2.9.1 and xmlsec 1.2.19 should be used.
- dacsinit(1) is not installed
and must be run from the build directory
DACS Version 1.4.28c
Release Notes
This version was not publicly released but the changes summarized
below were made to the code base.
Change Summary
- Platform upgrade: Mac OS X 10.8.3 (Mountain Lion)
- Added "load" and "loadrc" operators to vfs(), deprecated setvar(load, ...)
- Introduction of the "Expr" namespace in expressions; can set interactive
prompt strings
- Support for Google Authenticator keys
Post-Release Notes
This sentence intentionally left blank.
DACS Version 1.4.28b
Release Notes
This release addresses problems with Apache 2.4 support,
fixes some minor bugs, and upgrades some third-party support packages.
Change Summary
- Third-party software upgrades: OpenSSL 1.0.1e, Samba 3.6.12
- Fixes to the dacsacl(1) command
for building/rebuilding index file regardless of whether it already exists
- New strchop() function
- Groundwork for possible forward proxying mode
Post-Release Notes
DACS Version 1.4.28a
Release Notes
This release improves support for Apache 2.4,
corrects many problems with dacs.quick(7),
and fixes a variety of minor bugs.
There are no third-party support package upgrades, so upgrading from
DACS 1.4.28 should be easy.
For details, consult the
README and
HISTORY files,
dacs.readme(7), and
dacs.install(7).
Change Summary
- Added optional nocase argument to
dacsexpr(1) functions
strstr()
and
strrstr()
- Retired FreeBSD 7.X and 8.X as testing platforms
- Platform upgrades: CentOS 5.9, FreeBSD 9.1
- Corrected use of --srcdir in defs.mk.in,
and changed to absolute paths for some of the
src/conftools utilities
- mod_auth_dacs fixes and documentation updates for Apache 2.4;
note: now need to use "Require dacs-authz" directive
with Apache 2.4 httpd.conf;
see
Apache Module mod_auth_dacs
- Fixes to the dacsacl(1) command
- Important updates and corrections for
dacs.quick(7)
- Upgrade to Windows Server 2012 for NTLM/LDAP authentication testing
Post-Release Notes
- Apache 2.2 is the recommended version to use with this
release of DACS.
Some features of DACS may not work properly with Apache 2.4.
- The instructions in dacs.install(7)
do not completely describe the procedure for building
Apache 2.4.3. It is covered in Apache's INSTALL file, however.
For the testing platforms, we get the APR and APR-UTIL libraries
from apr.apache.org and unpack
them in the Apache distribution's srclib directory, then rename them
apr and apr-util, respectively, as it says in
INSTALL.
For DACS 1.4.28a we used apr-1.4.6 and apr-util-1.5.1.
When building httpd, run configure with the
--with-included-apr flag.
On CentOS 5.9, the Apache build initially failed with a complaint
about not finding pcre-config. To solve this, we did
% yum install pcre-devel.x86_64
When configuring for the DACS build it was not necessary
to use the --with-apache-apr flag.
- Remember that starting with Apache 2.4,
you need to write "Require dacs-authz" instead of
"Require valid-user".
If you use the old directive with Apache 2.4.x, httpd will
emit a message like
"AuthType DACS configured without corresponding module".
- In some configurations the dreaded
"undefined ssl_hook_Fixup symbol" error or the
"Cannot load modules/mod_ssl.so into server" error
is produced by httpd when it starts up.
This was also seen in earlier releases of Apache.
These errors can be due to an apparent bug in the Apache build procedure that
results in the mod_ssl.so module not knowing where
libssl.so and libcrypto.so are,
even though the correct path was specified at Apache build time through
the --with-ssl flag to configure.
One solution is to make mod_ssl a built-in module instead of a
dynamically loaded module.
Build Apache using something similar to this (using the
--enable-ssl=static flag is the important change):
% ./configure --prefix=/usr/local/apache2-2.4.3 --with-ssl=/usr/local/openssl-1.0.1c --enable-ssl=static
Then do a "make install".
Note that you will need to comment out the httpd.conf directive
that loads mod_ssl:
# LoadModule ssl_module modules/mod_ssl.so
Now from the Apache installation directory, try:
% bin/httpd -l
If httpd cannot find your OpenSSL libraries,
you will see an error message like this:
error while loading shared libraries: libssl.so.1.0.0: cannot open shared object file: No such file or directory
Tell the linker where the OpenSSL libraries are by setting the
LD_LIBRARY_PATH environment variable for
httpd; for example:
% sh -c "export LD_LIBRARY_PATH=/usr/local/openssl-1.0.1c/lib; bin/httpd -M"
You may also be able to resolve the problem using the ldconfig
command, but we don't know if that could possibly break other programs that
expect a different version of the OpenSSL library.
You will need to always set LD_LIBRARY_PATH
before running httpd, maybe using an alias or script.
If you use apachectl to manage Apache,
you could simply have it set LD_LIBRARY_PATH
(also see bin/envvars, which is sourced by bin/apachectl).
DACS Version 1.4.28
Release Notes
This minor bug fix release addresses build and portability issues.
For details, consult the
README and
HISTORY files,
dacs.readme(7), and
dacs.install(7).
Change Summary
- Upgrade to Mac OS X 10.8.2 (Mountain Lion)
- Third-party software upgrades:
OpenSSL 1.0.1c, SQLite 3.7.14.1, Samba 3.6.8,
OpenLDAP 2.4.33, Apache 2.2.23/2.4.3, BerkeleyDB 5.3.21, libxml2 2.8.0
- Renamed http to dacshttp
Post-Release Notes
- The Active Directory (LDAP) and NTLM authentication methods
have been successfully (though not exhaustively) tested against
Windows Server 2012 platform services.
It is likely that that platform will officially replace the
(ancient) Windows Server 2000 platform that has been used for testing
since the earliest releases of DACS.
- Some invalid absolute links appear in
dacs.exprs.5.xml
(and to a lesser extent in a couple of other manual pages)
and documentation generated from it.
They are easily fixed by deleting the "http://bsd6.dss.ca/..."
prefix to change them to the obvious relative URLs.
- Some references and links to http(1) were not updated to refer to
dacshttp(1).
- The --srcdir flag to configure may not be handled
correctly.
- For Apache 2.4, the mod_auth_dacs module identification string
may not be included in the SERVER_SIGNATURE string (and other places).
A quick fix is to modify mod_auth_dacs.c:dacs_register_hooks()
to ensure that ap_hook_post_config() is called.
- mod_auth_dacs may not work correctly with Apache 2.4.3.
Consult the Apache log for messages that look like
"AuthType DACS configured without corresponding module".
Until this is fixed, please check if Apache 2.4.1 works for you,
or use Apache 2.2.23 (or something close to it).
- Many problems with dacs.quick(7)
have been identified.
DACS Version 1.4.27b
Release Notes
This minor bug fix release addresses build and portability issues
found after the release of 1.4.27.
For details, consult the
README and
HISTORY files,
dacs.readme(7), and
dacs.install(7).
Change Summary
- FreeBSD 9.0 build issues fixed; upgrade to Mac OS X 10.7.3 (Lion)
- Bogus code that broke dacskey(1) removed
- HTTP_AUTH directive fixes
- third-party software upgrades:
OpenSSL 1.0.0h, SQLite 3.7.10, Samba 3.6.3,
OpenLDAP 2.4.29, Apache 2.2.22
- minor fixes to misc/Makefile.in
- use appropriate apr-config command to get Apache APR
include flags
- added OpenLDAP Public License (Version 2.8) to NOTICES to
facilitate inclusion of OpenLDAP code for Debian GNU/Linux support
- added OpenLDAP ldif.h and ldif.c to simplify build and
allow installed OpenLDAP headers and libraries to be used;
if LDAP authentication is enabled and the location of OpenLDAP is
not specified, configure will search for OpenLDAP libraries
- mod_auth_dacs now recognizes the
"wsgi-script" executable
type
Post-Release Notes
Nothing yet.
DACS Version 1.4.27
Release Notes
This is mainly a bug fix release.
Consult the
README and
HISTORY files,
dacs.readme(7), and
dacs.install(7).
Change Summary
- fixes and extensions to
HTTP_AUTH,
dacsauth(1),
and the dacsauth() function
and their documentation; the syntax of the HTTP_AUTH directive has been
modified (the -url flag was removed) and is not backward compatible in
some instances, so configuration changes may be necessary
- third-party software upgrades:
OpenSSL 1.0.0f, BerkeleyDB 5.3.15, SQLite 3.7.9, Samba 3.6.1,
OpenLDAP 2.4.28, libxml 2.7.8, xmlsec 1.2.18
- upgrade and fixes for Mac OS X 10.7.2 (Lion)
Post-Release Notes
- Yet more problems remain with the HTTP_AUTH directive;
fixes are currently being tested and patches will be posted after a
suitable evaluation period.
Contact us if you would like to try the patches now.
- Some debugging code crept in to the dacskey(1) utility,
which prevents it from functioning.
To fix the problem, edit src/mkkey.c and remove or comment out
the entire block of code that starts at line 645
(if (streq(argv[1], "enc")) {)
and ends at line 669
(return(0);).
- Building DACS on FreeBSD 9 may be problematic.
The primary development environment for DACS will be changed to FreeBSD 9.0
for the next release, however, and these problems will be addressed.
DACS Version 1.4.26
Release Notes
This is mainly a bug fix release.
Consult the
README and
HISTORY files,
dacs.readme(7), and
dacs.install(7).
Change Summary
- extensions to HTTP_AUTH,
dacsauth(1),
and the dacsauth() function
to return role information
- bug fixes to local_passwd_authenticate
and build/configuration procedures
- third-party software upgrades:
Apache 2.2.21, Readline 6.2, Samba 3.6.0,
OpenSSL-1.0.0e, OpenLDAP-2.4.26, xmlsec1-1.2.18, libxml2-2.7.8
- platform upgrades: CentOS 5.7, Mac OS X 10.6.8
- additional crypto support and self-tests, including initial OAuth support
- support for the Solaris/OpenSolaris platform has been withdrawn,
although commercial support is still available
Post-Release Notes
- In the description of the HTTP_AUTH directive in
dacs.conf(5),
the comment regarding the -r flag not being implemented
is incorrect and should be ignored.
Refer to dacsauth(1) for
information about the -r role-module-spec flag.
- libxml2-2.7.8 is supported
(some places in the documentation erroneously mention libxml2-2.7.7)
- DACS should work with Apache 2.0.64, although this has not yet
been confirmed
("The Apache HTTP Project developers strongly encourages all users to
migrate to Apache 2.2, as only limited and less frequent maintenance
is performed on this legacy flavor.")
- Recent work has shown that
XML Encryption may be insecure.
While this does not mean that DACS itself is insecure,
it may point to weaknesses in XML-based authentication methods that DACS
can use, such as Information Cards.
- A recent change: you must now sign on to the Oracle site before it allows
you to
download Berkeley DB.
You may be able to avoid this by using a URL such as
https://download.oracle.com/berkeley-db/db-5.3.15.tar.gz,
or you may be able to obtain BDB elsewhere
(such as
linux.softpedia.com,
pkgs.fedoraproject.org,
or
http://fossies.org").
Consider validating the downloaded file using a checksum published
on a different site, however.
- There may be issues with build-time enabling of Readline library
functionality on Mac OS X (to be addressed in the next release).
- Some HTTP_AUTH directives may not be parsed correctly
and/or the documentation may be incorrect in some cases.
This may also affect dacsauth(1).
Please pay special attention to testing these features until the problems
are resolved in the next release.
DACS Version 1.4.25
Release Notes
Although it mainly fixes bugs and adds some minor features,
this release includes improved support for one-time passwords
(such as time-based tokens, token provisioning,
and additional OTP token vendors),
introduces a new, simplified user-selectable authentication control,
fixes and improves PAM-based authentication,
and adds support for SQLite.
As with earlier releases of DACS,
a variety of problems were encountered building third-party software.
In particular, OpenSSL - which has seen a larger than usual number of
releases recently - seems to be troublesome.
These problems are addressed in
dacs.install(7).
Change Summary
- VFS support for SQLite (starting with 3.6.23.1)
(see dacs.conf(5))
- added "user_sufficient" authentication control
(see dacs_authenticate(8))
- fixes and improvements to PAM-based authentication
(see dacs_authenticate(8))
- third-party software upgrades: BerkeleyDB 5.0.21, Apache 2.2.15,
Readline 6.1, Samba 3.5.3, openssl-1.0.0a, openldap-2.4.21, xmlsec1-1.2.16,
libxml2-2.7.7
note: DACS will no longer build against earlier releases of Samba
note: it was necessary to rebuild xmlsec1 against OpenSSL 1.0.0
note: changes made in OpenSSL 0.9.8[mno] are incompatible with DACS;
do not use them with DACS
- XML bug fix for
dacs_select_credentials(8)
and minor (though incompatible) change to its DTD
(dacs_select_credentials.dtd)
- bug fixes: URL parsing, VFS rename,
dacstransform(1) and
dacs_transform(8),
function argument type conversion
(see Post-Release Notes for 1.4.24)
- initial, partial support for
JSON output
(this will be completed and tuned in the next release)
- minor additions to the
syntax() function
- dacsemail(1)
- added debug_xxx debug flag file mechanism
(see dacs_acs(8))
- bug fix: the syntax of the id attribute of an Auth/Roles/Transfer clause
should be restricted to an alphabetic followed by zero or
more alphanumerics, hyphens, and underscores
(see dacs.conf(5))
- upgrade: Mac OS X 10.6.4 (x86) platform
- added RFC 4231 HMAC test vectors
- added
-with-apache-apr-includes and
--with-apache-apr-cpp-defs
build flags
for Apache special cases
- many fixes and improvements to OTP token support in dacstoken;
new dacs_token web service; new support for time-based OTP tokens (TOTP);
incompatible changes to token account format and command line flags
(see dacstoken(1),
dacs_token(8), and
dacs_authenticate(8))
- persistent font change capability for HTML manual pages
- internal improvements: mutual exclusion locking, shared memory segments
(not available on some platforms)
- Rlinks,
dacsrlink(1): several important bug fixes
- undocumented dacs_complete word/string completion service
(see src/complete.c)
Post-Release Notes
Important (3-Nov-2010):
The local_passwd_authenticate authentication module for 1.4.25
may report a successful authentication outcome even if an incorrect
password is given.
If you are using this authentication module or plan to,
please apply
this patch immediately,
then "make install" DACS.
Sites running earlier releases of DACS should upgrade (and apply the patch),
or at least verify that their release's local_passwd_authenticate
is working properly.
- Not mentioned in the release notes and HISTORY were
some improvements to the output of dacs_error,
a generic error handling Perl script.
-
Note: There is
uncertainty
about the future of OpenSolaris.
This may lead to abandoning it as an officially supported platform
for DACS.
-
Solaris/OpenSolaris is easily the most troublesome platform when it
comes to building packages.
Here are examples of fairly basic configurations that have been used
to successfully build DACS with NTLM and LDAP authentication
on OpenSolaris 5.11.
For openldap-2.4.21:
./configure --disable-slapd --enable-static --without-cyrus-sasl
For samba-3.5.3:
./configure --enable-static=yes --with-ads=no --with-ldap=no --disable-swat \
--disable-cups --disable-pie
For DACS:
./configure --prefix=/usr/local/dacs --disable-shared --enable-static \
--enable-ntlm-auth --enable-ldap-auth --enable-user-info \
--with-apache=/usr/local/apache2-2.2.11 \
--with-apache-apr=/usr/local/apache2-2.2.11/apr-httpd \
--with-samba=/k/generic/src/sysutils/samba-3.5.3 \
--with-ldap=/k/generic/src/sysutils/openldap-2.4.21 \
--with-ssl=/usr/local/openssl-1.0.0a \
--with-expat=/usr/local/expat-2.0.1
- On Solaris (and perhaps other platforms), the following error message
might be produced when building DACS:
ld: fatal: option -dn and -P are incompatible
ld: fatal: Flags processing errors
collect2: ld returned 1 exit status
To correct the problem, edit defs.mk and change every occurrence
of "-Wl,-rpath," to "-R".
So, for example:
-Wl,-rpath,/local/expat-2.0.1/lib
will become
-R/usr/local/expat-2.0.1/lib
Make this change everywhere in defs.mk.
If you run configure again,
defs.mk will be replaced with a new copy,
so you will need to repeat these changes unless you know how to mess with
defs.mk.in and configure.ac.
- On Solaris (and perhaps other platforms),
the documentation may fail to install properly because
man/mkindex uses the -E flag with grep;
this flag is not understood by some versions of grep.
The solution is to
1) adjust your PATH so that an appropriate version
of grep is found;
2) edit man/mkindex at around line 160 and provide the
full pathname of an appropriate version of grep; or
3) edit man/mkindex at around line 160 and replace
grep -E "${which_el}" < "$el_f" | blah blah ...
with
sed -e "/${which_el}/p" -e d < "$el_f" | blah blah ...
DACS Version 1.4.24
Release Notes
This is primarily a bug fix release,
but it also introduces support for the Mac OS X 10.6/x86 platform.
As with earlier releases of DACS,
a variety of problems were encountered building third-party
software on OpenSolaris/x86.
These problems - and, sometimes, solutions - are addressed in
dacs.install(7).
Change Summary
- fixed several low-level bugs, some of which might have caused
DACS web services or utilities to crash
- added --enable-dump command line argument to aid debugging
(see dacs(1))
- added support for the FreeBSD 8.X (amd64) platform
(support for FreeBSD 7.X/amd64 continues)
- added support for the Mac OS X 10.6 on the x86 platform; note:
- if building OpenSSL, you may need to specify the 64-bit architecture
because its configuration appears to default to 32 bits; use e.g.,
/usr/bin/perl ./Configure darwin64-x86_64-cc \
--prefix=/usr/local/openssl-0.9.8l \
--openssldir=/usr/local/openssl-0.9.8l shared
- default owner/group of installed DACS files is "_www"
(names which seem to ship with the system);
this should probably agree with your Apache's httpd.conf settings
for User/Group
- third-party software upgrades:
OpenSSL 0.9.8l,
xmlsec1-1.2.14
Post-Release Notes
- A URI parsing bug causes some valid URIs to be considered invalid.
Examples:
% dacsexpr
> syntax(uri, "http://example.com?")
0
> syntax(uri, "http://example.com?foo")
0
> syntax(uri, "http://example.com?foo=baz")
0
A workaround is to insert a slash ("/") immediately before the
question mark.
- A virtual filestore bug can sometimes cause the "rename" operation,
when used with the dacs-kwv-fs scheme, to report success but result
in no data being modified.
- Several problems have been found in
dacs_transform(8)/dacstransform(1)
and their documentation;
until these are addressed in the next release,
please test carefully.
- Automatic conversion of a function argument to the string
data type may trigger an evaluation error in some cases.
A workaround is to use an explicit cast:
> hash((string) 123, 0)
- The XML document returned by
dacs_select_credentials
can be invalid because of a missing <ok> element.
If you require an immediate fix, edit src/select_credentials.c
and emit the element immediately after the
<dacs_select_credentials> element
(at or near line 439).
- Problems were apparently introduced by changes to CFB mode encryption
in OpenSSL 0.9.8m
[1,
2]
and DACS does not appear to work correctly with OpenSSL 0.9.8m,
0.9.8n, or 1.0.0.
Decryption/encryption performed by DACS using these releases of OpenSSL may not
be compatible with DACS releases that use earlier or later releases of OpenSSL.
These changes have apparently since been reversed in the OpenSSL code base.
Do not upgrade beyond the version(s) recommended for this release
of DACS
(see dacs.install(7)).
Note: after building DACS, always do a "make test".
- A bug has been found in
regmatch()
when subexpressions are used.
Matches may not be copied into a namespace if the namespace has already
been used.
- Though not yet confirmed, it appears that if any HTTP cookie
contains a double quote character, that HTTP cookie and subsequent ones
in the Cookie header may be ignored.
This can make it appear as if an authenticated user is unauthenticated,
for example, because the cookie bearing DACS credentials is not processed.
- Several long-standing problems with PAM-based authentication have been
identified.
Expect fixes and improved documentation in the next release.
DACS Version 1.4.23a
Release Notes
This release adds some refinements to the Information Card support,
introduces some new features, fixes some bugs,
and upgrades to recent releases of third-party supporting software.
Everyone is encouraged to upgrade to this release of DACS.
One significant new feature is an optional inactivity time out
(see the new directives,
ACS_TRACK_ACTIVITY and
ACS_INACTIVITY_LIMIT_SECS).
Another important feature is that
dacs_current_credentials can return information about a user's last
login and other logins that might be "active" - this can be useful for
detecting security breaches.
[Following the demise of CardSpace, support for Information Cards is
deprecated and web site material has been removed.]
If you are upgrading from an earlier release of DACS,
after installation check that you are using the site.conf
that comes with the new release.
Change Summary
- new InfoCard directives:
INFOCARD_STS_RP_ENDPOINT,
INFOCARD_TOKEN_MAX_LENGTH, and
INFOCARD_TOKEN_DRIFT_SECS
- new general directives:
ACS_TRACK_ACTIVITY and
ACS_INACTIVITY_LIMIT_SECS
- enhancements to
dacs_current_credentials(8),
including ability to report last sign on and active sign ons.
There is one potential incompatibility with previous releases, as the DTD
for the document returned by dacs_current_credentials has changed.
The different format is produced only if user tracking is enabled --
see
dacs(1).
The modifications to the XML are quite minor.
- third-party software upgrades:
Apache 2.2.14,
Samba 3.2.15,
BerkeleyDB 4.8.24,
GNU Readline 6.0,
libxml2-2.7.6,
xmlsec1-1.2.13
- bug fixes:
- dacs_version/dacsversion: reporting InfoCard enabled
- low-level database bug could cause random crashes
Post-Release Notes
Nothing yet.
DACS Version 1.4.23
Release Notes
This release mainly introduces support for Information Cards,
but it also includes some minor enhancements, bug fixes,
and upgrades to recent releases of third-party supporting software.
[Following the demise of CardSpace, support for Information Cards is
deprecated and web site material has been removed.]
If you are upgrading from an earlier release of DACS,
after installation check that you are using the site.conf
that comes with the new release.
Change Summary
- initial support for self-issued and managed InfoCards:
- reintroduction of dacs_select_credentials - review
dacs_select_credentials(8)
- special effective url pattern "*" - see
dacs.acls(5)
- extensions to index()
- fixed elapsed time calculation
- eliminated potential extraneous semi-colon when zapping DACS cookies
- the variable previously called JURISDICTION_URI is now called
JURISDICTION_URI_PREFIX
and a new variable called JURISDICTION_URI
has similar semantics but includes the request's scheme and any port
number
- new index table of variables added to the
Technical Documentation web page
- new directive: ACS_POST_EXCEPTION_MODE
- bug fixes:
- handling of -vfs argument (e.g., dacspasswd)
- regmatch() with multiple subexpressions and no namespace arg
- VERBOSE_LEVEL should not increase LOG_LEVEL
- PREDICATE directive in Roles clause
- getsize operation on HTTP types
- fixed potential segfault bug if decode(url, ...) fails, as when
SERVICE_ARGS is truncated
- fixes for parsing of Content-Type MIME headers
- added CSS for
dacs_current_credentials(8)
- set ACS_CREDENTIALS_LIMIT to 1 as the default
- added user("mine") variant
- added error-name CREDENTIALS_LIMIT (error-code 908)
to the ACS_ERROR_HANDLER
directive; this is undocumented in the manual and discovered too late to fix
(the error is triggered by
dacs_acs(8) if
ACS_CREDENTIALS_LIMIT
is exceeded).
- data type names used in
casts are now case sensitive
(they had been case insensitive, although that was not documented)
- third-party software upgrades:
openssl-0.9.8k, Apache 2.2.13,
OpenLDAP 2.4.17, Samba 3.2.14
Note: when upgrading to openssl-0.9.8j
there were some problems with "make install" and Makefiles under
the fips subdirectory did not have
INCLUDES set correctly and
some manual intervention was required to complete the build.
Additional details are here.
- improvements regarding logging of potentially sensitive information,
lowered priority of most Apache logging messages generated by
mod_auth_dacs
- upgrade Solaris 10 test platform to OpenSolaris 2008.11/x86 (SunOS 5.11)
Post-Release Notes
- You must use the built-in local_infocard_authentication module
rather than the web service; the latter mode of use is not fully implemented
(it will require changes to auth_reply.dtd).
Please see
dacs_authenticate(8).
- dacs_version(8) and
dacsversion(1)
do not report that InfoCard support has been enabled when it has been.
- A bug has been discovered that can cause DACS applications to crash,
particularly during configuration processing.
A fix will appear in the next release.
Building openssl-0.9.8j on FreeBSD
A "make install"
of the standard openssl-0.9.8j distribution fails on FreeBSD 7.0,
even if specifying only
--prefix and --openssldir to configure.
It may fail on other platforms, too
(I'm lookin' at you, OpenSolaris and Cygwin):
cp: fipscanister.o.sha1: No such file or directory
cp: fipscanister.o: No such file or directory
*** Error code 1
Stop in /usr/k/generic/src/sysutils/openssl-0.9.8j/fips.
Here is what was needed to fix the problem(s) on FreeBSD 7.0
(your mileage may vary).
- After unpacking the source distribution, run configure
- As usual, run:
% make
% make test
These should work properly; if they do, proceed.
- Do: make install
If it fails, continue with the following steps.
- Change to the fips subdirectory
- Edit each of {aes,des,dh,dsa,hmac,rand,rsa,sha}/Makefile and
(if necessary) change the value of INCLUDES
(defined near the beginning of the file) to:
INCLUDES=-I../.. -I..
- Run "make lib" in each of those directories:
% (cd aes; make lib)
% (cd des; make lib)
and so on
% (cd sha; make lib)
- Do: make fipscanister.o
It will probably report an error, but that's ok provided it actually creates
fipscanister.o.
- Do: make fips_standalone_sha1
- Do: ./fips_standalone_sha1 fipscanister.o > fipscanister.o.sha1
- Change to the distribution's root directory and try again to install:
% cd ..
% make install
If it still doesn't work, as on OpenSolaris and Cygwin,
try openssl-0.9.8i, which doesn't seem to
have these problems.
DACS Version 1.4.22
Release Notes
This release mainly fixes an assortment of bugs and upgrades to recent
releases of third-party supporting software.
- As in the past, Samba (3.2.7, this time)
would neither configure nor build on the Solaris 5.10 x86 platform
(see also DACS 1.4.15).
- Your mileage may vary, but when building OpenLDAP on the
Solaris 5.10 x86 platform, before running 'configure'
it was necessary to do
'setenv CC /usr/sfw/bin/gcc'
so that the correct compiler was found.
- On any platform, if you are including LDAP support and encounter
DACS build errors related to '-lsasl2' or 'sasl' symbols,
add the '--without-cyrus-sasl' flag when you run the
OpenLDAP 'configure', rebuild OpenLDAP, and then rebuild DACS.
Contrary to the documentation in inet(3),
the Solaris 5.10 x86 platform puts inet_aton() in libresolv;
if local_ldap_auth fails to build because inet_aton() is
not found, edit DACS's defs.mk (and defs.mk.in, if you like)
and add '-lresolv' to the end of the OPENLDAP_LIBS
definition, then run 'gmake' again.
- For the next release of DACS, we intend to upgrade to
OpenSolaris 2008.11 for testing.
Change Summary
- fixes for possibly buggy jurisdiction listing in dacs_admin(8)
- added optional public_key to jurisdiction's
group_member element in
groups.dtd
(used by dacs_admin, dacs_list_jurisdictions,
dacsinit)
- dacskey(1) can now print public
and private keys, bug fixes
- local_apache_auth handles large flat-file passwords
(htpasswd) quicker
- third-party support upgrades: OpenSSL 0.9.8i, OpenLDAP 2.3.43,
Apache 2.2.11, Samba 3.2.7, Berkeley DB 4.7.25
- new functions:
strtolower(),
strtoupper(),
strstr(),
strrstr()
- start at separating independent code into its own library,
libdss.a
- upgrade to docbook-xsl-1.74.0 and consequential minor format
processing changes
- additional tests for HMAC (FIPS 198-1)
- added configuration directive
AUTH_CREDENTIALS_ADMIN_LIFETIME_SECS
- fixes for URI decoding bugs
- build fixes for Solaris and GNU/Linux
- problems associated
with release 1.4.21 have been fixed;
truncated multipart/form-data arguments still sometimes occur,
but they should not cause dacs_acs to crash anymore
(see dacs_acs(8) and
the Apache configuration directive
SetDACSAuthPostBuffer
for details).
In any case, you should set SetDACSAuthPostBuffer to zero if
you do not require DACS to process the HTTP entity body.
If you are able to use the GET method instead, that will also avoid the problem.
[It seems that this problem with truncation is due to some recent subtle
changes in the way Apache processes brigades.]
Note that disabling this feature of DACS does not mean that you
cannot DACS-wrap programs that are run via POST, only that
DACS will not make variables contained within the POST data stream
available to its access control rules - the program will run normally
if DACS grants access.
Post-Release Notes
The following errata and comments are associated with this release:
- If you see the message "Mime parse of SERVICE_ARGS failed" in the
DACS log it suggests that the truncation problem mentioned above is occurring.
- Some browsers (Firefox3 is one of them) may formulate an HTTP request
using the POST method that includes a Content-Type header
that is valid but that DACS does not understand, causing DACS to ignore any
arguments in the entity body (meaning that the POST parameters are
not available to DACS).
In this context, a Content-Type header like
"application/x-www-form-urlencoded; charset=UTF-8" will trigger
the bug.
- The regmatch() function
may not return the correct value when there is at least one subexpression
in the regex and no namespace argument.
For example, "regmatch("foo", "(bar)|(baz)|(foo)")
returns 3 when it should return the string foo.
- The dacsacl(1) command unnecessarily
reformats its input ACL files. This is usually harmless, but can add a lot
of whitespace.
If a rule's url_pattern or url_expr attribute values contain
quotes, the corresponding INDEX file entries will sometimes not be read
correctly, resulting in an error and dacs_acs denying access.
If this happens, the INDEX file (and possibly also ACL files) will
need to be repaired manually.
- DACS may sometimes lose cookies following internal Apache redirects,
despite the access control rule in effect setting
pass_http_cookie to yes.
A symptom of this bug is that although a valid credentials cookie is sent
(possibly with other DACS or non-DACS cookies),
DACS appears to "forget" who is sending a request because the user's
DACS credentials are lost.
Other cookies may also mysteriously disappear, or disappear instead.
These internal redirections occur when Apache receives a request
that involves a DirectoryIndex directive, for instance.
This bug likely exists in earlier DACS releases.
For example, it is possible for Apache configuration to cause a user's
request for https://example.com to be internally redirected
to https://example.com/, then https://example.com/index.html,
and finally to https://example.com/index.php.
When this bug is triggered, the DACS rule for
https://example.com/index.php may not see the credentials that were
sent with the request.
If you require an immediate fix and are not concerned about DACS
cookies being revealed through environment variables
(such as when only trusted users have login access to your Apache box),
you can try a quick and dirty solution:
- change to the apache directory of the DACS distribution
- edit mod_auth_dacs.c (save the original, just in case)
- Locate the function dacs_cookie_zap() and make it
return immediately without doing anything
(just insert a return statement at its start)
- Do: make tag install
- Restart Apache
DACS Version 1.4.21
Release Notes
Although this release mainly addresses a wide assortment of bugs,
and upgrades to recent releases of third-party supporting software,
it also features some significant performance and administrative improvements.
Changes of note include:
- a new indexing mechanism for access control rules to accelerate
searches for the applicable rule - due to this change, however, the
dacsacl command must always be run after the ruleset
has been modified
(see dacsacl(1));
- re-introduction of the authorization caching feature,
a cookie-based mechanism to optionally bypass authorization checking of
requests after they have been approved once,
which can be of particular benefit for frequently accessed files such
as images and CSS files, or when a rule is relatively expensive to evaluate
(see dacs_acs(8));
- a complete rewrite of the dacs_admin web service to provide a
fully REST-ful, unified, and comprehensive administrative web-based console
[note that in this release, dacs_admin will only produce HTML output
and only supports read-only operations]
(see dacs_admin(8));
- extensions to the DACS programming language with new, composite data types
(lists, associative lists, and arrays)
[note that their implementation is mostly but not totally complete;
in particular, list references may not yet be embedded within strings]; and
- a new utility (dacsinit) for interactively configuring a
very basic federation and jurisdiction, which can help you to get started
with DACS quickly.
Change Summary
- Notable bug fixes and minor enhancements, including:
- Retirement of FreeBSD 4.X, 5.X, and 6.X testing platforms,
addition of FreeBSD 7.X (amd64) platform
- Upgrade to OpenSSL 0.9.8g
Note: when building it on FreeBSD, it was necessary to specify the
-fPIC flag to its config program
- Upgrades to Samba 3.0.28 and Apache 2.2.8/2.0.63
- Incompatible changes to access control rule processing:
- to both significantly improve performance and simplify the rule
processing engine, changes have been made to the way rules are named
and processed
- these changes will only affect users of earlier releases who are using
customized access control rules
- the new format preprocesses rules to create an index called
INDEX.
The index is an XML file
(with syntax acl_index.dtd)
located at the root
of each ACL directory structure
(e.g., /usr/local/dacs/acls/INDEX)
- you cannot have a rule file named "INDEX" (unless you change the
definition of ACL_INDEX_FILENAME and rebuild DACS)
- an index file is processed during rule processing to determine the rule
that best matches a request, so it must always reflect the set of
available rules and be up-to-date WRT their contents
- at most one rule file will be read during access control processing,
namely the best match
- the DTD
acl.dtd
has been revised with a new "status" attribute
(currently IMPLIED but eventually REQUIRED)
that is used to flag a
rule as enabled or disabled for access control checking purposes
- Release 1.4.21 ships with the standard DACS rules in the new format
- if an existing DACS installation has added custom ACLs, its old format
rules must be converted to the new format - the old format should no
longer be used
- because the changes affect the rule processing engine,
rules used by dacscheck(1)
must also be converted and indexed.
A command like the following might be used to do this
(your path will vary):
% dacsacl -un -build -vfs '[acls]file:///usr/local/myapp/rules'
- the
dacsacl(1)
command should be used to convert from the old format to
the new format:
% dacsacl -convert
this will create a new INDEX file or replace an existing one,
and edit existing rules to use the new "status" attribute
this should only need to be done one time (running it more than once
should not cause any problems, however, so if any errors are reported
you may re-run the conversion after fixing the problems)
- during conversion, rule files that were disabled in the old format will
also be disabled in the new format; if an old format file happens to
have a "status" attribute it will override the status implied
by its filename
- during conversion, the priority associated with any subdirectory is
lost, only the numeric suffix of files containing a rule is used
to determine the rule priority propagated to the INDEX file.
Manual attention may be required to preserve the intended order of
rule processing if subdirectory priority was significant in the old
format.
- rule files and subdirectories are not renamed during conversion
- apart from conversion to the new format, dacsacl does not support
the old format
- only the "acls" item type is converted,
not the "dacs_acls" (since
1.4.21 and later ship with the standard ACLs already converted)
- Important: after conversion check that the converted rules are enabled
or disabled properly. If you find an error, edit the rule and change its
status. When you are done, run dacsacl again.
- whenever a rule is added, deleted, or modified, dacsacl(1) must always
be run to rebuild the INDEX files:
% dacsacl -build
this will create new INDEX files or replace any existing ones and
assumes that rules are in the new format
(i.e., they have a "status" attribute)
- in the new format, all subdirectories are examined, regardless of any
"acl-" prefix, need not have a numeric suffix,
cannot be disabled,
and any numeric suffix does not influence rule priority
- in the new format, rule files must still begin with the
prefix "acl-"
(any other non-directory file names are ignored), but the
convention "acl-disabled" to signify a disabled
rule file is not followed - so although initially disabled after
conversion, in the new format a rule file or subdirectory
with this prefix does necessarily imply that the rule file or subdirectory
is disabled - only the INDEX determines that.
- in the new format, the "acl-" prefix is still required for files
containing rules but it is no longer required or significant for
subdirectories
- in the new format, priorities are non-negative integers, with zero
being the highest possible priority. Rules with equal priorities
are ordered based on the ASCII collating order strcmp(3) of their
full pathnames
- notwithstanding the conversion operation, in the new format a rule that
does not have a "status" attribute defaults to being disabled, and
the old style ACL prefix "acl-disabled" has no special meaning
(e.g., if such a rule is fed to dacsacl as a file argument
for syntax checking)
- in previous releases, if an error occurred while searching through rules
(e.g., a syntax error was found)
the search would terminate and access would be denied.
In the new format, if dacsacl finds an error in a rule it does not
update the INDEX file and because only the responsible rule is read,
errors in other rules should not trigger problems during rule processing.
- Incompatible changes and improvements to
dacs_admin(8)
- changes to resource naming (URLs) for more REST-ful conformance,
improved HTML interface
- bug fixes and minor improvements, including CSS support
- Re-introduction of the authorization caching feature
This allows positive access control decisions to be cached so that future
requests by the same client for resources controlled by the same rule
can be granted more quickly - see
dacs_acs(8)
- Addition of dacsinit, a script to create and initialize
a minimal, single jurisdiction federation.
There is currently no manual page for the program, but there are
brief descriptions
here and
here.
Run it with the -n flag the first time you use it.
If there is any positive feedback, the program is likely to be extended to
do more configuration and initializations.
Post-Release Notes
The following errata are associated with this release:
- The release accidentally shipped with a rule that allows all
access to dacs_admin.
This could potentially reveal information that should not be made
public, so it is important to either (1) disable the default rule for
dacs_admin,
(2) change the default to restrict access to dacs_admin, or
(3) add a custom rule for the jurisdiction, which will override the default,
and restrict access appropriately.
If you do (1) or (2), you should make the change to the installed
rule and to the rule that comes with the distribution
(acls/acl-admin.0) because 'make install' will replace
the installed rule with the rule that comes with the distribution.
Make sure that dacsacl is run after you make the changes,
and then verify that access has been disabled or restricted as you intend.
- A bug (or feature) in Makefile.in makes it necessary to build
DACS with the --enable-developer flag for dacs_admin to be
built and installed.
This will be changed in the next release.
- Examples of rules in the manual pages were not updated to
include the new "status" attribute.
(Note: the Tips have been revised to include
this attribute)
- It is not made clear in the manual page for
dacskey(1) that the
keyfile argument is accessed via the virtual filestore.
Therefore, a relative pathname is not acceptable.
- On some platforms, the pre-generated documentation in the distribution's
man directory may not unpack properly, causing make to think
that the documentation needs to be rebuilt even though it does not;
a bug in the Makefile can lead to the pre-generated documentation
files being truncated.
If this happens, restore the contents of the man directory from
the distribution tarball and do 'make touch install' from the
man directory.
- Optionally, DACS can be configured to use OpenLDAP
to supply core functionality for LDAP-based authentication
(local_ldap_auth).
On some platforms, OpenLDAP may fail to build, producing error messages
about undefined symbols beginning with "sasl_".
DACS does not require SASL support, so OpenLDAP can be configured with
the --with-cyrus-sasl=no flag.
- The local_apache_auth module runs very slowly when given a
large (e.g., thousands of entries) flat-file
(htpasswd) formatted password file.
Converting the file to Berkeley DB format (htdbm)
is currently the only solution (also see dbmmanage).
- The description of the
from() function should mention that
in the case where the argument is a full or partially matching domain name
and REMOTE_HOST is not available but
REMOTE_ADDR is,
a reverse DNS lookup will be performed on the argument and all IP addresses
that result will be tested against REMOTE_ADDR;
if this lookup fails, then the function raises an error condition and rule
processing will terminate.
You should therefore avoid using a domain name argument that may not be
resolvable on the host where DACS is run.
- Immediately after pasting the text to create a new access control rule in
Step 6.5 of the Quick Start tutorial, you must run
dacsacl(1) to rebuild the rule index:
% dacsacl -uj LA
You must always run dacsacl after you add or change an ACL.
- A bug was found in http(1) that breaks
the -f flag.
- A truncated multipart/form-data argument
(e.g., as a result of file uploading)
may cause dacs_acs(8) to crash.
Smaller uploads (up to approx. 7 KB) usually work, however.
Additionally, truncation may occur erroneously, depending on the size of
the argument, particular browser type being used, version of Apache,
and perhaps other environmental factors
(this problem has reared its ugly head before and appears to be intimately
related to Apache internals).
It may be possible to work around the problem(s) by adjusting
SetDACSAuthPostBuffer
and
ACS_POST_BUFFER_LIMIT.
Because the possibility of truncated arguments can never be eliminated,
there should probably be better ways to tell DACS what to do when they occur.
This and previous releases of DACS produce
HTTP cookies that have colons (and possibly other punctuation) in their names.
Although this is not known to cause problems with any web browsers,
it is
unacceptable to some versions of Tomcat.
It seems that
RFC 2109
(Sections 4.2.2 and 4.1)
and
RFC 2965
(Sections 3.2.2 and 3.1),
with
RFC 2616
(Section 2.2),
do not allow these "separators" to appear in a cookie name.
DACS does not currently have a workaround for
this problem, but then it does not claim to be RFC 2109/2965 compliant.
A future release of DACS will likely change
the syntax of its cookies to something benign.
Changes to the cookie name syntax may cause problems for interoperation
between different versions of DACS.
Note that middleware should not be relying upon (esp. parsing) the names of
DACS cookies, other than to identify the
different types of cookies, so a change should only be a minor inconvenience
for middleware.
It seems that issues may arise when
mod_rewrite
and
mod_proxy
come into play with DACS-wrapped resources.
A single proxied request may cause Apache to perform many authorization
checks.
Also, Apache mangles some variables associated with a proxied request
during processing (e.g., the REQUEST_URI)
and these may not be handled properly by DACS.
Avoid these kinds of requests, or at least test them carefully.
DACS Version 1.4.20
Release Notes
This is primarily a bug fix release.
DACS is security software - we urge all users to upgrade to the latest release.
Change Summary
- Bug fixes:
- important bug fix to local_passwd_authenticate prevents invalid
passwords from being accepted
- canonicalize the DACS error URL (avoiding a redundant acknowledgement
by dacs_notices(8))
- invalid Content-Type headers parsing
- buffer handling bugs
- VFS vfs-uri open bug
- renamed, refined, and documented
dacs_uproxy(8) (for security reasons,
it is not built by default)
- added -check argument to
dacskey(1) to do cursory key validation
- new functions:
ustamp(),
dacs_meta(),
dacs_approval()
- removed deprecated functions: hex_decode(), cescape(), mime_encode(),
mime_decode(), url_encode(), url_decode()
- third-party support upgrades: Samba 3.0.25b, BerkeleyDB 4.6.18,
OpenLDAP 2.3.37
- upgrade to GCC 4.2.1 for development
- dacs_prenv(8)
now sorts list of environment variables
- assorted fixes and improvements to
dacs.quick(7)
Post-Release Notes
While DACS is not officially supported on Solaris/SPARC,
a bug has been found on that platform that breaks the http(1) command
and internal HTTP requests.
One consequence of this bug is that authentication may fail;
this particular case can be avoided by using built-in authentication modules.
This bug will be fixed in the next release, but you can contact us for a patch.
The
SetDACSAuthConf
and
SetDACSAuthSiteConf
directives may not work properly.
Because these directives cause the environment variables
DACS_CONF and
DACS_SITE_CONF, respectively, to be passed to
dacs_acs(8),
a possible work-around is to explicitly set them in your Apache
configuration
(using
SetEnv,
for instance).
DACS should not be affected by the
problems
recently discovered in
OpenSSL 0.9.8e.
The next release of DACS will upgrade to the then-current release of OpenSSL.
DACS Version 1.4.19
Release Notes
This is primarily a bug fix and minor enhancements release.
DACS is security software - we urge all users to upgrade to the latest release.
Change Summary
- Bug fixes:
- handling of -expires date in
dacscookie(1) (also minor enhancements)
- dacsvfs(1)
must set field separator character properly
- multipart/form-data arguments not handled correctly
- setvar(split, ...) did not handle a trailing null element properly
- authorization tests after an internal redirect may have been
performed on the request URI again instead of the new target URI
or an empty string argument
- assorted fixes for
dacsrlink(1)
- ACS_ERROR_HANDLER
error-action was broken
-
dacs_list_jurisdictions(8)
with FORMAT=TEXT
- minor MIME whitespace parsing error
- fix for long-standing bug in
dacs_list_jurisdictions(8)
and
dacs_list_jurisdictions.dtd
plus some minor improvements and attribute renaming:
- attribute name renamed to jname (jurisdiction name)
- attribute name is now the full name of the jurisdiction
- attribute public_key renamed to fed_public_key
- attribute public_key is now the jurisdiction's public key,
if known
- bug fixes and overhaul to
dacsexpr(1)
command line processing.
Note: some changes are incompatible, though minor
Also:
- a -n flag for syntax checking
- removed -env flag
- improved "batch mode" (non-interactive) operation
- operation as a '#!' script
- fixes for bstring type
- parsing empty blocks, like "if (3) {} print('hi');"
- exec() now sets ${DACS::status} correctly
- fixes for
http(1), including handling binary content
- minor I/O processing bug fixes
formatting improvements for
dacs_conf(8) HTML
added expiry element to the concise syntax (an Rlink with an identity
can now be assigned a lifetime)
dacscheck(1)
can emit a redirection request (-redirect flag)
added -s flag to
dacsexpr(1)
DACS expression language changes:
added
AUTH_SINGLE_COOKIE
directive
removed obsolete manual pages
ignore expired rules via
expires_expr
attribute
extended
ACS_ERROR_HANDLER
to evaluate an expression, backward-compatible
changes to syntax, clarified documentation
added
dacslist(1)
command version of
dacs_list_jurisdictions(8)
change to DACS base-64 encoding character set to make encoded
strings safe in paths (this does not affect MIME base-64 encodings);
NOTE: the change is (temporarily) "mostly" backward compatible in that
the old encoding is still recognized, however some things could break.
DACS admins should take this opportunity to regenerate federation and
jurisdiction keys (see dacskey(1));
user passwords via local_passwd_authenticate
should also be updated
consolidated encoding/decoding functions into
encode() and
decode(),
and added dacs64 encoding type
NOTE: anyone using the old function names must make the obvious edits to
convert the old names into the new ones; the following functions are
deprecated and will be removed from a future release:
cescape(), hex_decode(), mime_encode(), mime_decode(), url_encode(),
url_decode()
additional internal PKI support
changed site.conf defaults for LOG_LEVEL and LOG_FORMAT
changes to default log message formats
added several new flags to
dacspasswd(1)
and various improvements.
Notes: These changes are backward compatible with existing DACS password
files. Not all of the new features can be accessed through
dacs_passwd(8),
dacs_admin(8), etc.
revisions to
dacs_passwd(8)
man page
use of DEFAULT_JURISDICTION environment variable - see
dacs(1)
upgrades: expat-2.0.1, samba-3.0.25a, openldap-2.3.35
new functionality for
cgiparse(8)
(should be backward compatible)
Added DACS_USERNAME to the "url syntax" argument list of
AUTH_SUCCESS_HANDLER
Post-Release Notes
- Important:
A bug in the local_passwd_authenticate authentication module
has been discovered that can cause an invalid DACS password to be accepted
when it should not be.
This does not affect any other forms of authentication or the
DACS password file.
Unless you are sure that you will not use this authentication module,
you must apply the following fix.
We apologize for the error.
This bug has been fixed and a new version of
src/local_passwd_auth.c is
available.
Replace the local_passwd_auth.c file (revid 1941)
that ships with dacs-1.4.19 with the new one (revid 1983).
Do a 'make clean' from the distribution's src directory,
then build and install DACS again.
Before deploying this or any other DACS authentication method in a production
system, please ensure that authentication succeeds only if all
authentication material is correct.
Correction: in the examples in
dacsauth(1),
the -vfs flag must appear with the module flags
(before the -u flag, for instance).
Regarding the notice acknowledgment feature
(dacs_notices(8),
dacs.nat(5)),
if a document requiring acknowledgement is accessed using the
https scheme, all links to the document must provide the port number
(even if it is 443) in its URL.
For instance, use
https://dss.fedroot.com:443/notices/ack-me.html
instead of
https://dss.fedroot.com/notices/ack-me.html.
Failure to do this causes users to see the same prompt twice.
The default port number will be handled correctly in the next release.
DACS Version 1.4.18
Release Notes
This is primarily a bug fix and minor enhancements release.
DACS is security software - we urge all users to upgrade to the latest release.
Notable improvements include:
- a new "authentication-at-authorization-time" feature that allows a
user identity to be established, either interactively or non-interactively,
via HTTP Basic Auth (RFC 2617) or using any available context
(the request URI, arguments, etc.);
see dacs_acs(8)
and ACS_PRE_AUTH
- a new "Rlinks" feature that can associate a URL with
authorizing rules and an identity, promoting collaboration and sharing;
see dacs_acs(8)
and dacsrlink(1)
- new functions:
counter(),
on_success(),
password(),
request_match(),
strptime(),
undef(),
var()
- new or enhanced directives:
ACS_FAIL,
ACS_PRE_AUTH,
ACS_SUCCESS,
AUTH_FAIL,
HTTP_AUTH,
HTTP_AUTH_ENABLE
Change Summary
- bug fixes for building shared library
- bug fix: conditional expressions could sometimes cause a segfault
- bug fix: application/x-www-form-urlencoded content type was
sometimes not properly encoded (this broke ampersands in passwords, for example)
- bug fix: make Args namespace available to configuration processing
- bug fix: http(1)
may write a binary body improperly
- replaced
Configuration.dtd,
which seems to have gotten lost, and updated
dacs_conf_reply.dtd
- added EXPR (-expr) pseudo-module to
dacsauth(1)
- added
strptime() function,
changes to time()
- dacs_authenticate(8)
now ignores unrecognized web service arguments
- tools/DACScheck* moved to tools/perl
- changes to
HTTP_AUTH and
HTTP_AUTH_ENABLE
directives in support of the new pre-authorization testing HTTP authentication
feature;
the changes to these two directives are backward compatible,
but anyone using either directives should review the updated descriptions
- added -invisible/-visible flags to
DACS_ACS
argument, with the former being the new default behaviour
- minimal support for Java via JNI - see
dacs.java(7)
- upgrade to Apache 2.2.4, OpenSSL 0.9.8e, Samba 3.0.24, OpenLDAP 2.3.34
- experimental
dacsauth() and
dacscheck() functions
note: use with care because they may have reentrancy bugs and may be
relatively heavy memory users
- added request_match()
function
- added -rlink flag to
DACS_ACS
(available as ${ARGS::RLINK} in ACS_PRE_AUTH expression)
- added the "n" modifier flag to
variables
- added
AUTH_FAIL,
ACS_SUCCESS,
ACS_FAIL,
ACS_PRE_AUTH directives
- added functions:
on_success(),
counter(),
var(),
password()
- minor enhancements to
time() function
- added ability to conditionally include a config directive via
undef()
- minor extensions to
acl.dtd for new optional attributes
- minor experimental addition to
acl.dtd
(the "identity" element)
- ACL checking extended to look at expires_expr
and url_expr attributes
- new BY_SIMPLE_REDIRECT error code for "pure" redirects
(this can be used with
redirect()
and a deny clause to create short links)
- addition of the Cookies namespace
- new "Rlinks" feature - see
dacsrlink(1)
- minor HTML formatting changes for
dacs_prenv(8)
- minor HTML formatting changes for
dacs_list_jurisdictions(8)
Post-Release Notes
There is a bug in
dacsvfs(1) that prevents a
field separator character other than the default (a colon) from being used.
A bug in http(1) causes improper output
buffering with the -ih flag.
Arguments passed through the multipart/form-data content type may
not be handled correctly.
Requests that are the result of an internal redirect by Apache may cause
DACS to become confused about the request URI that it should use.
The dacsrlink(1) command and its manual page have several bugs.
The -expires flag is buggy.
The manual page has a typo: the flag for the rlink operation
should be called -lmode instead of -mode.
The manual page lacks examples.
On Cygwin, a build using expat-2.0.0 was clean but the DACS binaries did not
work properly.
Building with expat-1.95.8 instead solved the problem.
DACS Version 1.4.17
Release Notes
This is primarily a bug fix and minor enhancements release.
DACS is security software - we urge all users to upgrade to the latest release.
Notable improvements include:
- a new 'simple' style of authentication via
local_simple_authenticate for inherently password-less
accounts (note that local_passwd_authenticate requires
a user provided password that cannot be the empty
string)
- improved handling of binary data
- upgrades to samba-3.0.23d, openldap-2.3.31, docbook-xsl-1.71.1
- new local_ldap_roles module can assign LDAP/ADS roles
to any user; it was previously necessary to
authenticate the user through local_ldap_authenticate
to obtain these roles
Neither Samba 3.0.23d nor 3.0.23c would build on the Solaris 5.10 x86 platform
(see also DACS 1.4.15).
Cygwin is once again (partially) supported.
Change Summary
- added new 'simple' style of authentication via
local_http_authenticate
for inherently password-less accounts (note that local_passwd_authenticate
requires a user provided password that cannot be the empty string)
- bug fix: composing and storing authentication styles in credentials
- bug fix: bareword not treated as string in some cases
- bug fix: empty role string from roles module not always handled properly
- improvements and clarifications to the OPTION Auth/Roles directive,
new
OPTION*
directive for better run-time adjustments
- bug fix: file(basename, ...) function
- new
AUTH_SUCCESS
directive gives a post-authentication hook
- clarifications and fixes to
LOG_FILTER directive's behaviour
- bug fix: variable modifier flag parsing
- updated copyright notices
- NOTE: six utilities have been renamed for consistency
aclcheck(1) to dacsacl(1),
conf(1) to dacsconf(1),
cookie(1) to dacscookie(1),
mkkey(1) to dacskey(1),
auth_grid(1) to dacsgrid(1),
auth_token(1) to dacstoken(1)
also renamed prenv(8) to dacs_prenv(8)
See
dacs(1)
for an explanation of the the naming convention. The original
names, which may have been confusing or conflicted with non-DACS software,
are temporarily still available via the dacs(1) command. Their manual
pages will be temporarily retained as reminders of the changes.
- added the unary type cast operator, and sizeof and typeof functions
- enhancements to the
substr() function
- improved handling of binary data for correct application of url_decode,
mime_decode, and future functions; new "bstring" data type;
new functions:
hex_decode(),
bstring(), and
cescape()
- added
hmac(),
digest(), and
random() functions
- documented C-style character and numeric escape codes
- upgrades to samba-3.0.23d, openldap-2.3.31, docbook-xsl-1.71.1
- fixed local_pam_auth build bug with shared libraries
- Auth/Roles/Transfer clause id tags are now case sensitive
- new
COOKIE_HTTPONLY
directive
- new
local_ldap_roles
module can assign LDAP/ADS roles to any user;
it was previously necessary to authenticate the user through
local_ldap_authenticate to obtain these roles
- Authorization header parsing using
setvar()
- bug fixes for building shared library
- minor extensions to
dacs_version(8) and its DTD
Post-Release Notes
A bug was found that may cause the Args namespace to be
unavailable during configuration processing by dacs_acs.
This will be fixed in the next release.
There may be problems compiling DACS on GNU/Linux if Apache was built
with large file support enabled (it was if apr.h defines
APR_HAS_LARGE_FILES to be 1).
Try configuring Apache's APR support library (srclib/apr) with
--disable-lfs, and then rebuilding Apache and DACS.
This will be addressed in the next release.
Apparently some GNU/Linux distributions sometimes install Apache's
apxs utility as apxs2.
In this case, DACS will not find apxs during its build.
A quick fix is to edit the DACS src/defs.mk.in file
and replace
apxs = $(apache_home)/bin/apxs
with wherever your apxs2 is, for example:
apxs = /usr/sbin/apxs2
DACS Version 1.4.16
Release Notes
This is primarily a bug fix and minor enhancements release. DACS is security
software - we urge all users to upgrade to the latest release.
Improvements of note include:
Note: In the final stages of testing we discovered that this
release of DACS does not
build on Cygwin, despite what is indicated elsewhere in the
DACS documentation.
This is because Cygwin lacks several library functions (even POSIX ones)
that are provided by all of the fully-supported platforms.
We will decide before the next release whether we will continue to
partially support the Cygwin platform or abandon it entirely.
Please let us know if you would like to see support for Cygwin continued.
Note: Minor but incompatible changes have been made to the
setvar function.
If you currently use this function, you will need to
review the documentation
and make appropriate changes before upgrading.
Change Summary
- bug fix: http_auth_jurisdiction variable didn't
set DACS_JURISDICTION
- bug fixes for building with Samba on GNU/Linux
- bug fixes for building with Samba on Solaris 8 (-lresolv)
- new authentication module, local_http_authenticate
(used to authenticate against a Google account, for instance)
- bug fix for
dacs_conf(8)
and conf(1)
where closing Roles tag may be omitted in XML and HTML output; CSS fix
- upgrade to OpenSSL 0.9.8d and Berkeley DB 4.5.20
- fixes to configure.ac:
--disable-... flags, --with-iconv processing
- added DACS_IDENTITY and DACS_CONCISE_IDENTITY
environment variables (useful with dacscheck)
- fix to Auth clause's INIT* directive to propagate
${Auth::CURRENT_USERNAME}
- distributed generation of user info records
(login/logout/access events),
written to "user_info" VFS type (--enable-user-info)
supports federation-wide tracking of user activity
(see dacs(1))
- minor VFS enhancements and bug fixes (file locking, append mode)
- bug fix: backslashes within strings were not always handled consistently,
especially two consecutive backslashes; this fix could possibly break some
existing strings that contain multiple consecutive backslashes
- build DACScheck.pm and install it in .../dacs/lib/perl
- additional test cases
- fixes for secure -aux prompting by dacsauth
- added -vfs flag to dacspasswd to specify alternate password file
- minor improvements to
revocation list processing,
including account disabling
- built-in versions of roles modules, fixes for enabling/disabling roles
modules by 'configure'
- minor build enhancements and simplifications
(including changes for linking shared libraries)
- fixes and improvements for
local_pam_authenticate
- added variables to the Conf namespace
(such as DACS_SITE_CONF and OPENSSL_PROG)
and renamed some for consistency
(such as SITE_CONF_SPEC to DACS_SITE_CONF_SPEC)
- added ${<namespace>::#} syntax to return the number of
variables in a namespace
- minor changes to
http(1)
- minor changes to
subset()
and
contains_any()
functions
- setvar() function:
- bug fixes and enhancements
- incompatible syntactical changes
- new operators:
copy, delete, load, loadi,
regsplit, split
- addition of "namespace" operator to
user() function
- redirect()
function now takes an optional error name or code
- bug fixes: CREDENTIALS_LIFETIME_SECS directive was ignored by
some auth modules
Post-Release Notes
In releases 1.4.16 and earlier, it is possible to create a DACS account that
has no password (the password is the empty string) but these accounts cannot
be used because
local_passwd_authenticate rejects these passwords
as a sanity check.
Password-less accounts will be addressed more consistently in release 1.4.17.
DACS Version 1.4.15
Release Notes
This is primarily a bug fix and minor enhancements release. DACS is security
software - we urge all users to upgrade to the latest release.
With this release, DACS now supports strong authentication based on the
Authenex A-Key hardware token
(and other OATH-HOTP/RFC 4226 compliant products).
This provides a very low cost and convenient path to two-factor
authentication, not only for web-based single sign-on and CGI programs, but for
virtually any software. No additional software is required to use the
Authenex token with DACS. We hope to support other vendors' products in
future releases. Besides auth_token(1),
please see a description of the
Authenex
A-Key and background on
two-factor
authentication.
This release no longer supports some PASSWORD_* directives,
as earlier advised.
If you configured them for a previous release, you will need to
delete some configuration directives.
Please see the
Change Summary.
This release includes incompatible changes to
dacs_auth_transfer(8).
If you configured it for a previous release, you will need to
change some configuration directives.
We apologize for the inconvenience, but we think you will agree that
the new way to configure cross-federation trusts is much simpler and
easier to understand.
Please see the
Change Summary.
We were unable to successfully build, or even configure, Samba 3.0.23c on
the Solaris 10 x86 platform but had no problems with it on FreeBSD and
GNU/Linux.
If you require NTLM support on the Solaris 2.8 platform and experience
difficulties building local_ntlm_auth, you may need to edit
src/defs.mk and add "-lresolv" to the
SAMBA_LIBS argument list
(this must be repeated if you re-run configure).
Please make sure you build Samba exactly as described in
dacs.install(7).
If this release of Samba does not build on your platform, or will not
work properly with DACS, try an earlier release that has been tested
with DACS: samba-3.0.23, samba-3.0.22, or samba-3.0.21a.
Although this release was tested with OpenSSL 0.9.8c, initial
testing with 0.9.8d has not revealed any problems and it should be ok to use.
Change Summary
Major changes and improvements include:
- upgrades to Apache 2.0.59 and Apache 2.2.3
- upgrades to Samba 3.0.23c, OpenSSL 0.9.8c, and OpenLDAP 2.3.27
- minor bug fixes to dacs_conf(8), conf(1), dacsauth(1), dacscheck(1),
and dacssched(1)
- renamed html/examples/login.html to html/examples/slogin.html and
added html/examples/login.html, a JavaScript version of login.php
- new authentication module to provide software-based, one-time passwords;
see auth_grid(1)
- new authentication module to support one-time password token devices;
see auth_token(1)
- new
dacs_autologin_ssl(8)
web service for automagic SSL login
- the
PASSWORD_MINIMUM_LENGTH,
PASSWORD_NEEDS_MIXED_CASE,
PASSWORD_NEEDS_PUNCTUATION,
and
PASSWORD_NEEDS_DIGITS
directives have been removed - use
PASSWORD_CONSTRAINTS;
PASSWORD_AUDIT
is now an Auth clause directive instead of a general directive
- added --with-cgi-suffix flag to configure
- extended syntax for
ACS_ERROR_HANDLER
directive (the optional url_pattern element)
- fixed local_cert_authenticate bug
- minor corrections and updates for
autologin(8)
- incompatible improvements and simplifications have been made
to
dacs_auth_transfer(8):
eliminated directives:
AUTH_TRANSFER_ERROR_URL,
AUTH_TRANSFER_IMPORT_URL,
and
AUTH_TRANSFER_SUCCESS_URL
eliminated VFS item types:
auth_transfer_imports,
auth_transfer_exports,
and
auth_transfer_cookies item types
added directive:
AUTH_TRANSFER_EXPORT
added: Transfer clause and new directives to dacs.conf
Some progress has been made with local_pam_authenticate and we hope to
have it functional in the next release.
Post-Release Notes
Both the HTML and XML output of conf(1) and dacs_conf(8) can be incorrect -
a closing Roles tag may be omitted.
This is insignificant for most users, but a
patch is available for
src/conf.c.
The CSS file for the HTML output (man/css/conf.css)
was not updated to include the new Transfer clause.
Though not important, a
patch is available.
DACS Version 1.4.14
Release Notes
This is primarily a bug fix and minor enhancements release.
It includes new applications that apply the
DACS rule processing engine
to problems other than web access control.
A
demonstration
of one of these applications,
dacs_transform(8),
is available.
The new dacstransform(1) command
was used to generate much of this site's documentation.
Improvements of note include:
- new configuration directives to enhance security and detect poor passwords
(see the Change Summary for a list of the new directives)
- improved tracking of user requests, including anonymous ones
- new applications of the DACS rule processing engine:
dacs_transform(8),
dacstransform(1),
dacssched(1),
and the
rule() predicate
Note:
A new feature, which is enabled by default, has been added to improve security.
Earlier releases will discard credentials generated by this release
unless the feature has been disabled at jurisdictions running this release,
however.
Please refer to the
VERIFY_UA directive for details.
Change Summary
Bug fixes, minor enhancements, and documentation improvements, including:
- upgrade to openldap-2.3.24
- upgrade to samba-3.0.23
- added rule() predicate, which exposes the rule processing engine
to expressions
- http(1) command redirect handling fixes
- new configuration directives (see
dacs.conf(5)):
PASSWORD_AUDIT,
PASSWORD_CONSTRAINTS
(Note: this new directive
replaces the PASSWORD_MINIMUM_LENGTH, PASSWORD_NEEDS_MIXED_CASE,
PASSWORD_NEEDS_PUNCTUATION, and PASSWORD_NEEDS_DIGITS directives,
which will be removed in future releases),
VERIFY_UA,
UNAUTH_ROLES,
ACS_CREDENTIALS_LIMIT
- added
ROLE_STRING_MAX_LENGTH
directive and improved role string error logging
- boolean value conversion fixes in expressions
- improved request tracking of unauthenticated users
New features:
- added
dacs_transform(8),
a prototype web service to demonstrate how the
DACS rule processing engine can be applied to document transformations
- added
dacstransform(1),
a command analog to dacs_transform(8)
- added
dacssched(1),
a prototype command to demonstrate how the DACS rule
processing engine can be applied to scheduling command execution
Post-Release Notes
None yet.
DACS Version 1.4.13
Release Notes
This is primarily a bug fix and minor enhancements release.
Please be sure to use dacs-1.4.13a - see below.
Important new features include:
Change Summary
Various minor bug fixes and man page improvements, including:
- port to Apache 2.2
requires --with-apache-apr flag when DACS is configured
- upgrade to Apache 2.0.58, Apache 2.2.2
- upgrade to openssl-0.9.8b
- minor changes to DACS license to clarify redistribution and repackaging
- new predicates file_owner() and file_group()
- completed and documented vfs() function
- added ${DACS::IDENTITY} variable
- fixed expression evaluation bug causing incorrect True/False result
from return/exit function
- fixed expression syntax bug when statement follows a brace-delimited
block: if (expr) { ... } statement
- fixed several expression parsing and evaluation bugs
- added 100+ initial expression test cases ("make tests")
- added NIST HMAC test vector tests
("make tests" or "make crypto; ./crypto")
- SSL library buffer management bug fix (affects http and sslclient)
- dacsauth, an initial version of a command line authentication program
- new authentication module, local_cas_authenticate, for authenticating
through the Central Authentication Service (CAS)
Post-Release Notes
DACS Version 1.4.12
Release Notes
This is primarily a bug fix and minor enhancements release.
Important new features include:
- the ability to authenticate against Apache htpasswd and htdbm files
using any DACS password-oriented authentication module
- a DACS implementation of RFC 2617 HTTP Basic Authentication supporting
authentication by any password-oriented DACS authentication module
- a DACS implementation of RFC 2617 HTTP Digest Authentication for
authenticating against Apache htdigest files
- built-in versions of authentication modules can be selected
Change Summary
Various minor bug fixes and man page improvements, including:
- added -ssl-flags argument to http(1)
- bug fix re COMPAT_MODE and old cookie name format
- bug fix re LOG_SENSITIVE directive
- bug fix re selection of "audit" log messages by LOG_FILTER
- minor fixes and improvements to dacscred and its documentation
- added tools/DACScheck.pm
- sslclient bug fixes
- clarification of regsub() behaviour
- bug fix for rule matching where Jurisdiction uri attribute ends in a slash
- new check for precondition element error
- fixes for Solaris 10 x86 platform
- bug fix re: <user name="any"/>
- minor improvements to http, including following redirects
- minor improvements to mkkey and its documentation
- properly ignore disabled rules
- upgrade to Samba 3.0.22
- upgrade to OpenLDAP 2.3.21
- configuration processing fixes and documentation clarifications
- Note: if the following directive appears in any site.conf or dacs.conf,
it should be deleted:
VFS "[default]dacs-fs:"
- Built-in authentication modules
In the Auth clause, you can use (so far):
URL="local_passwd_authenticate" (or URL="passwd")
URL="local_ntlm_authenticate" (or URL="ntlm")
URL="local_apache_authenticate" (or URL="apache")
URL="local_unix_authenticate" (or URL="unix")
For the last one, dacs_authenticate must be setuid root since it must
be able to read the shadow password file.
- Incompatible change to dacs_auth_agent local mode name mapping for
improved usability: Configure, e.g.,
VFS "[auth_agent_local_test]dacs-fs:/usr/local/dacs/testmap"
(previous behaviour of "auth_agent_local" is retained)
Where /usr/local/dacs/testmap is a file consisting of expressions,
one per line (a continued line ends with a backslash). Each expression
is evaluated until one is True; its value becomes the mapped username.
The value of the USERNAME argument is available to each expression
as ${Expr::_} (a new convention, reminiscent of Perl's $_ variable).
Say the file contains:
regsub(${Expr::_}, "^auggie doggie$", "auggie")
regsub(${Expr::_}, "^julia$", "sara")
If USERNAME is "auggie doggie", credentials will be issued for "auggie".
If USERNAME is "julia", credentials will be issued for "sara".
If USERNAME is something else, the request will fail.
- RFC 2617 Basic and Digest auth support:
- new local_apache_authenticate module lets DACS use
htpasswd, htdigest, and htdbm files directly
- does RFC 2617 Basic auth in conjunction with an htpasswd or htdbm file,
or with any DACS username/password based module
(e.g, local_unix_authenticate, local_ntlm_authenticate,
local_passwd_authenticate)
- does RFC 2617 Digest auth in conjunction with an htdigest file
- this feature should be considered semi-reliable pending additional testing
- documented in dacs_acs(8) and dacs_authenticate(8)
Post-Release Notes
- In previous versions, a reference to an undefined variable in a
configuration file did not result in an error; the empty string was
interpolated.
This behaviour has been changed in this release as a precaution against
buggy configuration files.
If you are upgrading from an earlier release and your configuration
file stops working, it may be because your dacs.conf or site.conf
tries to dereference an undefined variable.
Perhaps the easiest fix is to use the "e" or "?" modifier flag when
referencing a variable that might not be defined.
- The return/exit function sometimes yields an incorrect value.
- A syntax error can occur when a statement that
ends with a block is followed by another statement.
This sequence of statements should have the value 3:
if (1) { 2; } 3;
A temporary workaround is to explicitly separate the statements:
if (1) { 2; }; 3;
DACS Version 1.4.11
Release Notes
This is primarily a bug fix and minor enhancements release.
A new cross-federation identity transfer mechanism has been added.
It not only provides support for single sign-on among DACS federations,
but also between a DACS federation and other identity management systems.
See dacs_auth_transfer(8) for details.
The initial release of a web-based DACS administration interface called
FedAdmin will be made available shortly at Sourceforge's
contributed resource
project for DACS.
The DACS Java Library (DJL), which is being developed to
support the use of DACS in Java client applications, will also be updated.
Change Summary
Post-Release Notes
- This release uses va_copy(), which is not present in older
versions of stdarg(3) that come with GCC.
- The changes wrt cookie naming broke the pseudo-backward compatibility
enabled by the COMPAT_MODE directive.
This will be fixed in the next release.
The cookie name format change will, of course, also require all
jurisdictions within a federation to upgrade to this release if any
one of them upgrades, otherwise credentials may not be recognized.
While we apologize for any inconvenience, our mantra is "security first"
and we urge you to upgrade to the newest release as soon as you are able.
- The installation instructions in dacs.install(7) are missing
material on how to configure Apache for DACS.
You can obtain a
revised version
(right-click the link and "Save Link Target As..." or "Save Target As..."),
replace the one in your distribution's man directory with it,
and do a 'make install' from the man directory.
- A bug may prevent arguments passed as application/x-www-form-urlencoded
content type in the message body from being accessible in the
Args namespace.
- A bug prevents all "sensitive" messages from being logged, even
if LOG_SENSITIVE is set to "yes".
- A bug in the LOG_FILTER directive prevented non-audit events from being
properly ignored.
- A bug in configuration processing sometimes causes variables
in the Conf namespace to be interpolated as the empty string.
- Additional changes (not listed above):
- new directives: COOKIE_NO_DOMAIN and CSS_PATH
- bug fix for sslclient
- bug fix for installion of shared libraries
DACS Version 1.4.10
Release Notes
Change Summary
This release contains some minor new features, fixes bugs, and
improves the documentation.
A
contributed resource
project for DACS is now available.
The DACS Java Library (DJL) is being developed to support the use of DACS
in Java client applications. It implements Java wrapper classes for selected
DACS services, and provides an HTTP client through which DACS services may be
accessed and DACS credentials obtained and managed.
Changes of note:
- added -D as a dacsoption flag - see dacs(1)
- optional LOG_FORMAT directive added,
LOG_FEDERATION_NAME removed
(note: remove the latter from configuration files)
- optional SSL_PROG_ARGS directive added
- initial implementation of experimental COMPAT_MODE
directive to prevent DACS 1.2 credentials from being discarded
- implemented missing assignment operators
(+=, -=, etc.) and pre/post
inc/dec operators for integer variables
(${var}++, etc.)
- a default namespace ("Temp") is now allowed as a convenience:
${foo} = 17 is equivalent to ${Temp::foo} = 17
This can be disabled, or the name changed, at compile time
- added a PHP example to dacscheck(1)
- added if/elseif/else statement and the comma operator
- added expression testing framework to dacsexpr(1)
(see its -et flag)
- added -uj and -us dacsoptions
flags for convenience
- extensions to the VERIFY_IP directive
- upgrades to expat-2.0.0, BerkeleyDB 4.4.20, samba-3.0.21a, openldap-2.3.18
- added STATUS_LINE directive and
-status_line/-no_status_line DACS_ACS flags
Post-Release Notes
- On some newer GNU/Linux distributions, sslclient appears to fail randomly:
% perl -e 'printf "GET / HTTP/1.0\n\n";' | sslclient fedroot.com:443 > /dev/null
ssllib: set_nonblocking: fcntl: Invalid argument
If you want an immediate fix, replace your
src/ssllib.c with
ssllib.c.gz
[SHA(ssllib.c)= df23421c6f826b9cdac7d2f2a9491898b6137ef3]
- "make install" may fail if shared libraries have been configured.
To fix this, edit Makefile
(and/or Makefile.in), look for the targets
install-libs and install-shared-lib, and remove the string
"/$(SHARED_LIB)".
Or simply disable shared libraries (--disable-shared)
when you build this release.
DACS Version 1.4.9
Release Notes
Change Summary
This release contains some minor new features, fixes bugs, and
improves the documentation.
Other changes:
- many bug fixes and documentation revisions and improvements
- fixes and improvements to the dacscheck(1) command and its man page
- fixes to autologin(8) and exec() function
- fixes to local_roles, local_unix_roles, and dacs_authenticate(8)
- added the Env namespace
- fixes to dacs_notices(8) and its man page
- fixes to the virtual filestore and its documentation
- added --with-apache=omit (see INSTALL)
- added ability to select case sensitive/insensitive comparison of
federation/jurisdiction/usernames. See docs for the new NAME_COMPARE
directive and the revised user() predicate.
A consequence of this change is that accounts created by dacspasswd
are now lowercase names; otherwise case-insensitive comparisons will
consider "Bob" and "bob" equivalent. Some such existing accounts will
become inaccessible if the admin changes to case-insensitive names.
- added DACS-Status-Line with -check_only and -check_fail flags; see
dacs_acs(1)
- changes to dacs_acs.dtd
Post-Release Notes
None.
DACS Version 1.4.8
Release Notes
Change Summary
The major change is the new
dacscheck(1)
command, which we believe will
open up DACS to many developers and many new
applications. It provides
simplified, platform-independent, general-purpose access to the
DACS access
control rule evaluation engine. This feature can be used by any virtually
any application,
script (Perl, PHP, shell, etc.), server software, or CGI
program to make data-driven access control decisions rather than
program-driven ones. dacscheck can be used by itself and does not depend
on any other DACS programs,
web services, or even an web server. Simply
install it and start to use it. Please refer to the manual page for details
and examples.
Other changes:
- many bug fixes and documentation revisions and improvements
- upgrade to OpenSSL 0.9.8a
- new configuration directives for password constraints
- fixes for Cygwin
- backward compatible changes to the AUTH_SUCCESS_HANDLER
and SIGNOUT_HANDLER directives
- changes to dacs_passwd, its DTD and default ACL
- changes to DACS name parsing and user() predicate
- changes to behaviour of permit_chaining attribute
Post-Release Notes
- A bug in dacscheck(1) causes identities given in the "concise syntax"
to be parsed incorrectly.
A partial workaround is to omit the squirrelly braces;
for example, use
-i u=bobo or
-i u="bobo" or
-i 'u="bobo"'
instead of
-i '{u="bobo"}'
- A bug in dacscheck(1) may cause SEGVs on system configurations
where hostname(1) does not return the host's FQDN.
You can use the -fn flag to explicitly provide a federation name.
- A bug in autologin(8) prevents it from operating correctly.
The fix is to get
REMOTE_USER from the environment and pass its value as
the USERNAME argument to dacs_authenticate.
- A bug in expression evaluation causes a non-zero return status of
a command executed by exec() to abort evaluation.
- A bug in http(1) causes the -user-agent flag to be ignored.
DACS Version 1.4.7
Release Notes
Please note the following important changes/incompatibilities:
- changed from comma-separated URI lists to space-separated lists in all
notice acknowledgement XML
- changed ack() predicate to take individual URI arguments rather than
a single URI argument; NB: this may require changes to existing ACLs that
use the ack() predicate
- a "secure" cookie is emitted if a request comes over https, regardless of
SECURE_MODE
- Renamed acl-auth.0 to the more accurate acl-local-auth.0
Note: after acl-local-auth.0 has been installed, delete a previously
installed copy of acl-auth.0
- A new feature called ACL delegation allows a DACS
administrator to delegate access control decisions for a portion of the
URL space to another person (or DACS identity) or to rules obtained from
another source. See dacs.acls(5).
- The store command is now called vfs (delete any
previously installed copies of store).
Post-Release Notes
- Apache's AddDACSAuth directive's command-line-arg-string argument,
which is supposed to be optional, must actually be provided.
This will be fixed in the next release; in the meantime, you can use "-v".
- A bug in dacs_auth_agent's local mode of operation requires
the item type auth_agent_local to be configured (it's supposed to be optional).
This will be fixed in the next release.
- Where the INSTALL file describes sslclient, replace
www.fedroot.com
with fedroot.com.
Change Summary
This release includes:
- many bug fixes and documentation revisions
- some log entries now include a "session tracking identifier"
- sensible https/SSL defaults for the http command
- new dacs_auth_agent web service
- replacement of Store clause with VFS configuration
directive
Note: this may require revisions to dacs.conf and site.conf
- added version header/footer lines to HTML man pages
- important bug fixes for local_ntlm_authenticate and local_ldap_authenticate
- upgrades to samba-3.0.20a, openldap-2.2.26, docbook-xsl-1.69.1,
openssl-0.9.7i, and Apache 2.0.55
- new delegated ACLs feature
- aclcheck now also checks the revocation list
- reworking of the former "url" virtual filestore type (now called "vfs")
- http/https URI schemes are supported by the new VFS directive
DACS Version 1.4.6
Release Notes
Authentication bugs
Bugs in the NTLM and LDAP authentication modules have been found that
may cause authentication to fail.
Fixes for these bugs will appear in the next release.
Checksums
After obtaining a DACS release, please verify all checksums
for the file you downloaded.
Do not use a download if any checksum for it does not match.
Checksums will be posted here from now on.
OpenSSL's "dgst" command can be used to compute checksums:
openssl dgst -md5 dacs-1.4.6.tgz
openssl dgst -sha1 dacs-1.4.6.tgz
Checksums for dacs-1.4.6.tgz:
-rw-r--r-- 1 brachman wheel 1320654 Sep 19 16:24 dacs-1.4.6.tgz
MD5: c5c7bc5a941b9f568f2777c523aec121
SHA-1: f2783a0ecd769c332981f28c1fa7f4cd8c746a25
Checksums for dacs-1.4.6.tbz:
-rw-r--r-- 1 brachman wheel 972539 Sep 19 16:24 dacs-1.4.6.tbz
MD5: 7c1a510dee6e41d33eca4dfadd15afa5
SHA-1: 69137b4913f838eb8bcca17690b589bd26c3039d
A note about upgrading
Because DACS is security software, we strongly recommend that you upgrade to
the newest release as soon as you are able. This is neither a difficult nor
a time consuming procedure most times. Sometimes an incompatible change in
DACS will require you to change a DACS configuration file, but this should
not be difficult to do and we will try to advise you of such changes.
For a quick and dirty upgrade (assumes you aren't changing any third-party
packages or options):
- Obtain and unpack the new distribution and cd to it;
- Review the README and INSTALL instructions;
- Copy the src/config.nice from your installed version to the
new src directory and configure DACS:
"cd src; sh ./config.nice";
- Build DACS ("gmake");
- Stop Apache httpd ("apachectl stop");
- Install DACS ("gmake install");
- Make and install the latest mod_auth_dacs module
"cd ../apache; gmake tag install";
- Restart Apache httpd ("apachectl start"); and
- Check that DACS appears to be working correctly.
This will leave your existing DACS
configuration files alone but it will also leave files that are no longer
needed by the new DACS.
Note: whenever you upgrade to a more recent version of
DACS, please do not
forget to install the Apache mod_auth_dacs module that comes with your
new version of DACS.
Change Summary
This release includes:
- many bug fixes and documentation revisions
- initial version of dacs_notices
- initial version of dacscred
- improved support for middleware, changes to dacs_acs
DACS_ACS argument
- logging enhancements, including support for syslog(3)
DACS Version 1.4.5
Release Notes
Change Summary
DACS Version 1.4.4
Release Notes
Change Summary
DACS Version 1.4.3
Release Notes
If you are upgrading to this version of DACS from an older version
of DACS 1.4:
Documentation for the dacs_signout web service is missing from the
distribution.
Its manual page is available
here.
Change Summary
DACS Version 1.4.2
Release Notes
Index: INSTALL
- Please pay careful attention to the descriptions of the third-party
packages.
- For a few third-party packages, it is important that you use the
exact version that is mentioned.
Do not use anything newer or older.
- For other packages, a particular release is recommended.
It is less critical that you use the recommended release, but older
releases may have important bugs, including security problems.
Newer releases will not have been tested with DACS.
- You may save yourself time and headaches if you just use the
recommended releases.
Index: HISTORY
- added suport for LDAP and Microsoft ADS based authentication
- improved man pages
- minor bug fixes
- minor changes:
- new and renamed DACS expression functions, including
ldap name parsing
- if -v and --version are given, also print module version
stamps
- an initial version of WWW-Authenticate/Authorization
header handling (ACS can respond with or accept
RFC 2617 headers)
- added "ndbm" storage method (includes gdbm in
compatibility mode)
- added missing C/C++ bit operators for DACS expressions
Change Summary
© Copyright 2003-2025 DSS Distributed Systems Software, Inc.
All rights reserved.
$Id: $