ApiFormatRaw.php 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. <?php
  2. /*
  3. * Created on Feb 2, 2009
  4. *
  5. * API for MediaWiki 1.8+
  6. *
  7. * Copyright (C) 2009 Roan Kattouw <Firstname>.<Lastname>@home.nl
  8. *
  9. * This program is free software; you can redistribute it and/or modify
  10. * it under the terms of the GNU General Public License as published by
  11. * the Free Software Foundation; either version 2 of the License, or
  12. * (at your option) any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU General Public License along
  20. * with this program; if not, write to the Free Software Foundation, Inc.,
  21. * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  22. * http://www.gnu.org/copyleft/gpl.html
  23. */
  24. if (!defined('MEDIAWIKI')) {
  25. // Eclipse helper - will be ignored in production
  26. require_once ('ApiFormatBase.php');
  27. }
  28. /**
  29. * Formatter that spits out anything you like with any desired MIME type
  30. * @ingroup API
  31. */
  32. class ApiFormatRaw extends ApiFormatBase {
  33. /**
  34. * Constructor
  35. * @param $main ApiMain object
  36. * @param $errorFallback Formatter object to fall back on for errors
  37. */
  38. public function __construct($main, $errorFallback) {
  39. parent :: __construct($main, 'raw');
  40. $this->mErrorFallback = $errorFallback;
  41. }
  42. public function getMimeType() {
  43. $data = $this->getResultData();
  44. if(isset($data['error']))
  45. return $this->mErrorFallback->getMimeType();
  46. if(!isset($data['mime']))
  47. ApiBase::dieDebug(__METHOD__, "No MIME type set for raw formatter");
  48. return $data['mime'];
  49. }
  50. public function execute() {
  51. $data = $this->getResultData();
  52. if(isset($data['error']))
  53. {
  54. $this->mErrorFallback->execute();
  55. return;
  56. }
  57. if(!isset($data['text']))
  58. ApiBase::dieDebug(__METHOD__, "No text given for raw formatter");
  59. $this->printText($data['text']);
  60. }
  61. public function getVersion() {
  62. return __CLASS__ . ': $Id: ApiFormatRaw.php 48629 2009-03-20 11:40:54Z catrope $';
  63. }
  64. }