blob: 02841409d3d4818623ce38dd5ad5ffa77bc9f1bc [file] [log] [blame]
Andrey Andreevc5536aa2012-11-01 17:33:58 +02001<?php
Derek Allard2067d1a2008-11-13 22:59:24 +00002/**
3 * CodeIgniter
4 *
Phil Sturgeon07c1ac82012-03-09 17:03:37 +00005 * An open source application development framework for PHP 5.2.4 or newer
Derek Allard2067d1a2008-11-13 22:59:24 +00006 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05007 * NOTICE OF LICENSE
Andrey Andreevdbf4a5a2012-03-13 12:08:59 +02008 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05009 * Licensed under the Open Software License version 3.0
Andrey Andreevdbf4a5a2012-03-13 12:08:59 +020010 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -050011 * This source file is subject to the Open Software License (OSL 3.0) that is
12 * bundled with this package in the files license.txt / license.rst. It is
13 * also available through the world wide web at this URL:
14 * http://opensource.org/licenses/OSL-3.0
15 * If you did not receive a copy of the license and are unable to obtain it
16 * through the world wide web, please send an email to
17 * licensing@ellislab.com so we can send you a copy immediately.
18 *
Derek Allard2067d1a2008-11-13 22:59:24 +000019 * @package CodeIgniter
Derek Jonesf4a4bd82011-10-20 12:18:42 -050020 * @author EllisLab Dev Team
Greg Aker0defe5d2012-01-01 18:46:41 -060021 * @copyright Copyright (c) 2008 - 2012, EllisLab, Inc. (http://ellislab.com/)
Derek Jonesf4a4bd82011-10-20 12:18:42 -050022 * @license http://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
Derek Allard2067d1a2008-11-13 22:59:24 +000023 * @link http://codeigniter.com
24 * @since Version 1.0
25 * @filesource
26 */
Andrey Andreevc5536aa2012-11-01 17:33:58 +020027defined('BASEPATH') OR exit('No direct script access allowed');
Derek Allard2067d1a2008-11-13 22:59:24 +000028
Derek Allard2067d1a2008-11-13 22:59:24 +000029/**
30 * CodeIgniter Cookie Helpers
31 *
32 * @package CodeIgniter
33 * @subpackage Helpers
34 * @category Helpers
Derek Jonesf4a4bd82011-10-20 12:18:42 -050035 * @author EllisLab Dev Team
Derek Allard2067d1a2008-11-13 22:59:24 +000036 * @link http://codeigniter.com/user_guide/helpers/cookie_helper.html
37 */
38
39// ------------------------------------------------------------------------
40
Derek Allard2067d1a2008-11-13 22:59:24 +000041if ( ! function_exists('set_cookie'))
42{
Timothy Warren01b129a2012-04-27 11:36:50 -040043 /**
44 * Set cookie
45 *
46 * Accepts seven parameters, or you can submit an associative
47 * array in the first parameter containing all the values.
48 *
49 * @param mixed
50 * @param string the value of the cookie
51 * @param string the number of seconds until expiration
52 * @param string the cookie domain. Usually: .yourdomain.com
53 * @param string the cookie path
54 * @param string the cookie prefix
55 * @param bool true makes the cookie secure
56 * @param bool true makes the cookie accessible via http(s) only (no javascript)
57 * @return void
58 */
freewil4ad0fd82012-03-13 22:37:42 -040059 function set_cookie($name = '', $value = '', $expire = '', $domain = '', $path = '/', $prefix = '', $secure = FALSE, $httponly = FALSE)
Derek Allard2067d1a2008-11-13 22:59:24 +000060 {
Derek Allard2067d1a2008-11-13 22:59:24 +000061 // Set the config file options
62 $CI =& get_instance();
freewil4ad0fd82012-03-13 22:37:42 -040063 $CI->input->set_cookie($name, $value, $expire, $domain, $path, $prefix, $secure, $httponly);
Derek Allard2067d1a2008-11-13 22:59:24 +000064 }
65}
Barry Mienydd671972010-10-04 16:33:58 +020066
Derek Allard2067d1a2008-11-13 22:59:24 +000067// --------------------------------------------------------------------
68
Derek Allard2067d1a2008-11-13 22:59:24 +000069if ( ! function_exists('get_cookie'))
70{
Timothy Warren01b129a2012-04-27 11:36:50 -040071 /**
72 * Fetch an item from the COOKIE array
73 *
74 * @param string
75 * @param bool
76 * @return mixed
77 */
Derek Allard2067d1a2008-11-13 22:59:24 +000078 function get_cookie($index = '', $xss_clean = FALSE)
79 {
Derek Jonesa04cfa72009-02-10 20:16:57 +000080 $CI =& get_instance();
Andrey Andreevdbf4a5a2012-03-13 12:08:59 +020081 $prefix = isset($_COOKIE[$index]) ? '' : config_item('cookie_prefix');
Derek Jones2c8dc582009-02-10 20:15:49 +000082 return $CI->input->cookie($prefix.$index, $xss_clean);
Derek Allard2067d1a2008-11-13 22:59:24 +000083 }
84}
85
86// --------------------------------------------------------------------
87
Derek Allard2067d1a2008-11-13 22:59:24 +000088if ( ! function_exists('delete_cookie'))
89{
Timothy Warren01b129a2012-04-27 11:36:50 -040090 /**
91 * Delete a COOKIE
92 *
93 * @param mixed
94 * @param string the cookie domain. Usually: .yourdomain.com
95 * @param string the cookie path
96 * @param string the cookie prefix
97 * @return void
98 */
Derek Allard2067d1a2008-11-13 22:59:24 +000099 function delete_cookie($name = '', $domain = '', $path = '/', $prefix = '')
100 {
101 set_cookie($name, '', '', $domain, $path, $prefix);
102 }
103}
104
Derek Allard2067d1a2008-11-13 22:59:24 +0000105/* End of file cookie_helper.php */
Andrey Andreeve6f7d612012-03-20 15:39:22 +0200106/* Location: ./system/helpers/cookie_helper.php */