html-uploads.pl 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. # Copyright (C) 2004 Alex Schroeder <alex@emacswiki.org>
  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
  14. # along with this program; if not, write to the
  15. # Free Software Foundation, Inc.
  16. # 59 Temple Place, Suite 330
  17. # Boston, MA 02111-1307 USA
  18. use strict;
  19. use v5.10;
  20. AddModuleDescription('html-uploads.pl', 'Restricted HTML Upload');
  21. our (%Action, @UploadTypes);
  22. $Action{download} = \&HtmlUploadsDoDownload;
  23. # anybody can download raw html
  24. sub HtmlUploadsDoDownload {
  25. push(@UploadTypes, 'text/html') unless grep(/^text\/html$/, @UploadTypes);
  26. return DoDownload(@_);
  27. }
  28. # but only admins can upload raw html
  29. *OldHtmlUploadsDoPost = \&DoPost;
  30. *DoPost = \&NewHtmlUploadsDoPost;
  31. sub NewHtmlUploadsDoPost {
  32. my @args = @_;
  33. if (not grep(/^text\/html$/, @UploadTypes)
  34. and UserIsAdmin()) {
  35. push(@UploadTypes, 'text/html');
  36. }
  37. return OldHtmlUploadsDoPost(@args);
  38. }