mirror of
https://github.com/kanidm/kanidm.git
synced 2025-02-23 12:37:00 +01:00
255 lines
7.8 KiB
Makefile
255 lines
7.8 KiB
Makefile
IMAGE_BASE ?= kanidm
|
|
IMAGE_VERSION ?= devel
|
|
CONTAINER_TOOL_ARGS ?=
|
|
IMAGE_ARCH ?= "linux/amd64,linux/arm64"
|
|
CONTAINER_BUILD_ARGS ?=
|
|
MARKDOWN_FORMAT_ARGS ?= --options-line-width=100
|
|
CONTAINER_TOOL ?= docker
|
|
|
|
BOOK_VERSION ?= master
|
|
|
|
.DEFAULT: help
|
|
.PHONY: help
|
|
help:
|
|
@grep -E -h '\s##\s' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-20s\033[0m %s\n", $$1, $$2}'
|
|
|
|
.PHONY: buildx/kanidmd/x86_64_v3
|
|
buildx/kanidmd/x86_64_v3: ## build multiarch server images
|
|
buildx/kanidmd/x86_64_v3:
|
|
@$(CONTAINER_TOOL) buildx build $(CONTAINER_TOOL_ARGS) --pull --push --platform "linux/amd64/v3" \
|
|
-f kanidmd/Dockerfile -t $(IMAGE_BASE)/server:x86_64_$(IMAGE_VERSION) \
|
|
--build-arg "KANIDM_BUILD_PROFILE=container_x86_64_v3" \
|
|
--build-arg "KANIDM_FEATURES=" \
|
|
$(CONTAINER_BUILD_ARGS) .
|
|
@$(CONTAINER_TOOL) buildx imagetools $(CONTAINER_TOOL_ARGS) inspect $(IMAGE_BASE)/server:$(IMAGE_VERSION)
|
|
|
|
.PHONY: buildx/kanidmd
|
|
buildx/kanidmd: ## Build multiarch kanidm server images and push to docker hub
|
|
buildx/kanidmd:
|
|
@$(CONTAINER_TOOL) buildx build $(CONTAINER_TOOL_ARGS) \
|
|
--pull --push --platform $(IMAGE_ARCH) \
|
|
-f kanidmd/Dockerfile \
|
|
-t $(IMAGE_BASE)/server:$(IMAGE_VERSION) \
|
|
--build-arg "KANIDM_BUILD_PROFILE=container_generic" \
|
|
--build-arg "KANIDM_FEATURES=" \
|
|
$(CONTAINER_BUILD_ARGS) .
|
|
@$(CONTAINER_TOOL) buildx imagetools $(CONTAINER_TOOL_ARGS) inspect $(IMAGE_BASE)/server:$(IMAGE_VERSION)
|
|
|
|
.PHONY: buildx/kanidm_tools
|
|
buildx/kanidm_tools: ## Build multiarch kanidm tool images and push to docker hub
|
|
buildx/kanidm_tools:
|
|
@$(CONTAINER_TOOL) buildx build $(CONTAINER_TOOL_ARGS) \
|
|
--pull --push --platform $(IMAGE_ARCH) \
|
|
-f kanidm_tools/Dockerfile \
|
|
-t $(IMAGE_BASE)/tools:$(IMAGE_VERSION) \
|
|
--build-arg "KANIDM_BUILD_PROFILE=container_generic" \
|
|
--build-arg "KANIDM_FEATURES=" \
|
|
$(CONTAINER_BUILD_ARGS) .
|
|
@$(CONTAINER_TOOL) buildx imagetools $(CONTAINER_TOOL_ARGS) inspect $(IMAGE_BASE)/tools:$(IMAGE_VERSION)
|
|
|
|
.PHONY: buildx/radiusd
|
|
buildx/radiusd: ## Build multi-arch radius docker images and push to docker hub
|
|
buildx/radiusd:
|
|
@$(CONTAINER_TOOL) buildx build $(CONTAINER_TOOL_ARGS) \
|
|
--pull --push --platform $(IMAGE_ARCH) \
|
|
-f kanidm_rlm_python/Dockerfile \
|
|
-t $(IMAGE_BASE)/radius:$(IMAGE_VERSION) .
|
|
@$(CONTAINER_TOOL) buildx imagetools $(CONTAINER_TOOL_ARGS) inspect $(IMAGE_BASE)/radius:$(IMAGE_VERSION)
|
|
|
|
.PHONY: buildx
|
|
buildx: buildx/kanidmd/x86_64_v3 buildx/kanidmd buildx/kanidm_tools buildx/radiusd
|
|
|
|
.PHONY: build/kanidmd
|
|
build/kanidmd: ## Build the kanidmd docker image locally
|
|
build/kanidmd:
|
|
@$(CONTAINER_TOOL) build $(CONTAINER_TOOL_ARGS) -f kanidmd/Dockerfile -t $(IMAGE_BASE)/server:$(IMAGE_VERSION) \
|
|
--build-arg "KANIDM_BUILD_PROFILE=container_generic" \
|
|
--build-arg "KANIDM_FEATURES=" \
|
|
$(CONTAINER_BUILD_ARGS) .
|
|
|
|
.PHONY: build/radiusd
|
|
build/radiusd: ## Build the radiusd docker image locally
|
|
build/radiusd:
|
|
@$(CONTAINER_TOOL) build $(CONTAINER_TOOL_ARGS) \
|
|
-f kanidm_rlm_python/Dockerfile \
|
|
-t $(IMAGE_BASE)/radius:$(IMAGE_VERSION) .
|
|
|
|
.PHONY: build
|
|
build: build/kanidmd build/radiusd
|
|
|
|
.PHONY: test/kanidmd
|
|
test/kanidmd: ## Run cargo test in docker
|
|
test/kanidmd:
|
|
@$(CONTAINER_TOOL) build \
|
|
$(CONTAINER_TOOL_ARGS) -f kanidmd/Dockerfile \
|
|
--target builder \
|
|
-t $(IMAGE_BASE)/server:$(IMAGE_VERSION)-builder \
|
|
$(CONTAINER_BUILD_ARGS) .
|
|
@$(CONTAINER_TOOL) run --rm $(IMAGE_BASE)/server:$(IMAGE_VERSION)-builder cargo test
|
|
|
|
.PHONY: test/radiusd
|
|
test/radiusd: ## Run a test radius server
|
|
test/radiusd: build/radiusd
|
|
cd kanidm_rlm_python && \
|
|
./run_radius_container.sh
|
|
|
|
.PHONY: test
|
|
test:
|
|
cargo test
|
|
|
|
.PHONY: precommit
|
|
precommit: ## all the usual test things
|
|
precommit: test codespell test/pykanidm doc/format
|
|
|
|
.PHONY: vendor
|
|
vendor:
|
|
cargo vendor
|
|
|
|
.PHONY: vendor-prep
|
|
vendor-prep: vendor
|
|
tar -cJf vendor.tar.xz vendor
|
|
|
|
.PHONY: install-tools
|
|
install-tools: ## install kanidm_tools in your local environment
|
|
install-tools:
|
|
cd kanidm_tools && cargo install --path . --force
|
|
|
|
.PHONY: prep
|
|
prep:
|
|
cargo outdated -R
|
|
cargo audit
|
|
|
|
.PHONY: codespell
|
|
codespell:
|
|
codespell -c \
|
|
-L crate,unexpect,Pres,pres,ACI,aci,te,ue \
|
|
--skip='./target,./pykanidm/.venv,./pykanidm/.mypy_cache,./.mypy_cache' \
|
|
--skip='./docs/*,./.git' \
|
|
--skip='./kanidmd_web_ui/src/external,./kanidmd_web_ui/pkg/external' \
|
|
--skip='./kanidmd/lib/src/constants/system_config.rs,./pykanidm/site,./kanidmd/lib/src/constants/*.json'
|
|
|
|
.PHONY: test/pykanidm/pytest
|
|
test/pykanidm/pytest: ## python library testing
|
|
cd pykanidm && \
|
|
poetry install && \
|
|
poetry run pytest -vv
|
|
|
|
.PHONY: test/pykanidm/lint
|
|
test/pykanidm/lint: ## python library linting
|
|
cd pykanidm && \
|
|
poetry install && \
|
|
poetry run ruff tests kanidm
|
|
|
|
.PHONY: test/pykanidm/mypy
|
|
test/pykanidm/mypy: ## python library type checking
|
|
cd pykanidm && \
|
|
poetry install && \
|
|
echo "Running mypy" && \
|
|
poetry run mypy --strict tests kanidm
|
|
|
|
.PHONY: test/pykanidm
|
|
test/pykanidm: ## run the kanidm python module test suite (mypy/lint/pytest)
|
|
test/pykanidm: test/pykanidm/pytest test/pykanidm/mypy test/pykanidm/lint
|
|
|
|
########################################################################
|
|
|
|
.PHONY: doc
|
|
doc: ## Build the rust documentation locally
|
|
doc:
|
|
cargo doc --document-private-items
|
|
|
|
.PHONY: doc/format
|
|
doc/format: ## Format docs and the Kanidm book
|
|
find . -type f -not -path './target/*' -not -path '*/.venv/*' \
|
|
-name \*.md \
|
|
-exec deno fmt --check $(MARKDOWN_FORMAT_ARGS) "{}" +
|
|
|
|
.PHONY: doc/format/fix
|
|
doc/format/fix: ## Fix docs and the Kanidm book
|
|
find . -type f -not -path './target/*' -not -path '*/.venv/*' \
|
|
-name \*.md \
|
|
-exec deno fmt $(MARKDOWN_FORMAT_ARGS) "{}" +
|
|
|
|
.PHONY: book
|
|
book: ## Build the Kanidm book
|
|
book:
|
|
cargo doc --no-deps
|
|
mdbook build kanidm_book
|
|
rm -rf ./docs/
|
|
mv ./kanidm_book/book/ ./docs/
|
|
mkdir -p ./docs/rustdoc/${BOOK_VERSION}
|
|
mv ./target/doc/* ./docs/rustdoc/${BOOK_VERSION}/
|
|
|
|
.PHONY: book_versioned
|
|
book_versioned:
|
|
echo "Book version: ${BOOK_VERSION}"
|
|
rm -rf ./target/doc
|
|
git switch -c "${BOOK_VERSION}"
|
|
git pull origin "${BOOK_VERSION}"
|
|
cargo doc --no-deps --quiet
|
|
mdbook build kanidm_book
|
|
rm -rf ./docs/
|
|
mkdir -p ./docs
|
|
mv ./kanidm_book/book/ ./docs/${BOOK_VERSION}/
|
|
mkdir -p ./docs/${BOOK_VERSION}/rustdoc/
|
|
mv ./target/doc/* ./docs/${BOOK_VERSION}/rustdoc/
|
|
git switch master
|
|
|
|
.PHONY: clean_book
|
|
clean_book:
|
|
rm -rf ./docs
|
|
|
|
.PHONY: docs/pykanidm/build
|
|
docs/pykanidm/build: ## Build the mkdocs
|
|
docs/pykanidm/build:
|
|
cd pykanidm && \
|
|
poetry install && \
|
|
poetry run mkdocs build
|
|
|
|
.PHONY: docs/pykanidm/serve
|
|
docs/pykanidm/serve: ## Run the local mkdocs server
|
|
docs/pykanidm/serve:
|
|
cd pykanidm && \
|
|
poetry install && \
|
|
poetry run mkdocs serve
|
|
|
|
########################################################################
|
|
|
|
.PHONY: release/kanidm
|
|
release/kanidm: ## Build the Kanidm CLI - ensure you include the environment variable KANIDM_BUILD_PROFILE
|
|
cargo build -p kanidm_tools --bin kanidm --release
|
|
|
|
.PHONY: release/kanidmd
|
|
release/kanidmd: ## Build the Kanidm daemon - ensure you include the environment variable KANIDM_BUILD_PROFILE
|
|
cargo build -p daemon --bin kanidmd --release
|
|
|
|
.PHONY: release/kanidm-ssh
|
|
release/kanidm-ssh: ## Build the Kanidm SSH tools - ensure you include the environment variable KANIDM_BUILD_PROFILE
|
|
cargo build --release \
|
|
--bin kanidm_ssh_authorizedkeys \
|
|
--bin kanidm_ssh_authorizedkeys_direct
|
|
|
|
.PHONY: release/kanidm-unixd
|
|
release/kanidm-unixd: ## Build the Kanidm UNIX tools - ensure you include the environment variable KANIDM_BUILD_PROFILE
|
|
release/kanidm-unixd:
|
|
cargo build -p pam_kanidm --release
|
|
cargo build -p nss_kanidm --release
|
|
cargo build --release \
|
|
--bin kanidm_unixd \
|
|
--bin kanidm_unixd_status \
|
|
--bin kanidm_unixd_tasks \
|
|
--bin kanidm_cache_clear \
|
|
--bin kanidm_cache_invalidate
|
|
|
|
|
|
# cert things
|
|
|
|
.PHONY: cert/clean
|
|
cert/clean: ## clean out the insecure cert bits
|
|
cert/clean:
|
|
rm -f /tmp/kanidm/*.pem
|
|
rm -f /tmp/kanidm/*.cnf
|
|
rm -f /tmp/kanidm/*.csr
|
|
rm -f /tmp/kanidm/ca.txt*
|
|
rm -f /tmp/kanidm/ca.{cnf,srl,srl.old}
|