html-uploads.pl 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  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 3 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, see <http://www.gnu.org/licenses/>.
  15. use strict;
  16. use v5.10;
  17. AddModuleDescription('html-uploads.pl', 'Restricted HTML Upload');
  18. our (%Action, @UploadTypes);
  19. $Action{download} = \&HtmlUploadsDoDownload;
  20. # anybody can download raw html
  21. sub HtmlUploadsDoDownload {
  22. push(@UploadTypes, 'text/html') unless grep(/^text\/html$/, @UploadTypes);
  23. return DoDownload(@_);
  24. }
  25. # but only admins can upload raw html
  26. *OldHtmlUploadsDoPost = \&DoPost;
  27. *DoPost = \&NewHtmlUploadsDoPost;
  28. sub NewHtmlUploadsDoPost {
  29. my @args = @_;
  30. if (not grep(/^text\/html$/, @UploadTypes)
  31. and UserIsAdmin()) {
  32. push(@UploadTypes, 'text/html');
  33. }
  34. return OldHtmlUploadsDoPost(@args);
  35. }