001 /* 002 * Cumulus4j - Securing your data in the cloud - http://cumulus4j.org 003 * Copyright (C) 2011 NightLabs Consulting GmbH 004 * 005 * This program is free software: you can redistribute it and/or modify 006 * it under the terms of the GNU Affero General Public License as 007 * published by the Free Software Foundation, either version 3 of the 008 * License, or (at your option) any later version. 009 * 010 * This program is distributed in the hope that it will be useful, 011 * but WITHOUT ANY WARRANTY; without even the implied warranty of 012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 013 * GNU Affero General Public License for more details. 014 * 015 * You should have received a copy of the GNU Affero General Public License 016 * along with this program. If not, see <http://www.gnu.org/licenses/>. 017 */ 018 package org.cumulus4j.crypto; 019 020 import org.bouncycastle.crypto.KeyGenerationParameters; 021 import org.bouncycastle.crypto.params.KeyParameter; 022 023 /** 024 * Generator for secret keys to be used in <a target="_blank" href="http://en.wikipedia.org/wiki/Symmetric_encryption">symmetric encryption</a>. 025 * 026 * @author Marco หงุ่ยตระกูล-Schulze - marco at nightlabs dot de 027 */ 028 public interface SecretKeyGenerator 029 { 030 /** 031 * Initialise this <code>SecretKeyGenerator</code>. Implementations should 032 * be able to initialise with defaults, if no parameters are given (i.e. <code>params</code> being <code>null</code>). 033 * Usually, defaults mean to generate 256 bit keys. 034 * @param params the parameters or <code>null</code>, if defaults should be used. 035 */ 036 void init(KeyGenerationParameters params); 037 038 /** 039 * Generate random a secret key. Throws an {@link IllegalStateException}, if 040 * {@link #init(KeyGenerationParameters)} was not yet called. 041 * @return the newly created secret key; never <code>null</code>. 042 */ 043 KeyParameter generateKey(); 044 }