org.rythmengine.Sandbox Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of rythm-engine Show documentation
Show all versions of rythm-engine Show documentation
A strong typed high performance Java Template engine with .Net Razor like syntax
/*
* Copyright (C) 2013 The Rythm Engine project
* Gelin Luo
*
* 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.rythmengine;
import org.rythmengine.logger.ILogger;
import org.rythmengine.logger.Logger;
import org.rythmengine.sandbox.RythmSecurityManager;
import org.rythmengine.sandbox.SandboxExecutingService;
import java.io.File;
import java.util.Map;
import java.util.Stack;
/**
* A wrapper of Rythm engine and make sure the rendering is happen in Sandbox mode
*/
public class Sandbox {
private static final ILogger logger = Logger.get(Sandbox.class);
private static final InheritableThreadLocal sandboxMode = new InheritableThreadLocal() {
@Override
protected Boolean initialValue() {
return false;
}
};
static boolean sandboxMode() {
return sandboxMode.get();
}
RythmEngine engine;
SandboxExecutingService secureExecutor = null;
private static boolean sandboxLive = false;
/**
* Turn off sandbox mode. Used by Rythm unit testing program
* @param code
*/
public static void turnOffSandbox(String code) {
if (!sandboxLive) return;
rsm().forbiddenIfCodeNotMatch(code);
sandboxLive = false;
System.setSecurityManager(null);
}
public Sandbox(RythmEngine engine, SandboxExecutingService executor) {
this.engine = engine;
this.secureExecutor = executor;
sandboxLive = true;
restrictedZone.set(new Stack());
}
private static RythmSecurityManager rsm() {
return (RythmSecurityManager)System.getSecurityManager();
}
private RythmEngine engine() {
if (null != engine) return engine;
return Rythm.engine();
}
private Map userContext;
public Sandbox setUserContext(Map context) {
this.userContext = context;
return this;
}
public String render(String template, Object... args) {
sandboxMode.set(true);
try {
return secureExecutor.execute(userContext, template, args);
} finally {
sandboxMode.set(false);
}
}
public String render(File file, Object... args) {
sandboxMode.set(true);
try {
return secureExecutor.execute(userContext,file, args);
} finally {
sandboxMode.set(false);
}
}
public static String hasAccessToRestrictedClasses(RythmEngine engine, String code) {
for (String s : engine.conf().restrictedClasses()) {
if (code.contains(s)) return s;
}
return null;
}
private final static ThreadLocal> restrictedZone = new ThreadLocal>(){
@Override
protected Stack initialValue() {
return new Stack();
}
};
public final static void enterRestrictedZone(String code) {
if (!sandboxLive || !sandboxMode()) return;
rsm().forbiddenIfCodeNotMatch(code);
restrictedZone.get().push(true);
}
public final static void enterSafeZone(String code) {
if (!sandboxLive || !sandboxMode()) return;
rsm().forbiddenIfCodeNotMatch(code);
restrictedZone.get().push(false);
}
public final static void leaveCurZone(String code) {
if (!sandboxLive || !sandboxMode()) return;
rsm().forbiddenIfCodeNotMatch(code);
Stack stack = restrictedZone.get();
if (stack.isEmpty()) {
throw new IllegalStateException("EMPTY ZONE");
}
stack.pop();
}
public final static boolean isRestricted() {
if (!sandboxLive || !sandboxMode()) return false;
Stack stack = restrictedZone.get();
if (stack.isEmpty()) return false;
return stack.peek();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy