/**
* Copyright (c) 2000-present Liferay, Inc. All rights reserved.
*
* This library is free software; you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the Free
* Software Foundation; either version 2.1 of the License, or (at your option)
* any later version.
*
* This library 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 Lesser General Public License for more
* details.
*/
package com.liferay.portal.kernel.io;
import com.liferay.portal.kernel.util.ClassResolverUtil;
import com.liferay.portal.kernel.util.StringUtil;
import java.io.IOException;
import java.io.InputStream;
import java.io.InvalidClassException;
import java.io.ObjectInputStream;
import java.io.ObjectStreamClass;
import java.util.Arrays;
import java.util.HashSet;
import java.util.Set;
/**
* @author Mika Koivisto
*/
public class ProtectedObjectInputStream extends ObjectInputStream {
public ProtectedObjectInputStream(InputStream inputStream)
throws IOException {
super(inputStream);
}
/**
* @throws ClassNotFoundException
* @throws IOException
*/
protected Class<?> doResolveClass(ObjectStreamClass objectStreamClass)
throws ClassNotFoundException, IOException {
String name = objectStreamClass.getName();
return ClassResolverUtil.resolveByContextClassLoader(name);
}
@Override
protected Class<?> resolveClass(ObjectStreamClass objectStreamClass)
throws ClassNotFoundException, IOException {
if (_restrictedClassNames.contains(objectStreamClass.getName())) {
throw new InvalidClassException(
"Reject resolving of restricted class " +
objectStreamClass.getName());
}
return doResolveClass(objectStreamClass);
}
private static final Set<String> _restrictedClassNames;
static {
String[] restrictedClassNames = StringUtil.split(
System.getProperty(
ProtectedObjectInputStream.class.getName() +
".restricted.class.names"));
_restrictedClassNames = new HashSet<>(
Arrays.asList(restrictedClassNames));
}
}