Dockerfile 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. FROM httpd:2.4-alpine
  2. RUN \
  3. apk add --upgrade --update-cache curl && \
  4. mkdir -p /var/www/html && \
  5. mkdir -p /var/www/conf && \
  6. \
  7. echo "Generating content..." && \
  8. \
  9. # add images
  10. for i in 0 1 2 3 4 5 6 7 8 9; do \
  11. curl -sL -o "/var/www/html/$i.jpg" "https://picsum.photos/1280/960"; \
  12. echo "Added $i.jpg."; \
  13. done && \
  14. \
  15. # add transparent png
  16. curl -s -o /var/www/html/transparent-test.png "https://www.w3.org/Graphics/PNG/alphatest.png" && \
  17. echo "Added transparent-test.png." && \
  18. \
  19. # add fonts
  20. for font in notoserif/NotoSerif-Regular.ttf unlock/Unlock-Regular.ttf blackandwhitepicture/BlackAndWhitePicture-Regular.ttf indieflower/IndieFlower-Regular.ttf; do \
  21. curl -s -o "/var/www/html/$(basename $font)" "https://cdn.jsdelivr.net/gh/google/fonts/ofl/$font"; \
  22. echo "Added $font."; \
  23. done && \
  24. \
  25. # add video
  26. curl -s -o /var/www/html/video.mp4 "http://techslides.com/demos/sample-videos/small.mp4" && \
  27. echo "Added small.mp4." && \
  28. \
  29. # add PDF
  30. curl -s -o /var/www/html/dummy.pdf "https://www.w3.org/WAI/ER/tests/xhtml/testfiles/resources/pdf/dummy.pdf" && \
  31. echo "Added dummy.pdf." && \
  32. \
  33. # set ownership properly
  34. chown -R daemon:daemon /var/www && \
  35. \
  36. # create some inaccessible files for testing
  37. mkdir -p /var/www/html/inaccessible-dir && \
  38. curl -sL -o "/var/www/html/inaccessible-image.jpg" "https://picsum.photos/1280/960" && \
  39. echo 'Lorem upsum dolor sit amet' > /var/www/html/inaccessible-text-file.txt && \
  40. > /var/www/html/inaccessible-file && \
  41. chmod 700 /var/www/html/inaccessible* && \
  42. \
  43. # set up apache
  44. echo >> /usr/local/apache2/conf/httpd.conf && \
  45. echo 'LoadModule dav_module modules/mod_dav.so' >> /usr/local/apache2/conf/httpd.conf && \
  46. echo 'LoadModule dav_fs_module modules/mod_dav_fs.so' >> /usr/local/apache2/conf/httpd.conf && \
  47. echo 'LoadModule dav_lock_module modules/mod_dav_lock.so' >> /usr/local/apache2/conf/httpd.conf && \
  48. echo >> /usr/local/apache2/conf/httpd.conf && \
  49. echo 'Include /var/www/conf/*.conf' >> /usr/local/apache2/conf/httpd.conf && \
  50. \
  51. echo 'DavLockDB "/usr/local/apache2/var/DavLock"' >> /var/www/conf/location.conf && \
  52. echo >> /var/www/conf/location.conf && \
  53. echo '<Directory /var/www>' >> /var/www/conf/location.conf && \
  54. echo ' Dav On' >> /var/www/conf/location.conf && \
  55. echo ' Require all granted' >> /var/www/conf/location.conf && \
  56. echo '</Directory>' >> /var/www/conf/location.conf && \
  57. \
  58. mkdir -p /usr/local/apache2/var && \
  59. chown -R daemon:daemon /usr/local/apache2/var && \
  60. chmod -R 755 /usr/local/apache2/var && \
  61. \
  62. # set ownership properly
  63. chown -R daemon:daemon /var/www && \
  64. \
  65. # clean up
  66. apk del curl;
  67. EXPOSE 80