~canonical-sysadmins/wordpress/4.6

« back to all changes in this revision

Viewing changes to wp-includes/SimplePie/Cache/File.php

  • Committer: Jacek Nykis
  • Date: 2015-01-05 16:17:05 UTC
  • Revision ID: jacek.nykis@canonical.com-20150105161705-w544l1h5mcg7u4w9
Initial commit

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
<?php
 
2
/**
 
3
 * SimplePie
 
4
 *
 
5
 * A PHP-Based RSS and Atom Feed Framework.
 
6
 * Takes the hard work out of managing a complete RSS/Atom solution.
 
7
 *
 
8
 * Copyright (c) 2004-2012, Ryan Parman, Geoffrey Sneddon, Ryan McCue, and contributors
 
9
 * All rights reserved.
 
10
 *
 
11
 * Redistribution and use in source and binary forms, with or without modification, are
 
12
 * permitted provided that the following conditions are met:
 
13
 *
 
14
 *      * Redistributions of source code must retain the above copyright notice, this list of
 
15
 *        conditions and the following disclaimer.
 
16
 *
 
17
 *      * Redistributions in binary form must reproduce the above copyright notice, this list
 
18
 *        of conditions and the following disclaimer in the documentation and/or other materials
 
19
 *        provided with the distribution.
 
20
 *
 
21
 *      * Neither the name of the SimplePie Team nor the names of its contributors may be used
 
22
 *        to endorse or promote products derived from this software without specific prior
 
23
 *        written permission.
 
24
 *
 
25
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS
 
26
 * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
 
27
 * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS
 
28
 * AND CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 
29
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 
30
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 
31
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
 
32
 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 
33
 * POSSIBILITY OF SUCH DAMAGE.
 
34
 *
 
35
 * @package SimplePie
 
36
 * @version 1.3.1
 
37
 * @copyright 2004-2012 Ryan Parman, Geoffrey Sneddon, Ryan McCue
 
38
 * @author Ryan Parman
 
39
 * @author Geoffrey Sneddon
 
40
 * @author Ryan McCue
 
41
 * @link http://simplepie.org/ SimplePie
 
42
 * @license http://www.opensource.org/licenses/bsd-license.php BSD License
 
43
 */
 
44
 
 
45
/**
 
46
 * Caches data to the filesystem
 
47
 *
 
48
 * @package SimplePie
 
49
 * @subpackage Caching
 
50
 */
 
51
class SimplePie_Cache_File implements SimplePie_Cache_Base
 
52
{
 
53
        /**
 
54
         * Location string
 
55
         *
 
56
         * @see SimplePie::$cache_location
 
57
         * @var string
 
58
         */
 
59
        protected $location;
 
60
 
 
61
        /**
 
62
         * Filename
 
63
         *
 
64
         * @var string
 
65
         */
 
66
        protected $filename;
 
67
 
 
68
        /**
 
69
         * File extension
 
70
         *
 
71
         * @var string
 
72
         */
 
73
        protected $extension;
 
74
 
 
75
        /**
 
76
         * File path
 
77
         *
 
78
         * @var string
 
79
         */
 
80
        protected $name;
 
81
 
 
82
        /**
 
83
         * Create a new cache object
 
84
         *
 
85
         * @param string $location Location string (from SimplePie::$cache_location)
 
86
         * @param string $name Unique ID for the cache
 
87
         * @param string $type Either TYPE_FEED for SimplePie data, or TYPE_IMAGE for image data
 
88
         */
 
89
        public function __construct($location, $name, $type)
 
90
        {
 
91
                $this->location = $location;
 
92
                $this->filename = $name;
 
93
                $this->extension = $type;
 
94
                $this->name = "$this->location/$this->filename.$this->extension";
 
95
        }
 
96
 
 
97
        /**
 
98
         * Save data to the cache
 
99
         *
 
100
         * @param array|SimplePie $data Data to store in the cache. If passed a SimplePie object, only cache the $data property
 
101
         * @return bool Successfulness
 
102
         */
 
103
        public function save($data)
 
104
        {
 
105
                if (file_exists($this->name) && is_writeable($this->name) || file_exists($this->location) && is_writeable($this->location))
 
106
                {
 
107
                        if ($data instanceof SimplePie)
 
108
                        {
 
109
                                $data = $data->data;
 
110
                        }
 
111
 
 
112
                        $data = serialize($data);
 
113
                        return (bool) file_put_contents($this->name, $data);
 
114
                }
 
115
                return false;
 
116
        }
 
117
 
 
118
        /**
 
119
         * Retrieve the data saved to the cache
 
120
         *
 
121
         * @return array Data for SimplePie::$data
 
122
         */
 
123
        public function load()
 
124
        {
 
125
                if (file_exists($this->name) && is_readable($this->name))
 
126
                {
 
127
                        return unserialize(file_get_contents($this->name));
 
128
                }
 
129
                return false;
 
130
        }
 
131
 
 
132
        /**
 
133
         * Retrieve the last modified time for the cache
 
134
         *
 
135
         * @return int Timestamp
 
136
         */
 
137
        public function mtime()
 
138
        {
 
139
                if (file_exists($this->name))
 
140
                {
 
141
                        return filemtime($this->name);
 
142
                }
 
143
                return false;
 
144
        }
 
145
 
 
146
        /**
 
147
         * Set the last modified time to the current time
 
148
         *
 
149
         * @return bool Success status
 
150
         */
 
151
        public function touch()
 
152
        {
 
153
                if (file_exists($this->name))
 
154
                {
 
155
                        return touch($this->name);
 
156
                }
 
157
                return false;
 
158
        }
 
159
 
 
160
        /**
 
161
         * Remove the cache
 
162
         *
 
163
         * @return bool Success status
 
164
         */
 
165
        public function unlink()
 
166
        {
 
167
                if (file_exists($this->name))
 
168
                {
 
169
                        return unlink($this->name);
 
170
                }
 
171
                return false;
 
172
        }
 
173
}