001/** 002 * 003 * Copyright 2017 Paul Schaub 004 * 005 * Licensed under the Apache License, Version 2.0 (the "License"); 006 * you may not use this file except in compliance with the License. 007 * You may obtain a copy of the License at 008 * 009 * http://www.apache.org/licenses/LICENSE-2.0 010 * 011 * Unless required by applicable law or agreed to in writing, software 012 * distributed under the License is distributed on an "AS IS" BASIS, 013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 014 * See the License for the specific language governing permissions and 015 * limitations under the License. 016 */ 017package org.jivesoftware.smackx.omemo.exceptions; 018 019import java.util.Collections; 020import java.util.Iterator; 021import java.util.List; 022 023public final class MultipleCryptoFailedException extends CryptoFailedException { 024 025 /** 026 * 027 */ 028 private static final long serialVersionUID = 1L; 029 030 private final List<CryptoFailedException> cryptoFailedExceptions; 031 032 private MultipleCryptoFailedException(String message, List<CryptoFailedException> cryptoFailedExceptions) { 033 super(message); 034 this.cryptoFailedExceptions = Collections.unmodifiableList(cryptoFailedExceptions); 035 if (cryptoFailedExceptions.isEmpty()) { 036 throw new IllegalArgumentException("Exception list must not be empty."); 037 } 038 } 039 040 public static MultipleCryptoFailedException from(List<CryptoFailedException> cryptoFailedExceptions) { 041 StringBuilder sb = new StringBuilder("Multiple CryptoFailedExceptions: "); 042 Iterator<CryptoFailedException> it = cryptoFailedExceptions.iterator(); 043 while (it.hasNext()) { 044 sb.append(it.next()); 045 if (it.hasNext()) { 046 sb.append(", "); 047 } 048 } 049 return new MultipleCryptoFailedException(sb.toString(), cryptoFailedExceptions); 050 } 051 052 public List<CryptoFailedException> getCryptoFailedExceptions() { 053 return cryptoFailedExceptions; 054 } 055}