blob: f3d48ac91114fa0bc97a47b444172692d54beff3 [file] [log] [blame]
Derek Jones8ede1a22011-10-05 13:34:52 -05001################
2Common Functions
3################
4
5CodeIgniter uses a few functions for its operation that are globally
6defined, and are available to you at any point. These do not require
7loading any libraries or helpers.
8
9is_php('version_number')
Andrey Andreev3fb02672012-10-22 16:48:01 +030010========================
Derek Jones8ede1a22011-10-05 13:34:52 -050011
12is_php() determines of the PHP version being used is greater than the
13supplied version_number.
14
15::
16
Derek Jones46715e52011-10-05 17:36:22 -050017 if (is_php('5.3.0'))
18 {
19 $str = quoted_printable_encode($str);
20 }
Derek Jones8ede1a22011-10-05 13:34:52 -050021
22Returns boolean TRUE if the installed version of PHP is equal to or
23greater than the supplied version number. Returns FALSE if the installed
24version of PHP is lower than the supplied version number.
25
26is_really_writable('path/to/file')
Andrey Andreev3fb02672012-10-22 16:48:01 +030027==================================
Derek Jones8ede1a22011-10-05 13:34:52 -050028
29is_writable() returns TRUE on Windows servers when you really can't
30write to the file as the OS reports to PHP as FALSE only if the
31read-only attribute is marked. This function determines if a file is
32actually writable by attempting to write to it first. Generally only
33recommended on platforms where this information may be unreliable.
34
35::
36
Derek Jones46715e52011-10-05 17:36:22 -050037 if (is_really_writable('file.txt'))
38 {
39 echo "I could write to this if I wanted to";
40 }
41 else
42 {
43 echo "File is not writable";
44 }
Derek Jones8ede1a22011-10-05 13:34:52 -050045
46config_item('item_key')
Andrey Andreev3fb02672012-10-22 16:48:01 +030047=======================
Derek Jones8ede1a22011-10-05 13:34:52 -050048
49The :doc:`Config library <../libraries/config>` is the preferred way of
50accessing configuration information, however config_item() can be used
51to retrieve single keys. See Config library documentation for more
52information.
53
Derek Jones46715e52011-10-05 17:36:22 -050054show_error('message'), show_404('page'), log_message('level', 'message')
55========================================================================
Derek Jones8ede1a22011-10-05 13:34:52 -050056
57These are each outlined on the :doc:`Error Handling <errors>` page.
58
Andrey Andreev3fb02672012-10-22 16:48:01 +030059set_status_header(code, 'text')
60===============================
Derek Jones8ede1a22011-10-05 13:34:52 -050061
62Permits you to manually set a server status header. Example::
63
Derek Jones46715e52011-10-05 17:36:22 -050064 set_status_header(401);
65 // Sets the header as: Unauthorized
Derek Jones8ede1a22011-10-05 13:34:52 -050066
67`See here <http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html>`_ for
68a full list of headers.
69
70remove_invisible_characters($str)
Andrey Andreev3fb02672012-10-22 16:48:01 +030071=================================
Derek Jones8ede1a22011-10-05 13:34:52 -050072
73This function prevents inserting null characters between ascii
74characters, like Java\\0script.
75
76html_escape($mixed)
Andrey Andreev3fb02672012-10-22 16:48:01 +030077===================
Derek Jones8ede1a22011-10-05 13:34:52 -050078
Andrey Andreev3fb02672012-10-22 16:48:01 +030079This function provides short cut for ``htmlspecialchars()`` function. It
Derek Jones8ede1a22011-10-05 13:34:52 -050080accepts string and array. To prevent Cross Site Scripting (XSS), it is
81very useful.
Andrey Andreev6ef498b2012-06-05 22:01:58 +030082
83get_mimes()
Andrey Andreev3fb02672012-10-22 16:48:01 +030084===========
Andrey Andreev6ef498b2012-06-05 22:01:58 +030085
Andrey Andreev3fb02672012-10-22 16:48:01 +030086This function returns the MIMEs array *from config/mimes.php*.
87
88is_https()
89==========
90
91Returns TRUE if a secure (HTTPS) connection is used and FALSE
92in any other case (including non-HTTP requests).