Dockerfile 2.4 KB

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