You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

467 lines
15 KiB

4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
  1. #
  2. #--------------------------------------------------------------------------
  3. # Image Setup
  4. #--------------------------------------------------------------------------
  5. #
  6. # To edit the 'workspace' base Image, visit its repository on Github
  7. # https://github.com/Laradock/workspace
  8. #
  9. # To change its version, see the available Tags on the Docker Hub:
  10. # https://hub.docker.com/r/laradock/workspace/tags/
  11. #
  12. # Note: Base Image name format {image-tag}-{php-version}
  13. #
  14. LABEL maintainer="Mahmoud Zalt <mahmoud@zalt.me>"
  15. # Set Environment Variables
  16. ENV DEBIAN_FRONTEND noninteractive
  17. # Start as root
  18. USER root
  19. ###########################################################################
  20. # Laradock non-root user:
  21. ###########################################################################
  22. # Add a non-root user to prevent files being created with root permissions on host machine.
  23. ARG PUID=1000
  24. ENV PUID ${PUID}
  25. ARG PGID=1000
  26. ENV PGID ${PGID}
  27. # always run apt update when start and after add new source list, then clean up at end.
  28. RUN set -xe; \
  29. apt-get update -yqq && \
  30. pecl channel-update pecl.php.net && \
  31. groupadd -g ${PGID} laradock && \
  32. useradd -u ${PUID} -g laradock -m laradock -G docker_env && \
  33. usermod -p "*" laradock -s /bin/bash && \
  34. apt-get install -yqq \
  35. apt-utils \
  36. #
  37. #--------------------------------------------------------------------------
  38. # Mandatory Software's Installation
  39. #--------------------------------------------------------------------------
  40. #
  41. # Mandatory Software's such as ("php-cli", "git", "vim", ....) are
  42. # installed on the base image 'laradock/workspace' image. If you want
  43. # to add more Software's or remove existing one, you need to edit the
  44. # base image (https://github.com/Laradock/workspace).
  45. #
  46. # next lines are here becase there is no auto build on dockerhub see https://github.com/laradock/laradock/pull/1903#issuecomment-463142846
  47. libzip-dev zip unzip \
  48. # Install the zip extension
  49. php${PHP_VERSION}-zip \
  50. # nasm
  51. nasm && \
  52. php -m | grep -q 'zip'
  53. #
  54. #--------------------------------------------------------------------------
  55. # Optional Software's Installation
  56. #--------------------------------------------------------------------------
  57. #
  58. # Optional Software's will only be installed if you set them to `true`
  59. # in the `docker-compose.yml` before the build.
  60. # Example:
  61. # - WORKSPACE_INSTALL_NODE=false
  62. # - ...
  63. #
  64. ###########################################################################
  65. # Set Timezone
  66. ###########################################################################
  67. ARG TZ=Europe/Moscow
  68. ENV TZ ${TZ}
  69. RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
  70. ###########################################################################
  71. # User Aliases
  72. ###########################################################################
  73. USER root
  74. COPY ./aliases.sh /root/aliases.sh
  75. COPY ./aliases.sh /home/laradock/aliases.sh
  76. RUN sed -i 's/\r//' /root/aliases.sh && \
  77. sed -i 's/\r//' /home/laradock/aliases.sh && \
  78. chown laradock:laradock /home/laradock/aliases.sh && \
  79. echo "" >> ~/.bashrc && \
  80. echo "# Load Custom Aliases" >> ~/.bashrc && \
  81. echo "source ~/aliases.sh" >> ~/.bashrc && \
  82. echo "" >> ~/.bashrc
  83. USER laradock
  84. RUN echo "" >> ~/.bashrc && \
  85. echo "# Load Custom Aliases" >> ~/.bashrc && \
  86. echo "source ~/aliases.sh" >> ~/.bashrc && \
  87. echo "" >> ~/.bashrc
  88. ###########################################################################
  89. # ssh:
  90. ###########################################################################
  91. USER root
  92. ARG INSTALL_SSH=false
  93. ENV INSTALL_SSH ${INSTALL_SSH}
  94. RUN if [ ${INSTALL_SSH} = true ]; then \
  95. rm -f /etc/service/sshd/down \
  96. ;fi
  97. USER laradock
  98. RUN if [ ${INSTALL_SSH} = true ]; then \
  99. mkdir -p ~/.ssh && ln -s /run/secrets/user_ssh_key ~/.ssh/id_rsa \
  100. ;fi
  101. ###########################################################################
  102. # MySQL Client:
  103. ###########################################################################
  104. USER root
  105. ARG INSTALL_MYSQL_CLIENT=false
  106. RUN if [ ${INSTALL_MYSQL_CLIENT} = true ]; then \
  107. apt-get update -yqq && \
  108. apt-get -y install mysql-client \
  109. ;fi
  110. ###########################################################################
  111. # PYTHON:
  112. ###########################################################################
  113. USER root
  114. ARG INSTALL_PYTHON=false
  115. RUN if [ ${INSTALL_PYTHON} = true ]; then \
  116. apt-get update && apt-get -y install python python-pip python-dev build-essential \
  117. && python -m pip install --upgrade "pip < 21.0" \
  118. && python -m pip install --upgrade virtualenv \
  119. ;fi
  120. ###########################################################################
  121. # fswatch
  122. ###########################################################################
  123. USER root
  124. ARG INSTALL_FSWATCH=false
  125. RUN if [ ${INSTALL_FSWATCH} = true ]; then \
  126. apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 47FE03C1 \
  127. && add-apt-repository -y ppa:hadret/fswatch \
  128. || apt-get update -yqq \
  129. && apt-get -y install fswatch \
  130. ;fi
  131. ###########################################################################
  132. # ping:
  133. ###########################################################################
  134. USER root
  135. ARG INSTALL_PING=false
  136. RUN if [ ${INSTALL_PING} = true ]; then \
  137. apt-get update -yqq && \
  138. apt-get -y install inetutils-ping \
  139. ;fi
  140. ###########################################################################
  141. # Install S3 minio client:
  142. ###########################################################################
  143. USER root
  144. ARG INSTALL_S3_MINIO_CLIENT=false
  145. RUN if [ ${INSTALL_S3_MINIO_CLIENT} = true ]; then \
  146. curl https://dl.min.io/client/mc/release/linux-amd64/mc > /usr/local/sbin/mc \
  147. && chmod +x /usr/local/sbin/mc \
  148. ; fi
  149. ###########################################################################
  150. # Composer:
  151. ###########################################################################
  152. USER root
  153. # Add the composer.json
  154. COPY ./composer.json /home/laradock/.composer/composer.json
  155. # Make sure that ~/.composer belongs to laradock
  156. RUN chown -R laradock:laradock /home/laradock/.composer
  157. RUN ln -s /run/secrets/composer_auth /home/laradock/.composer/auth.json
  158. # Export composer vendor path
  159. RUN echo "" >> ~/.bashrc && \
  160. echo 'export PATH="$HOME/.composer/vendor/bin:$PATH"' >> ~/.bashrc
  161. # Update composer
  162. ARG COMPOSER_VERSION=2
  163. ENV COMPOSER_VERSION ${COMPOSER_VERSION}
  164. RUN composer self-update --${COMPOSER_VERSION}
  165. USER laradock
  166. # Check if global install need to be ran
  167. ARG COMPOSER_GLOBAL_INSTALL=false
  168. ENV COMPOSER_GLOBAL_INSTALL ${COMPOSER_GLOBAL_INSTALL}
  169. RUN if [ ${COMPOSER_GLOBAL_INSTALL} = true ]; then \
  170. # run the install
  171. composer global install \
  172. ;fi
  173. ARG COMPOSER_REPO_PACKAGIST
  174. ENV COMPOSER_REPO_PACKAGIST ${COMPOSER_REPO_PACKAGIST}
  175. RUN if [ ${COMPOSER_REPO_PACKAGIST} ]; then \
  176. composer config -g repo.packagist composer ${COMPOSER_REPO_PACKAGIST} \
  177. ;fi
  178. # Export composer vendor path
  179. RUN echo "" >> ~/.bashrc && \
  180. echo 'export PATH="~/.composer/vendor/bin:$PATH"' >> ~/.bashrc
  181. ###########################################################################
  182. # Non-root user : PHPUnit path
  183. ###########################################################################
  184. # add ./vendor/bin to non-root user's bashrc (needed for phpunit)
  185. USER laradock
  186. RUN echo "" >> ~/.bashrc && \
  187. echo 'export PATH="/var/www/vendor/bin:$PATH"' >> ~/.bashrc
  188. ###########################################################################
  189. # Check PHP version:
  190. ###########################################################################
  191. RUN set -xe; php -v | head -n 1 | grep -q "PHP ${PHP_VERSION}."
  192. ###########################################################################
  193. # xDebug:
  194. ###########################################################################
  195. USER root
  196. ARG INSTALL_XDEBUG=false
  197. RUN if [ ${INSTALL_XDEBUG} = true ]; then \
  198. # Load the xdebug extension only with phpunit commands
  199. apt-get install -y php${PHP_VERSION}-xdebug && \
  200. sed -i 's/^;//g' /etc/php/${PHP_VERSION}/cli/conf.d/20-xdebug.ini && \
  201. echo "alias phpunit='php -dzend_extension=xdebug.so /var/www/vendor/bin/phpunit'" >> ~/.bashrc \
  202. ;fi
  203. # ADD for REMOTE debugging
  204. COPY ./xdebug.ini /etc/php/${PHP_VERSION}/cli/conf.d/xdebug.ini
  205. RUN sed -i "s/xdebug.remote_autostart=0/xdebug.remote_autostart=1/" /etc/php/${PHP_VERSION}/cli/conf.d/xdebug.ini && \
  206. sed -i "s/xdebug.remote_enable=0/xdebug.remote_enable=1/" /etc/php/${PHP_VERSION}/cli/conf.d/xdebug.ini && \
  207. sed -i "s/xdebug.cli_color=0/xdebug.cli_color=1/" /etc/php/${PHP_VERSION}/cli/conf.d/xdebug.ini
  208. ###########################################################################
  209. # WP CLI:
  210. ###########################################################################
  211. # The command line interface for WordPress
  212. USER root
  213. ARG INSTALL_WP_CLI=false
  214. RUN if [ ${INSTALL_WP_CLI} = true ]; then \
  215. curl -fsSL -o /usr/local/bin/wp https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar | bash && \
  216. chmod +x /usr/local/bin/wp \
  217. ;fi
  218. ###########################################################################
  219. # Node / NVM:
  220. ###########################################################################
  221. USER laradock
  222. # Check if NVM needs to be installed
  223. ARG INSTALL_NODE=false
  224. ENV INSTALL_NODE ${INSTALL_NODE}
  225. ARG NODE_VERSION=node
  226. ENV NODE_VERSION ${NODE_VERSION}
  227. ARG INSTALL_NPM_GULP=false
  228. ARG INSTALL_NPM_BOWER=false
  229. ARG INSTALL_NPM_VUE_CLI=false
  230. ARG INSTALL_NPM_ANGULAR_CLI=false
  231. ARG NPM_REGISTRY
  232. ENV NPM_REGISTRY ${NPM_REGISTRY}
  233. ENV NVM_DIR /home/laradock/.nvm
  234. RUN if [ ${INSTALL_NODE} = true ]; then \
  235. # Install nvm (A Node Version Manager)
  236. mkdir -p $NVM_DIR && \
  237. curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.11/install.sh | bash \
  238. && . $NVM_DIR/nvm.sh \
  239. && nvm install ${NODE_VERSION} \
  240. && nvm use ${NODE_VERSION} \
  241. && nvm alias ${NODE_VERSION} \
  242. && if [ ${NPM_REGISTRY} ]; then \
  243. npm config set registry ${NPM_REGISTRY} \
  244. ;fi \
  245. && if [ ${INSTALL_NPM_GULP} = true ]; then \
  246. npm install -g gulp \
  247. ;fi \
  248. && if [ ${INSTALL_NPM_BOWER} = true ]; then \
  249. npm install -g bower \
  250. ;fi \
  251. && if [ ${INSTALL_NPM_VUE_CLI} = true ]; then \
  252. npm install -g @vue/cli \
  253. ;fi \
  254. && if [ ${INSTALL_NPM_ANGULAR_CLI} = true ]; then \
  255. npm install -g @angular/cli \
  256. ;fi \
  257. && ln -s `npm bin --global` /home/laradock/.node-bin \
  258. ;fi
  259. # Wouldn't execute when added to the RUN statement in the above block
  260. # Source NVM when loading bash since ~/.profile isn't loaded on non-login shell
  261. RUN if [ ${INSTALL_NODE} = true ]; then \
  262. echo "" >> ~/.bashrc && \
  263. echo 'export NVM_DIR="$HOME/.nvm"' >> ~/.bashrc && \
  264. echo '[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh" # This loads nvm' >> ~/.bashrc \
  265. ;fi
  266. # Add NVM binaries to root's .bashrc
  267. USER root
  268. RUN if [ ${INSTALL_NODE} = true ]; then \
  269. cp -R /home/laradock/.nvm /root/ && \
  270. chown -R root:root /root/.nvm && \
  271. echo "" >> ~/.bashrc && \
  272. echo 'export NVM_DIR="$HOME/.nvm"' >> ~/.bashrc && \
  273. echo '[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh" # This loads nvm' >> ~/.bashrc \
  274. ;fi
  275. # Add PATH for node
  276. ENV PATH $PATH:/home/laradock/.node-bin
  277. # Make it so the node modules can be executed with 'docker-compose exec'
  278. # We'll create symbolic links into '/usr/local/bin'.
  279. RUN if [ ${INSTALL_NODE} = true ]; then \
  280. find $NVM_DIR -type f -name node -exec ln -s {} /usr/local/bin/node \; && \
  281. NODE_MODS_DIR="$NVM_DIR/versions/node/$(node -v)/lib/node_modules" && \
  282. ln -s $NODE_MODS_DIR/bower/bin/bower /usr/local/bin/bower && \
  283. ln -s $NODE_MODS_DIR/gulp/bin/gulp.js /usr/local/bin/gulp && \
  284. ln -s $NODE_MODS_DIR/npm/bin/npm-cli.js /usr/local/bin/npm && \
  285. ln -s $NODE_MODS_DIR/npm/bin/npx-cli.js /usr/local/bin/npx && \
  286. ln -s $NODE_MODS_DIR/vue-cli/bin/vue /usr/local/bin/vue && \
  287. ln -s $NODE_MODS_DIR/vue-cli/bin/vue-init /usr/local/bin/vue-init && \
  288. ln -s $NODE_MODS_DIR/vue-cli/bin/vue-list /usr/local/bin/vue-list \
  289. ;fi
  290. RUN if [ ${NPM_REGISTRY} ]; then \
  291. . ~/.bashrc && npm config set registry ${NPM_REGISTRY} \
  292. ;fi
  293. ###########################################################################
  294. # GULP:
  295. ###########################################################################
  296. ARG INSTALL_GULP=false
  297. ENV INSTALL_GULP ${INSTALL_GULP}
  298. USER root
  299. RUN if [ ${INSTALL_GULP} = true ]; then \
  300. npm i -g gulp gulp-cli \
  301. ;fi
  302. ###########################################################################
  303. # YARN:
  304. ###########################################################################
  305. USER laradock
  306. ARG INSTALL_YARN=false
  307. ENV INSTALL_YARN ${INSTALL_YARN}
  308. ARG YARN_VERSION=latest
  309. ENV YARN_VERSION ${YARN_VERSION}
  310. RUN if [ ${INSTALL_YARN} = true ]; then \
  311. [ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh" && \
  312. if [ ${YARN_VERSION} = "latest" ]; then \
  313. curl -o- -L https://yarnpkg.com/install.sh | bash; \
  314. else \
  315. curl -o- -L https://yarnpkg.com/install.sh | bash -s -- --version ${YARN_VERSION}; \
  316. fi && \
  317. echo "" >> ~/.bashrc && \
  318. echo 'export PATH="$HOME/.yarn/bin:$PATH"' >> ~/.bashrc \
  319. ;fi
  320. # Add YARN binaries to root's .bashrc
  321. USER root
  322. RUN if [ ${INSTALL_YARN} = true ]; then \
  323. echo "" >> ~/.bashrc && \
  324. echo 'export YARN_DIR="/home/laradock/.yarn"' >> ~/.bashrc && \
  325. echo 'export PATH="$YARN_DIR/bin:$PATH"' >> ~/.bashrc \
  326. ;fi
  327. # Add PATH for YARN
  328. ENV PATH $PATH:/home/laradock/.yarn/bin
  329. ###########################################################################
  330. # S3 config helper
  331. ###########################################################################
  332. USER laradock
  333. COPY ./minio/auth.json /home/laradock/.mc/config.json
  334. ###########################################################################
  335. # Add known hosts
  336. ###########################################################################
  337. USER laradock
  338. RUN if [ ${INSTALL_SSH} = true ]; then \
  339. mkdir -p ~/.ssh && ln -s /run/secrets/user_ssh_key ~/.ssh/id_rsa \
  340. && ssh-keyscan -t rsa github.com >> ~/.ssh/known_hosts \
  341. && ssh-keyscan -t rsa bitbucket.org >> ~/.ssh/known_hosts \
  342. && ssh-keyscan -t rsa gitlab.com >> ~/.ssh/known_hosts \
  343. && ssh-keyscan -t rsa vcs.wpstudio.ru >> ~/.ssh/known_hosts \
  344. ;fi
  345. ###########################################################################
  346. # Crontab
  347. ###########################################################################
  348. USER root
  349. COPY ./crontab /etc/cron.d
  350. RUN chmod -R 644 /etc/cron.d
  351. #
  352. #--------------------------------------------------------------------------
  353. # Final Touch
  354. #--------------------------------------------------------------------------
  355. #
  356. USER root
  357. # Clean up
  358. RUN apt-get clean && \
  359. rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* && \
  360. rm /var/log/lastlog /var/log/faillog
  361. # Set default work directory
  362. WORKDIR /var/www