001/** 002 * 003 * Copyright (c) 2014, the Railo Company Ltd. All rights reserved. 004 * 005 * This library is free software; you can redistribute it and/or 006 * modify it under the terms of the GNU Lesser General Public 007 * License as published by the Free Software Foundation; either 008 * version 2.1 of the License, or (at your option) any later version. 009 * 010 * This library 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 GNU 013 * Lesser General Public License for more details. 014 * 015 * You should have received a copy of the GNU Lesser General Public 016 * License along with this library. If not, see <http://www.gnu.org/licenses/>. 017 * 018 **/ 019package lucee.runtime.type.scope; 020 021import lucee.runtime.config.ConfigServer; 022import lucee.runtime.exp.PageException; 023 024public interface ClusterRemote { 025 026 /** 027 * broadcast data on stack and clear stack 028 */ 029 public void broadcastEntries(); 030 031 /** 032 * set entry on stack 033 * @param entry 034 */ 035 public void addEntry(ClusterEntry entry); 036 037 038 /** 039 * check if the value can distributed over the "cluster" 040 * @param value 041 * @throws PageException 042 */ 043 public boolean checkValue(Object value); 044 045 /** 046 * duplicate this object 047 * @return duplicated object 048 */ 049 public ClusterRemote duplicate(); 050 051 /** 052 * @param configServer 053 * @param cluster 054 */ 055 public void init(ConfigServer configServer,Cluster cluster); 056 057}