/
com/planet_ink/coffee_mud/Abilities/Common/
com/planet_ink/coffee_mud/Abilities/Diseases/
com/planet_ink/coffee_mud/Abilities/Druid/
com/planet_ink/coffee_mud/Abilities/Fighter/
com/planet_ink/coffee_mud/Abilities/Languages/
com/planet_ink/coffee_mud/Abilities/Misc/
com/planet_ink/coffee_mud/Abilities/Prayers/
com/planet_ink/coffee_mud/Abilities/Properties/
com/planet_ink/coffee_mud/Abilities/Skills/
com/planet_ink/coffee_mud/Abilities/Songs/
com/planet_ink/coffee_mud/Abilities/Spells/
com/planet_ink/coffee_mud/Abilities/Thief/
com/planet_ink/coffee_mud/Abilities/Traps/
com/planet_ink/coffee_mud/Behaviors/
com/planet_ink/coffee_mud/CharClasses/interfaces/
com/planet_ink/coffee_mud/Commands/
com/planet_ink/coffee_mud/Commands/interfaces/
com/planet_ink/coffee_mud/Common/
com/planet_ink/coffee_mud/Common/interfaces/
com/planet_ink/coffee_mud/Exits/interfaces/
com/planet_ink/coffee_mud/Items/Armor/
com/planet_ink/coffee_mud/Items/Basic/
com/planet_ink/coffee_mud/Items/CompTech/
com/planet_ink/coffee_mud/Items/MiscMagic/
com/planet_ink/coffee_mud/Items/Weapons/
com/planet_ink/coffee_mud/Items/interfaces/
com/planet_ink/coffee_mud/Libraries/
com/planet_ink/coffee_mud/Libraries/interfaces/
com/planet_ink/coffee_mud/Locales/
com/planet_ink/coffee_mud/MOBS/
com/planet_ink/coffee_mud/Races/
com/planet_ink/coffee_mud/Races/interfaces/
com/planet_ink/coffee_mud/WebMacros/
com/planet_ink/coffee_mud/WebMacros/interfaces/
com/planet_ink/coffee_mud/core/
com/planet_ink/coffee_mud/core/collections/
com/planet_ink/coffee_mud/core/interfaces/
com/planet_ink/coffee_mud/core/intermud/
com/planet_ink/coffee_mud/core/intermud/i3/
com/planet_ink/coffee_web/server/
com/planet_ink/siplet/applet/
lib/
resources/factions/
resources/fakedb/
resources/progs/autoplayer/
resources/quests/holidays/
web/
web/admin.templates/
web/admin/grinder/
web/admin/images/
web/clan.templates/
web/pub.templates/
web/pub/images/mxp/
web/pub/sounds/
web/pub/textedit/
package com.planet_ink.coffee_mud.WebMacros.interfaces;

import com.planet_ink.coffee_mud.core.interfaces.*;
import com.planet_ink.coffee_mud.core.*;
import com.planet_ink.coffee_mud.core.collections.*;
import com.planet_ink.coffee_mud.Abilities.interfaces.*;
import com.planet_ink.coffee_mud.Areas.interfaces.*;
import com.planet_ink.coffee_mud.Behaviors.interfaces.*;
import com.planet_ink.coffee_mud.CharClasses.interfaces.*;
import com.planet_ink.coffee_mud.Commands.interfaces.*;
import com.planet_ink.coffee_mud.Libraries.interfaces.*;
import com.planet_ink.coffee_mud.Common.interfaces.*;
import com.planet_ink.coffee_mud.Exits.interfaces.*;
import com.planet_ink.coffee_mud.Items.interfaces.*;
import com.planet_ink.coffee_mud.Locales.interfaces.*;
import com.planet_ink.coffee_mud.MOBS.interfaces.*;
import com.planet_ink.coffee_mud.Races.interfaces.*;
import com.planet_ink.coffee_mud.core.exceptions.*;
import com.planet_ink.coffee_web.interfaces.*;

import java.util.*;

/*
   Copyright 2002-2016 Bo Zimmerman

   Licensed 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.
 */
/**
 * Web Macros are special commands which can be inserted into coffeemud web page
 * (cmvp) files, and can have those command strings substituted with calculated
 * results. They can include parameters, and can access the other URL
 * parameters.
 */
public interface WebMacro extends CMObject
{
	/**
	 * The public name of this macro
	 * 
	 * @return The public name of this macro
	 */
	@Override
	public String name();

	/**
	 * Whether the runMacro or runBinaryMacro executor should be called.
	 * 
	 * @see WebMacro#runBinaryMacro(HTTPRequest, String, HTTPResponse)
	 * @see WebMacro#runMacro(HTTPRequest, String, HTTPResponse)
	 * @return whether the runBinaryMacro executor should be called instead of
	 *         runMacro
	 */
	public boolean preferBinary();

	/**
	 * Whether this macro is restricted to the admin web server.
	 * 
	 * @return true if the macro is restricted to the admin web server
	 */
	public boolean isAdminMacro();

	/**
	 * Whether this macro substitutes as an aspect of the web path instead of a
	 * standard web macro. If true is returned, URLs such as:
	 * http://mydomain.com/mymacroname?firstparm=value&secondparm=value
	 * might succeeed
	 * 
	 * @return whether this is a wierd URL macro
	 */
	public boolean isAWebPath();

	/**
	 * This method is executed only if this macro returns true for
	 * preferBinary(). It will execute the macro and return its results as a
	 * binary byte array.
	 * 
	 * The response object is used to set cookies and headers only.  Any 
	 * response body is in the return object.  Since 99% of macros are only
	 * filling in an existing page, nothing will be done with that anyway,
	 * and is only important when isAWebPath return true.
	 * 
	 * @see WebMacro#preferBinary()
	 * @see com.planet_ink.coffee_web.interfaces.HTTPRequest
	 * @param httpReq the external requests object
	 * @param parm any parameter strings given to the macro
	 * @param httpResp the response, with headers
	 * @return the binary stream result of running this macro
	 * @throws HTTPServerException a http error to pass to the user
	 */
	public byte[] runBinaryMacro(HTTPRequest httpReq, String parm, HTTPResponse httpResp) throws HTTPServerException;

	/**
	 * This method is executed only if this macro returns false for
	 * preferBinary(). It will execute the macro and return its results as a
	 * string, which is then substituted for the macro reference in the web page
	 * where the macro was found.
	 * 
	 * The response object is used to set cookies and headers only.  Any 
	 * response body is in the return object.  Since 99% of macros are only
	 * filling in an existing page, nothing will be done with that anyway,
	 * and is only important when isAWebPath return true.
	 * 
	 * @see WebMacro#preferBinary()
	 * @see com.planet_ink.coffee_web.interfaces.HTTPRequest
	 * @param httpReq the external requests object
	 * @param parm any parameter strings given to the macro
	 * @param httpResp the response, with headers
	 * @return the string result of running this macro
	 * @throws HTTPServerException a http error to pass to the user
	 */
	public String runMacro(HTTPRequest httpReq, String parm, HTTPResponse httpResp) throws HTTPServerException;
}