index.php 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. <?php
  2. /*
  3. * GNU social
  4. * Copyright (C) 2010, Free Software Foundation, Inc
  5. *
  6. * This program is free software: you can redistribute it and/or modify
  7. * it under the terms of the GNU Affero General Public License as published by
  8. * the Free Software Foundation, either version 3 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU Affero General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Affero General Public License
  17. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. */
  19. // basename should make sure we can't escape this directory
  20. $u = basename($_GET['resource']);
  21. if (!strpos($u, '@')) {
  22. throw new Exception('Bad resource');
  23. exit(1);
  24. }
  25. if (mb_strpos($u, 'acct:')===0) {
  26. $u = substr($u, 5);
  27. }
  28. // Just to be a little bit safer, you know, with all the unicode stuff going on
  29. $u = filter_var($u, FILTER_SANITIZE_EMAIL);
  30. $f = $u . ".xml";
  31. if (file_exists($f)) {
  32. header('Content-Disposition: attachment; filename="'.urlencode($f).'"');
  33. header('Content-type: application/xrd+xml');
  34. echo file_get_contents($f);
  35. }