NaiveImportTitleFactory.php 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. <?php
  2. /**
  3. * This program is free software; you can redistribute it and/or modify
  4. * it under the terms of the GNU General Public License as published by
  5. * the Free Software Foundation; either version 2 of the License, or
  6. * (at your option) any later version.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. *
  13. * You should have received a copy of the GNU General Public License along
  14. * with this program; if not, write to the Free Software Foundation, Inc.,
  15. * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  16. * http://www.gnu.org/copyleft/gpl.html
  17. *
  18. * @file
  19. */
  20. use MediaWiki\MediaWikiServices;
  21. /**
  22. * A class to convert page titles on a foreign wiki (ForeignTitle objects) into
  23. * page titles on the local wiki (Title objects), using a default namespace
  24. * mapping.
  25. *
  26. * For built-in namespaces (0 <= ID < 100), we try to find a local namespace
  27. * with the same namespace ID as the foreign page. If no such namespace exists,
  28. * or the namespace ID is unknown or > 100, we look for a local namespace with
  29. * a matching namespace name. If that can't be found, we dump the page in the
  30. * main namespace as a last resort.
  31. */
  32. class NaiveImportTitleFactory implements ImportTitleFactory {
  33. /**
  34. * Determines which local title best corresponds to the given foreign title.
  35. * If such a title can't be found or would be locally invalid, null is
  36. * returned.
  37. *
  38. * @param ForeignTitle $foreignTitle The ForeignTitle to convert
  39. * @return Title|null
  40. */
  41. public function createTitleFromForeignTitle( ForeignTitle $foreignTitle ) {
  42. if ( $foreignTitle->isNamespaceIdKnown() ) {
  43. $foreignNs = $foreignTitle->getNamespaceId();
  44. // For built-in namespaces (0 <= ID < 100), we try to find a local NS with
  45. // the same namespace ID
  46. if (
  47. $foreignNs < 100 &&
  48. MediaWikiServices::getInstance()->getNamespaceInfo()->exists( $foreignNs )
  49. ) {
  50. return Title::makeTitleSafe( $foreignNs, $foreignTitle->getText() );
  51. }
  52. }
  53. // Do we have a local namespace by the same name as the foreign
  54. // namespace?
  55. $targetNs = MediaWikiServices::getInstance()->getContentLanguage()->getNsIndex(
  56. $foreignTitle->getNamespaceName() );
  57. if ( $targetNs !== false ) {
  58. return Title::makeTitleSafe( $targetNs, $foreignTitle->getText() );
  59. }
  60. // Otherwise, just fall back to main namespace
  61. return Title::makeTitleSafe( 0, $foreignTitle->getFullText() );
  62. }
  63. }