man.isc-hmac-fixup.html revision e9ed929fd1a190f29391be9c7ae324e7e56ff9c9
1N/A<!--
1N/A - Copyright (C) 2004-2015 Internet Systems Consortium, Inc. ("ISC")
1N/A - Copyright (C) 2000-2003 Internet Software Consortium.
1N/A -
1N/A - Permission to use, copy, modify, and/or distribute this software for any
1N/A - purpose with or without fee is hereby granted, provided that the above
1N/A - copyright notice and this permission notice appear in all copies.
1N/A -
1N/A - THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
1N/A - REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
1N/A - AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
1N/A - INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
1N/A - LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
1N/A - OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
1N/A - PERFORMANCE OF THIS SOFTWARE.
1N/A-->
1N/A<!-- $Id$ -->
1N/A<html>
1N/A<head>
1N/A<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
1N/A<title>isc-hmac-fixup</title>
1N/A<meta name="generator" content="DocBook XSL Stylesheets V1.71.1">
1N/A<link rel="start" href="Bv9ARM.html" title="BIND 9 Administrator Reference Manual">
1N/A<link rel="up" href="Bv9ARM.ch13.html" title="Manual pages">
1N/A<link rel="prev" href="man.genrandom.html" title="genrandom">
1N/A<link rel="next" href="man.nsec3hash.html" title="nsec3hash">
1N/A</head>
1N/A<body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF">
1N/A<div class="navheader">
1N/A<table width="100%" summary="Navigation header">
1N/A<tr><th colspan="3" align="center"><span class="application">isc-hmac-fixup</span></th></tr>
1N/A<tr>
1N/A<td width="20%" align="left">
1N/A<a accesskey="p" href="man.genrandom.html">Prev</a>�</td>
1N/A<th width="60%" align="center">Manual pages</th>
1N/A<td width="20%" align="right">�<a accesskey="n" href="man.nsec3hash.html">Next</a>
1N/A</td>
1N/A</tr>
1N/A</table>
1N/A<hr>
1N/A</div>
1N/A<div class="refentry" lang="en">
1N/A<a name="man.isc-hmac-fixup"></a><div class="titlepage"></div>
1N/A<div class="refnamediv">
1N/A<h2>Name</h2>
1N/A<p><span class="application">isc-hmac-fixup</span> &#8212; fixes HMAC keys generated by older versions of BIND</p>
1N/A</div>
1N/A<div class="refsynopsisdiv">
1N/A<h2>Synopsis</h2>
1N/A<div class="cmdsynopsis"><p><code class="command">isc-hmac-fixup</code> {<em class="replaceable"><code>algorithm</code></em>} {<em class="replaceable"><code>secret</code></em>}</p></div>
1N/A</div>
1N/A<div class="refsect1" lang="en">
1N/A<a name="id2625997"></a><h2>DESCRIPTION</h2>
1N/A<p>
1N/A Versions of BIND 9 up to and including BIND 9.6 had a bug causing
1N/A HMAC-SHA* TSIG keys which were longer than the digest length of the
1N/A hash algorithm (i.e., SHA1 keys longer than 160 bits, SHA256 keys
1N/A longer than 256 bits, etc) to be used incorrectly, generating a
1N/A message authentication code that was incompatible with other DNS
1N/A implementations.
1N/A </p>
1N/A<p>
1N/A This bug has been fixed in BIND 9.7. However, the fix may
1N/A cause incompatibility between older and newer versions of
1N/A BIND, when using long keys. <span><strong class="command">isc-hmac-fixup</strong></span>
1N/A modifies those keys to restore compatibility.
1N/A </p>
1N/A<p>
1N/A To modify a key, run <span><strong class="command">isc-hmac-fixup</strong></span> and
1N/A specify the key's algorithm and secret on the command line. If the
1N/A secret is longer than the digest length of the algorithm (64 bytes
1N/A for SHA1 through SHA256, or 128 bytes for SHA384 and SHA512), then a
1N/A new secret will be generated consisting of a hash digest of the old
1N/A secret. (If the secret did not require conversion, then it will be
1N/A printed without modification.)
1N/A </p>
1N/A</div>
1N/A<div class="refsect1" lang="en">
1N/A<a name="id2670057"></a><h2>SECURITY CONSIDERATIONS</h2>
1N/A<p>
1N/A Secrets that have been converted by <span><strong class="command">isc-hmac-fixup</strong></span>
1N/A are shortened, but as this is how the HMAC protocol works in
1N/A operation anyway, it does not affect security. RFC 2104 notes,
1N/A "Keys longer than [the digest length] are acceptable but the
1N/A extra length would not significantly increase the function
1N/A strength."
1N/A </p>
1N/A</div>
1N/A<div class="refsect1" lang="en">
1N/A<a name="id2670073"></a><h2>SEE ALSO</h2>
1N/A<p>
1N/A <em class="citetitle">BIND 9 Administrator Reference Manual</em>,
1N/A <em class="citetitle">RFC 2104</em>.
1N/A </p>
1N/A</div>
1N/A<div class="refsect1" lang="en">
1N/A<a name="id2670090"></a><h2>AUTHOR</h2>
1N/A<p><span class="corpauthor">Internet Systems Consortium</span>
1N/A </p>
1N/A</div>
1N/A</div>
1N/A<div class="navfooter">
1N/A<hr>
1N/A<table width="100%" summary="Navigation footer">
1N/A<tr>
1N/A<td width="40%" align="left">
1N/A<a accesskey="p" href="man.genrandom.html">Prev</a>�</td>
1N/A<td width="20%" align="center"><a accesskey="u" href="Bv9ARM.ch13.html">Up</a></td>
1N/A<td width="40%" align="right">�<a accesskey="n" href="man.nsec3hash.html">Next</a>
1N/A</td>
1N/A</tr>
1N/A<tr>
1N/A<td width="40%" align="left" valign="top">
1N/A<span class="application">genrandom</span>�</td>
1N/A<td width="20%" align="center"><a accesskey="h" href="Bv9ARM.html">Home</a></td>
1N/A<td width="40%" align="right" valign="top">�<span class="application">nsec3hash</span>
1N/A</td>
1N/A</tr>
1N/A</table>
1N/A</div>
1N/A<p style="text-align: center;">BIND 9.11.0pre-alpha</p>
1N/A</body>
1N/A</html>
1N/A