/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * 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. */ package org.apache.shiro.crypto.hash; import org.apache.shiro.codec.Base64; import org.apache.shiro.codec.Hex; /** * Generates an SHA-1 Hash (Secure Hash Standard, NIST FIPS 180-1) from a given input <tt>source</tt> with an * optional <tt>salt</tt> and hash iterations. * <p/> * See the {@link SimpleHash SimpleHash} parent class JavaDoc for a detailed explanation of Hashing * techniques and how the overloaded constructors function. * * @since 0.9 */ public class Sha1Hash extends SimpleHash { //TODO - complete JavaDoc public static final String ALGORITHM_NAME = "SHA-1"; public Sha1Hash() { super(ALGORITHM_NAME); } public Sha1Hash(Object source) { super(ALGORITHM_NAME, source); } public Sha1Hash(Object source, Object salt) { super(ALGORITHM_NAME, source, salt); } public Sha1Hash(Object source, Object salt, int hashIterations) { super(ALGORITHM_NAME, source, salt, hashIterations); } public static Sha1Hash fromHexString(String hex) { Sha1Hash hash = new Sha1Hash(); hash.setBytes(Hex.decode(hex)); return hash; } public static Sha1Hash fromBase64String(String base64) { Sha1Hash hash = new Sha1Hash(); hash.setBytes(Base64.decode(base64)); return hash; } }