# Ver: 1.11 by Endial Fang (endial@126.com)
#

# 系统默认变量 ====================================================================
# 该部分变量为系统根据编译命令默认设置
# `TARGETPLATFORM`：构建后的目标平台信息。如 `linux/amd64`，`linux/arm/v7`，`windows/amd64`
# `TARGETOS`：目标平台信息（TARGETPLATFORM）中的操作系统部分，如：`linux`、`windows`
# `TARGETARCH`：目标平台信息（TARGETPLATFORM）中的平台架构部分，如：`amd64`、`arm`
# `TARGETVARIANT`：目标平台信息（TARGETPLATFORM）中的版本变体部分，如：`v7`
# `BUILDPLATFORM`：用于构建的节点平台信息
# `BUILDOS`：用于构建的节点平台信息（BUILDPLATFORM）中的操作系统部分
# `BUILDARCH`：用于构建的节点平台信息（BUILDPLATFORM）中的平台架构部分
# `BUILDVARIANT`：用于构建的节点平台信息（BUILDPLATFORM）中的版本变体部分

# 可变参数 ========================================================================
# 该部分变量，在编译命令中通过 `--build-arg` 传入；如果未设置，则使用下面对应的默认值

ARG APP_NAME=alpine
ARG APP_VER=3.23
ARG REGISTRY_URL="docker.io/"
ARG APT_SOURCE=default

# 1. 生成镜像 =====================================================================
FROM --platform=${TARGETPLATFORM:-linux/amd64} ${REGISTRY_URL}alpine:${APP_VER}

# 声明需要使用的全局可变参数（ARG声明的变量仅编译打包阶段有效）
ARG APP_NAME
ARG APP_VER
ARG APT_SOURCE

# 定义应用的基础信息变量（ENV声明的变量实例化后容器内有效）
ENV LANG=en_US.UTF-8 \
	LANGUAGE=en_US.UTF-8 \
	LC_ALL=en_US.UTF-8

# 镜像元数据标签 - 符合OCI镜像规范
LABEL org.opencontainers.image.title="${APP_NAME}" \
      org.opencontainers.image.version="${APP_VER}" \
      org.opencontainers.image.description="Docker image for Alpine." \
      org.opencontainers.image.authors="Endial Fang <endial@126.com>" \
      org.opencontainers.image.url="https://gitee.com/colovu/docker-${APP_NAME}" \
      org.opencontainers.image.vendor="Endial Fang (colovu)" \
      org.opencontainers.image.licenses="Apache-2.0" \
      org.opencontainers.image.source="https://gitee.com/colovu/docker-${APP_NAME}" \
      org.opencontainers.image.documentation="https://gitee.com/colovu/docker-${APP_NAME}/blob/main/README.md" \
      maintainer="Endial Fang <endial@126.com>"

# 拷贝默认的通用脚本文件
COPY .ci/common/alpine /

RUN set -eux; \
    \
	# 选择软件包源，以加速后续软件包安装
	select_source ${APT_SOURCE}; \
	\
	# 安装常用的软件包
	install_pkg bash tzdata dumb-init curl; \
	\
	# 配置时区默认为 Shanghai
	cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime; \
	\
	# 增加 musl 版本的 locales 支持，并设置默认为 UTF-8
	apk add --no-cache libintl; \
	apk add --no-cache --virtual .locale_build git cmake make musl-dev gcc gettext-dev; \
	git clone https://gitlab.com/rilian-la-te/musl-locales; \
	cd musl-locales && cmake -DLOCALE_PROFILE=OFF -DCMAKE_INSTALL_PREFIX:PATH=/usr . && make && make install; \
	cd .. && rm -r musl-locales; \
	apk del .locale_build; \
	rm -rf /var/cache/apk/*;

# 应用程序的服务命令，必须使用非守护进程方式运行。如果使用变量，则该变量必须在运行环境中存在（ENV可以获取）
CMD []
