API15

JLog/addEntry: Difference between revisions

From Joomla! Documentation

Doxiki (talk | contribs)
New page: <span class="editsection" style="font-size:76%;"> <nowiki>[</nowiki>Edit Descripton<nowiki>]</nowiki> </span> {{Description:JLog/addEntry}} ===Synt...
 
m removing red link to edit, no existant pages
Line 1: Line 1:
<span class="editsection" style="font-size:76%;">
<span class="editsection" style="font-size:76%;">
<nowiki>[</nowiki>[[Description:JLog/addEntry|Edit Descripton]]<nowiki>]</nowiki>
<nowiki>[<! removed edit link to red link >]</nowiki>
</span>
</span>


{{Description:JLog/addEntry}}
<! removed transcluded page call, red link never existed >


===Syntax===
===Syntax===
Line 72: Line 71:


<span class="editsection" style="font-size:76%;">
<span class="editsection" style="font-size:76%;">
<nowiki>[</nowiki>[[SeeAlso:JLog/addEntry|Edit See Also]]<nowiki>]</nowiki>
<nowiki>[<! removed edit link to red link >]</nowiki>
</span>
</span>
{{SeeAlso:JLog/addEntry}}
<! removed transcluded page call, red link never existed >


===Examples===
===Examples===
Line 87: Line 86:
  format= ,,,
  format= ,,,
</dpl>
</dpl>
[[Category:Archived pages API15]]

Revision as of 18:35, 12 May 2013

[<! removed edit link to red link >]

<! removed transcluded page call, red link never existed >

Syntax

addEntry($entry)
Parameter Name Default Value Description
$entry

Defined in

libraries/joomla/error/log.php

Importing

jimport( 'joomla.error.log' );

Source Body

function addEntry($entry)
{
        // Set some default field values if not already set.
        $date =& JFactory::getDate();
        if (!isset ($entry['date'])) {

                $entry['date'] = $date->toFormat("%Y-%m-%d");
        }
        if (!isset ($entry['time'])) {

                $entry['time'] = $date->toFormat("%H:%M:%S");
        }
        if (!isset ($entry['c-ip'])) {
                $entry['c-ip'] = $_SERVER['REMOTE_ADDR'];
        }

        // Ensure that the log entry keys are all uppercase
        $entry = array_change_key_case($entry, CASE_UPPER);

        // Find all fields in the format string
        $fields = array ();
        $regex = "/{(.*?)}/i";
        preg_match_all($regex, $this->_format, $fields);

        // Fill in the field data
        $line = $this->_format;
        for ($i = 0; $i < count($fields[0]); $i++)
        {
                $line = str_replace($fields[0][$i], (isset ($entry[$fields[1][$i]])) ? $entry[$fields[1][$i]] : "-", $line);
        }

        // Write the log entry line
        if ($this->_openLog())
        {
                if (!fputs($this->_file, "\n" . $line)) {
                        return false;
                }
        } else {
                return false;
        }
        return true;
}

[<! removed edit link to red link >] <! removed transcluded page call, red link never existed >

Examples

<CodeExamplesForm />