/****************************************************************************** * Product: Adempiere ERP & CRM Smart Business Solution * * Copyright (C) 1999-2006 ComPiere, Inc. All Rights Reserved. * * This program is free software; you can redistribute it and/or modify it * * under the terms version 2 of the GNU General Public License as published * * by the Free Software Foundation. This program is distributed in the hope * * that it will be useful, but WITHOUT ANY WARRANTY; without even the implied * * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * * See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * * with this program; if not, write to the Free Software Foundation, Inc., * * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. * * For the text or an alternative of this public license, you may reach us * * ComPiere, Inc., 2620 Augustine Dr. #245, Santa Clara, CA 95054, USA * * or via info@compiere.org or http://www.compiere.org/license.html * *****************************************************************************/ package org.compiere.util; import java.io.UnsupportedEncodingException; import java.math.BigDecimal; import java.security.NoSuchAlgorithmException; import java.sql.Timestamp; /** * iDempiere interface for enryption, decryption.
* To enable your own class, you need to set the property ADEMPIERE_SECURE * when starting the client or server.
* The setting for the default class would be:
* -DADEMPIERE_SECURE=org.compiere.util.Secure * * @author Jorg Janke * @version $Id: SecureInterface.java,v 1.2 2006/07/30 00:52:23 jjanke Exp $ */ public interface SecureInterface { /** Class Name implementing SecureInterface */ public static final String ADEMPIERE_SECURE = "ADEMPIERE_SECURE"; /** Default Class Name implementing SecureInterface */ public static final String ADEMPIERE_SECURE_DEFAULT = "org.compiere.util.Secure"; /** Clear Text Indicator xyz */ public static final String CLEARVALUE_START = "xyz"; /** Clear Text Indicator */ public static final String CLEARVALUE_END = ""; /** Encrypted Text Indiactor ~ */ public static final String ENCRYPTEDVALUE_START = "~"; /** Encrypted Text Indiactor ~ */ public static final String ENCRYPTEDVALUE_END = "~"; /** * Encryption. * @param value clear value * @param AD_Client_ID * @return encrypted String */ public String encrypt (String value,int AD_Client_ID); /** * Decryption. * @param value encrypted value * @return decrypted String */ public String decrypt (String value,int AD_Client_ID); /** * Encryption. * @param value clear value * @param AD_Client_ID * @return encrypted integer value */ public Integer encrypt (Integer value,int AD_Client_ID); /** * Decryption. * @param value encrypted value * @param AD_Client_ID * @return decrypted integer value */ public Integer decrypt (Integer value,int AD_Client_ID); /** * Encryption. * @param value clear value * @param AD_Client_ID * @return encrypted BigDecimal value */ public BigDecimal encrypt (BigDecimal value,int AD_Client_ID); /** * Decryption. * @param value encrypted value * @param AD_Client_ID * @return decrypted BigDecimal value */ public BigDecimal decrypt (BigDecimal value,int AD_Client_ID); /** * Encryption. * @param value clear value * @param AD_Client_ID * @return encrypted Timestamp value */ public Timestamp encrypt (Timestamp value,int AD_Client_ID); /** * Decryption. * @param value encrypted value * @param AD_Client_ID * @return decrypted Timestamp value */ public Timestamp decrypt (Timestamp value,int AD_Client_ID); /** * Digest string value.
* JavaScript version see - http://pajhome.org.uk/crypt/md5/index.html * * @param value message * @return HexString of digested message (length = 32 characters) */ public String getDigest (String value); /** * Checks, if value is a valid digest * @param value digest string * @return true if valid digest */ public boolean isDigest (String value); /** * Convert String and salt to SHA-512 hash with iterations
* https://www.owasp.org/index.php/Hashing_Java * * @param value message * @return HexString of message (length = 128 characters) * @throws NoSuchAlgorithmException * @throws UnsupportedEncodingException */ public String getSHA512Hash (int iterations, String value, byte[] salt) throws NoSuchAlgorithmException, UnsupportedEncodingException; } // SecureInterface