/docx4j-core/src/main/java/org/docx4j/org/apache/poi/poifs/crypt/standard/StandardEncryptionInfoBuilder.java
http://github.com/plutext/docx4j · Java · 128 lines · 81 code · 19 blank · 28 comment · 27 complexity · 0b2f70c8884639dc67864166c534f175 MD5 · raw file
- /* NOTICE: This file has been changed by Plutext Pty Ltd for use in docx4j.
- * The package name has been changed; there may also be other changes.
- *
- * This notice is included to meet the condition in clause 4(b) of the License.
- */
-
- /* ====================================================================
- 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.docx4j.org.apache.poi.poifs.crypt.standard;
-
- import java.io.IOException;
-
-
-
-
- //import org.docx4j.org.apache.poi.EncryptedDocumentException;
- import org.docx4j.org.apache.poi.EncryptedDocumentException;
- import org.docx4j.org.apache.poi.poifs.crypt.ChainingMode;
- import org.docx4j.org.apache.poi.poifs.crypt.CipherAlgorithm;
- import org.docx4j.org.apache.poi.poifs.crypt.EncryptionInfo;
- import org.docx4j.org.apache.poi.poifs.crypt.EncryptionInfoBuilder;
- import org.docx4j.org.apache.poi.poifs.crypt.HashAlgorithm;
- import org.docx4j.org.apache.poi.util.LittleEndianInput;
-
- public class StandardEncryptionInfoBuilder implements EncryptionInfoBuilder {
-
- EncryptionInfo info;
- StandardEncryptionHeader header;
- StandardEncryptionVerifier verifier;
- StandardDecryptor decryptor;
- StandardEncryptor encryptor;
-
- /**
- * initialize the builder from a stream
- */
- public void initialize(EncryptionInfo info, LittleEndianInput dis) throws IOException {
- this.info = info;
-
- @SuppressWarnings("unused")
- int hSize = dis.readInt();
- header = new StandardEncryptionHeader(dis);
- verifier = new StandardEncryptionVerifier(dis, header);
-
- if (info.getVersionMinor() == 2 && (info.getVersionMajor() == 3 || info.getVersionMajor() == 4)) {
- decryptor = new StandardDecryptor(this);
- }
- }
-
- /**
- * initialize the builder from scratch
- */
- public void initialize(EncryptionInfo info, CipherAlgorithm cipherAlgorithm, HashAlgorithm hashAlgorithm, int keyBits, int blockSize, ChainingMode chainingMode) {
- this.info = info;
-
- if (cipherAlgorithm == null) {
- cipherAlgorithm = CipherAlgorithm.aes128;
- }
- if (cipherAlgorithm != CipherAlgorithm.aes128 &&
- cipherAlgorithm != CipherAlgorithm.aes192 &&
- cipherAlgorithm != CipherAlgorithm.aes256) {
- throw new EncryptedDocumentException("Standard encryption only supports AES128/192/256.");
- }
-
- if (hashAlgorithm == null) {
- hashAlgorithm = HashAlgorithm.sha1;
- }
- if (hashAlgorithm != HashAlgorithm.sha1) {
- throw new EncryptedDocumentException("Standard encryption only supports SHA-1.");
- }
- if (chainingMode == null) {
- chainingMode = ChainingMode.ecb;
- }
- if (chainingMode != ChainingMode.ecb) {
- throw new EncryptedDocumentException("Standard encryption only supports ECB chaining.");
- }
- if (keyBits == -1) {
- keyBits = cipherAlgorithm.defaultKeySize;
- }
- if (blockSize == -1) {
- blockSize = cipherAlgorithm.blockSize;
- }
- boolean found = false;
- for (int ks : cipherAlgorithm.allowedKeySize) {
- found |= (ks == keyBits);
- }
- if (!found) {
- throw new EncryptedDocumentException("KeySize "+keyBits+" not allowed for Cipher "+cipherAlgorithm.toString());
- }
- header = new StandardEncryptionHeader(cipherAlgorithm, hashAlgorithm, keyBits, blockSize, chainingMode);
- verifier = new StandardEncryptionVerifier(cipherAlgorithm, hashAlgorithm, keyBits, blockSize, chainingMode);
- decryptor = new StandardDecryptor(this);
- encryptor = new StandardEncryptor(this);
- }
-
- public StandardEncryptionHeader getHeader() {
- return header;
- }
-
- public StandardEncryptionVerifier getVerifier() {
- return verifier;
- }
-
- public StandardDecryptor getDecryptor() {
- return decryptor;
- }
-
- public StandardEncryptor getEncryptor() {
- return encryptor;
- }
-
- public EncryptionInfo getEncryptionInfo() {
- return info;
- }
- }