3 * MediaWiki page data importer.
5 * Copyright © 2003,2005 Brooke Vibber <bvibber@wikimedia.org>
6 * https://www.mediawiki.org/
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License along
19 * with this program; if not, write to the Free Software Foundation, Inc.,
20 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
21 * http://www.gnu.org/copyleft/gpl.html
24 * @ingroup SpecialPage
28 * This is a horrible hack used to keep source compatibility.
29 * @ingroup SpecialPage
31 class UploadSourceAdapter
{
32 /** @var ImportSource[] */
33 public static $sourceRegistrations = [];
35 /** @var resource|null Must exists on stream wrapper class */
38 /** @var ImportSource */
42 private $mBuffer = '';
48 * @param ImportSource $source
51 public static function registerSource( ImportSource
$source ) {
52 $id = wfRandomString();
54 self
::$sourceRegistrations[$id] = $source;
63 public static function isSeekableSource( string $id ) {
64 if ( !isset( self
::$sourceRegistrations[$id] ) ) {
67 return self
::$sourceRegistrations[$id]->isSeekable();
75 public static function seekSource( string $id, int $offset ) {
76 if ( !isset( self
::$sourceRegistrations[$id] ) ) {
79 return self
::$sourceRegistrations[$id]->seek( $offset );
86 * @param string &$opened_path
89 public function stream_open( $path, $mode, $options, &$opened_path ) {
90 $url = parse_url( $path );
91 if ( !isset( $url['host'] ) ) {
96 if ( !isset( self
::$sourceRegistrations[$id] ) ) {
100 $this->mSource
= self
::$sourceRegistrations[$id];
109 public function stream_read( $count ) {
113 while ( !$leave && !$this->mSource
->atEnd() &&
114 strlen( $this->mBuffer
) < $count
116 $read = $this->mSource
->readChunk();
118 if ( !strlen( $read ) ) {
122 $this->mBuffer
.= $read;
125 if ( strlen( $this->mBuffer
) ) {
126 $return = substr( $this->mBuffer
, 0, $count );
127 $this->mBuffer
= substr( $this->mBuffer
, $count );
130 $this->mPosition +
= strlen( $return );
136 * @param string $data
139 public function stream_write( $data ) {
146 public function stream_tell() {
147 return $this->mPosition
;
153 public function stream_eof() {
154 return $this->mSource
->atEnd();
160 public function url_stat() {
163 $result['dev'] = $result[0] = 0;
164 $result['ino'] = $result[1] = 0;
165 $result['mode'] = $result[2] = 0;
166 $result['nlink'] = $result[3] = 0;
167 $result['uid'] = $result[4] = 0;
168 $result['gid'] = $result[5] = 0;
169 $result['rdev'] = $result[6] = 0;
170 $result['size'] = $result[7] = 0;
171 $result['atime'] = $result[8] = 0;
172 $result['mtime'] = $result[9] = 0;
173 $result['ctime'] = $result[10] = 0;
174 $result['blksize'] = $result[11] = 0;
175 $result['blocks'] = $result[12] = 0;