# # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. from __future__ import absolute_import, division, print_function from nacl import exceptions as exc from nacl._sodium import ffi, lib from nacl.utils import ensure # crypto_hash_BYTES = lib.crypto_hash_bytes() crypto_hash_BYTES = lib.crypto_hash_sha512_bytes() crypto_hash_sha256_BYTES = lib.crypto_hash_sha256_bytes() crypto_hash_sha512_BYTES = lib.crypto_hash_sha512_bytes() def crypto_hash(message): """ Hashes and returns the message ``message``. :param message: bytes :rtype: bytes """ digest = ffi.new("unsigned char[]", crypto_hash_BYTES) rc = lib.crypto_hash(digest, message, len(message)) ensure(rc == 0, 'Unexpected library error', raising=exc.RuntimeError) return ffi.buffer(digest, crypto_hash_BYTES)[:]
# Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. from __future__ import absolute_import, division, print_function from nacl import exceptions as exc from nacl._sodium import ffi, lib from nacl.exceptions import ensure # crypto_hash_BYTES = lib.crypto_hash_bytes() crypto_hash_BYTES = lib.crypto_hash_sha512_bytes() crypto_hash_sha256_BYTES = lib.crypto_hash_sha256_bytes() crypto_hash_sha512_BYTES = lib.crypto_hash_sha512_bytes() def crypto_hash(message): """ Hashes and returns the message ``message``. :param message: bytes :rtype: bytes """ digest = ffi.new("unsigned char[]", crypto_hash_BYTES) rc = lib.crypto_hash(digest, message, len(message)) ensure(rc == 0, 'Unexpected library error', raising=exc.RuntimeError)