/****************************************************************************************
                 Script to read and write cookies from JavaScript
                     Written by Mark Wilton-Jones, 31/12/2001
*****************************************************************************************

Please see http://www.howtocreate.co.uk/jslibs/ for details and a demo of this script
Please see http://www.howtocreate.co.uk/jslibs/termsOfUse.html for terms of use

This script allows you to store and retrieve cookies easily using JavaScript. Cookies
are variables that can be stored on a user's computer and be picked up by any other web
pages in the correct domain. Cookies are set to expire after a certain length of time.

Be warned that many users will not permit cookies on their computers. Do not make your
web sites rely on them. This script provides a return value that says if they accepted
or rejected a cookie.

To use:
_________________________________________________________________________

Inbetween the <head> tags, put:

	<script src="PATH TO SCRIPT/cookie.js" type="text/javascript" language="javascript"></script>

To store a cookie, use:

  var cookieAccepted = SetCookie( cookieName, cookieValue[, lifeTime[, path[, domain[, isSecure]]]] )

  cookieName  = is the name of the cookie (as a string) and can contain any characters.

  cookieValue = is the value that the cookie stores (as a string) and can contain any characters.

  lifeTime    = is the amount of time in seconds that you want the cookie to last for
                (after which the user's computer will delete it).
                The default is until the browser is closed.

  path        = gives the path or directories that the cookie should be accessible from.
                The default is the current path.
                Alter this using ../ (up one directory) / starting at the base directory
                and subdirectoryName/ to start from the currentDirectory/subdirectoryName/

  domain      = gives the domain that the cookie is accessible from.
                This must have at least one . in it	and in many browsers it must have at 
                least two. The default is the current domain.

  isSecure    = can be true or false and says whether or not the cookie is only accessible 
                on sites with a secure (https) connection.

If the user rejected the cookie, cookieAccepted will be false. In Opera, if cookies are on prompt,
the failure responce is received immediately, even if the user then accepts the cookie.

To retrieve a cookie, use:

	var myCookie = GetCookie( cookieNameAsAString );

To modify a cookie, simply set it again with the new settings;

To delete a cookie, use:

	var cookieDeletePermitted = SetCookie( cookieNameAsAString, '', 'delete' );

	or set lifeTime to a less than 0 value.

If the user rejected the attempt to delete the cookie, cookieDeletePermitted will be false.
_______________________________________________________________________________________*/

var expire = new Date ().getTime();

function GetCookie( cookieName )
{
	/* retrieved in the format cookieName4=value; cookieName3=value; cookieName2=value; cookieName1=value
	only cookies for this domain and path will be retrieved */
 var cookieJar = document.cookie.split( "; " );
 for( var x = 0; x < cookieJar.length; x++ )
 {
  var oneCookie = cookieJar[x].split( "=" );
  if( oneCookie[0] == escape( cookieName ) ) { return unescape( oneCookie[1] ); }
 }
 return null;
}

function SetCookie( cookieName, cookieValue, lifeTime, path, domain, isSecure )
{
 if( !cookieName ) { return false; }
 if( lifeTime == "delete" ) { lifeTime = -10; } //this is in the past. Expires immediately.

	/* This next line sets the cookie but does not overwrite other cookies.
	syntax: cookieName=cookieValue[;expires=dataAsString[;path=pathAsString[;domain=domainAsString[;secure]]]]
	Because of the way that document.cookie behaves, writing this here is equivalent to writing
	document.cookie = whatIAmWritingNow + "; " + document.cookie; */

   //alert(new Date(expire).toGMTString()+'  =  '+new Date(expire+(24 * 60 * 60 * 1000 * lifeTime)).toGMTString());

 document.cookie = escape( cookieName ) + "=" + escape( cookieValue ) +
 ( lifeTime ? ";expires=" + new Date(expire + (24 * 60 * 60 * 1000 * lifeTime)).toGMTString() : "" ) +
 ( path ? ";path=" + path : "") + 
 ( domain ? ";domain=" + domain : "") + 
 ( isSecure ? ";secure" : "");

 //check if the cookie has been set/deleted as required
 if( lifeTime < 0 ) { if( typeof( GetCookie( cookieName ) ) == "string" ) { return false; } return true; }
 if( typeof( GetCookie( cookieName ) ) == "string" ) { return true; } return false;
}

