Compare commits
No commits in common. "main" and "0.2.1" have entirely different histories.
32 changed files with 74 additions and 537 deletions
41
.gitignore
vendored
41
.gitignore
vendored
|
@ -1,28 +1,31 @@
|
||||||
# Allowlisting gitignore template for GO projects prevents us
|
# ---> Go
|
||||||
# from adding various unwanted local files, such as generated
|
# If you prefer the allow list template instead of the deny list, see community template:
|
||||||
# files, developer configurations or IDE-specific files etc.
|
# https://github.com/github/gitignore/blob/main/community/Golang/Go.AllowList.gitignore
|
||||||
#
|
#
|
||||||
# Recommended: Go.AllowList.gitignore
|
# Binaries for programs and plugins
|
||||||
|
*.exe
|
||||||
|
*.exe~
|
||||||
|
*.dll
|
||||||
|
*.so
|
||||||
|
*.dylib
|
||||||
|
|
||||||
# Ignore everything
|
# Test binary, built with `go test -c`
|
||||||
*
|
*.test
|
||||||
|
|
||||||
# But not these files...
|
# Output of the go coverage tool, specifically when used with LiteIDE
|
||||||
!/.gitignore
|
*.out
|
||||||
|
|
||||||
!*.go
|
# Dependency directories (remove the comment below to include it)
|
||||||
!go.sum
|
# vendor/
|
||||||
!go.mod
|
|
||||||
|
|
||||||
!examples/*
|
# Go workspace file
|
||||||
|
go.work
|
||||||
|
|
||||||
!*.md
|
bin/
|
||||||
!LICENSE
|
|
||||||
|
|
||||||
!Makefile
|
examples/testing/
|
||||||
|
|
||||||
# Woodpecker CI
|
*.yaml
|
||||||
!.woodpecker/*
|
!examples/*.yaml
|
||||||
|
|
||||||
# ...even if they are in subdirectories
|
test/
|
||||||
!*/
|
|
||||||
|
|
24
.vscode/launch.json
vendored
24
.vscode/launch.json
vendored
|
@ -1,24 +0,0 @@
|
||||||
{
|
|
||||||
// Use IntelliSense to learn about possible attributes.
|
|
||||||
// Hover to view descriptions of existing attributes.
|
|
||||||
// For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
|
|
||||||
"version": "0.2.0",
|
|
||||||
"configurations": [
|
|
||||||
{
|
|
||||||
"name": "Debug Dry Run",
|
|
||||||
"type": "go",
|
|
||||||
"request": "launch",
|
|
||||||
"mode": "auto",
|
|
||||||
"program": "${workspaceFolder}/cmd/certwarden-deploy/main.go",
|
|
||||||
"args": ["--config", "${workspaceFolder}/config.yaml", "--dry-run"]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "Debug",
|
|
||||||
"type": "go",
|
|
||||||
"request": "launch",
|
|
||||||
"mode": "auto",
|
|
||||||
"program": "${workspaceFolder}/cmd/certwarden-deploy/main.go",
|
|
||||||
"args": ["--config", "${workspaceFolder}/config.yaml", "--verbose"]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
|
@ -20,13 +20,13 @@ steps:
|
||||||
- APP_NAME=certwarden-deploy
|
- APP_NAME=certwarden-deploy
|
||||||
- FORGE=https://code.lila.network
|
- FORGE=https://code.lila.network
|
||||||
commands:
|
commands:
|
||||||
- apk add --update --no-cache xz curl jq make git
|
- apk add --update --no-cache xz curl jq
|
||||||
- make build
|
- go mod download
|
||||||
- cd bin/
|
- go build -o output/$APP_NAME-${CI_COMMIT_TAG##v}-${GOOS}-${GOARCH}${GOARM} main.go
|
||||||
- mv $APP_NAME $APP_NAME-${GOOS}-${GOARCH}${GOARM}
|
- cd output
|
||||||
- xz --keep --compress $APP_NAME-${GOOS}-${GOARCH}${GOARM}
|
- xz --keep --compress $APP_NAME-${CI_COMMIT_TAG##v}-${GOOS}-${GOARCH}${GOARM}
|
||||||
- sha256sum $APP_NAME-${GOOS}-${GOARCH}${GOARM} >> $APP_NAME-${GOOS}-${GOARCH}${GOARM}.sha256
|
- sha256sum $APP_NAME-${CI_COMMIT_TAG##v}-${GOOS}-${GOARCH}${GOARM} >> $APP_NAME-${CI_COMMIT_TAG##v}-${GOOS}-${GOARCH}${GOARM}.sha256
|
||||||
- sha256sum $APP_NAME-${GOOS}-${GOARCH}${GOARM}.xz >> $APP_NAME-${GOOS}-${GOARCH}${GOARM}.xz.sha256
|
- sha256sum $APP_NAME-${CI_COMMIT_TAG##v}-${GOOS}-${GOARCH}${GOARM}.xz >> $APP_NAME-${CI_COMMIT_TAG##v}-${GOOS}-${GOARCH}${GOARM}.xz.sha256
|
||||||
- |-
|
- |-
|
||||||
export RELEASE_ID=`curl --location "$FORGE/api/v1/repos/$CI_REPO/releases?limit=10" \
|
export RELEASE_ID=`curl --location "$FORGE/api/v1/repos/$CI_REPO/releases?limit=10" \
|
||||||
--header 'Accept: application/json' -s -S \
|
--header 'Accept: application/json' -s -S \
|
||||||
|
@ -35,23 +35,23 @@ steps:
|
||||||
curl --location "$FORGE/api/v1/repos/$CI_REPO/releases/$RELEASE_ID/assets" \
|
curl --location "$FORGE/api/v1/repos/$CI_REPO/releases/$RELEASE_ID/assets" \
|
||||||
--header "Authorization: token $FORGEJO_APIKEY" \
|
--header "Authorization: token $FORGEJO_APIKEY" \
|
||||||
--header 'Content-Type: multipart/form-data' -s -S \
|
--header 'Content-Type: multipart/form-data' -s -S \
|
||||||
--form "attachment=@$APP_NAME-${GOOS}-${GOARCH}${GOARM};type=application/octet-stream" \
|
--form "attachment=@$APP_NAME-${CI_COMMIT_TAG##v}-${GOOS}-${GOARCH}${GOARM};type=application/octet-stream" \
|
||||||
--fail-with-body
|
--fail-with-body
|
||||||
- |-
|
- |-
|
||||||
curl --location "$FORGE/api/v1/repos/$CI_REPO/releases/$RELEASE_ID/assets" \
|
curl --location "$FORGE/api/v1/repos/$CI_REPO/releases/$RELEASE_ID/assets" \
|
||||||
--header "Authorization: token $FORGEJO_APIKEY" \
|
--header "Authorization: token $FORGEJO_APIKEY" \
|
||||||
--header 'Content-Type: multipart/form-data' -s -S \
|
--header 'Content-Type: multipart/form-data' -s -S \
|
||||||
--form "attachment=@$APP_NAME-${GOOS}-${GOARCH}${GOARM}.xz;type=application/octet-stream" \
|
--form "attachment=@$APP_NAME-${CI_COMMIT_TAG##v}-${GOOS}-${GOARCH}${GOARM}.xz;type=application/octet-stream" \
|
||||||
--fail-with-body
|
--fail-with-body
|
||||||
- |-
|
- |-
|
||||||
curl --location "$FORGE/api/v1/repos/$CI_REPO/releases/$RELEASE_ID/assets" \
|
curl --location "$FORGE/api/v1/repos/$CI_REPO/releases/$RELEASE_ID/assets" \
|
||||||
--header "Authorization: token $FORGEJO_APIKEY" \
|
--header "Authorization: token $FORGEJO_APIKEY" \
|
||||||
--header 'Content-Type: multipart/form-data' -s -S \
|
--header 'Content-Type: multipart/form-data' -s -S \
|
||||||
--form "attachment=@$APP_NAME-${GOOS}-${GOARCH}${GOARM}.sha256;type=application/octet-stream" \
|
--form "attachment=@$APP_NAME-${CI_COMMIT_TAG##v}-${GOOS}-${GOARCH}${GOARM}.sha256;type=application/octet-stream" \
|
||||||
--fail-with-body
|
--fail-with-body
|
||||||
- |-
|
- |-
|
||||||
curl --location "$FORGE/api/v1/repos/$CI_REPO/releases/$RELEASE_ID/assets" \
|
curl --location "$FORGE/api/v1/repos/$CI_REPO/releases/$RELEASE_ID/assets" \
|
||||||
--header "Authorization: token $FORGEJO_APIKEY" \
|
--header "Authorization: token $FORGEJO_APIKEY" \
|
||||||
--header 'Content-Type: multipart/form-data' -s -S \
|
--header 'Content-Type: multipart/form-data' -s -S \
|
||||||
--form "attachment=@$APP_NAME-${GOOS}-${GOARCH}${GOARM}.xz.sha256;type=application/octet-stream" \
|
--form "attachment=@$APP_NAME-${CI_COMMIT_TAG##v}-${GOOS}-${GOARCH}${GOARM}.xz.sha256;type=application/octet-stream" \
|
||||||
--fail-with-body
|
--fail-with-body
|
||||||
|
|
|
@ -1,38 +0,0 @@
|
||||||
when:
|
|
||||||
- event: push
|
|
||||||
branch: main
|
|
||||||
path:
|
|
||||||
include:
|
|
||||||
- 'docs/**'
|
|
||||||
- '.woodpecker/deploy-docs.yml'
|
|
||||||
ignore_message: '[ALL]'
|
|
||||||
|
|
||||||
steps:
|
|
||||||
build:
|
|
||||||
image: golang:1.22-bookworm
|
|
||||||
environment:
|
|
||||||
- HUGO_VERSION=0.128.1
|
|
||||||
- TZ=Europe/Berlin
|
|
||||||
|
|
||||||
commands:
|
|
||||||
- cd docs/
|
|
||||||
- wget https://github.com/gohugoio/hugo/releases/download/v$${HUGO_VERSION}/hugo_extended_$${HUGO_VERSION}_linux-amd64.deb && apt install ./hugo_extended_$${HUGO_VERSION}_linux-amd64.deb && rm -f hugo_extended_$${HUGO_VERSION}_linux-amd64.deb
|
|
||||||
- hugo --minify --destination ./public
|
|
||||||
|
|
||||||
upload:
|
|
||||||
image: alpine:latest
|
|
||||||
secrets:
|
|
||||||
- RSYNC_SSHKEY
|
|
||||||
- RSYNC_TARGET_SERVER
|
|
||||||
- RSYNC_TARGET_USER
|
|
||||||
environment:
|
|
||||||
- TARGET_PATH=/webroot/certwarden-deploy.adora.codes
|
|
||||||
- RSYNC_TARGET_PORT=2003
|
|
||||||
commands:
|
|
||||||
- cd docs/
|
|
||||||
- apk add --update --no-cache openssh rsync git
|
|
||||||
- mkdir -p $HOME/.ssh
|
|
||||||
- echo "$RSYNC_SSHKEY" > $HOME/.ssh/id_ed25519
|
|
||||||
- chmod 0600 $HOME/.ssh/id_ed25519
|
|
||||||
- ssh-keyscan -t ed25519 -p $RSYNC_TARGET_PORT $RSYNC_TARGET_SERVER >> $HOME/.ssh/known_hosts
|
|
||||||
- rsync -avh -e "ssh -p $RSYNC_TARGET_PORT" --delete ./public/ $RSYNC_TARGET_USER@$RSYNC_TARGET_SERVER:$TARGET_PATH
|
|
13
CHANGELOG.md
13
CHANGELOG.md
|
@ -7,16 +7,6 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
|
|
||||||
|
|
||||||
## [Unreleased]
|
## [Unreleased]
|
||||||
## [0.2.2] - 2024-07-30
|
|
||||||
|
|
||||||
### Changed
|
|
||||||
- changed the way the version string is handled internally
|
|
||||||
- CI pipeline changed
|
|
||||||
- documentation is now more sophisticated and has a new theme
|
|
||||||
|
|
||||||
### Added
|
|
||||||
- Makefile
|
|
||||||
|
|
||||||
## [0.2.1] - 2024-07-12
|
## [0.2.1] - 2024-07-12
|
||||||
### Fixed
|
### Fixed
|
||||||
- Configuration validation did not work as intended
|
- Configuration validation did not work as intended
|
||||||
|
@ -50,8 +40,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
- some documentation
|
- some documentation
|
||||||
|
|
||||||
|
|
||||||
[unreleased]: https://code.lila.network/adoralaura/certwarden-deploy/compare/0.2.2...HEAD
|
[unreleased]: https://code.lila.network/adoralaura/certwarden-deploy/compare/0.2.1...HEAD
|
||||||
[0.2.2]: https://code.lila.network/adoralaura/certwarden-deploy/compare/0.2.1...0.2.2
|
|
||||||
[0.2.1]: https://code.lila.network/adoralaura/certwarden-deploy/compare/0.2.0...0.2.1
|
[0.2.1]: https://code.lila.network/adoralaura/certwarden-deploy/compare/0.2.0...0.2.1
|
||||||
[0.2.0]: https://code.lila.network/adoralaura/certwarden-deploy/compare/0.1.1...0.2.0
|
[0.2.0]: https://code.lila.network/adoralaura/certwarden-deploy/compare/0.1.1...0.2.0
|
||||||
[0.1.1]: https://code.lila.network/adoralaura/certwarden-deploy/compare/0.1.0...0.1.1
|
[0.1.1]: https://code.lila.network/adoralaura/certwarden-deploy/compare/0.1.0...0.1.1
|
||||||
|
|
|
@ -6,7 +6,7 @@ I use my own [Forgejo Instance](https://code.lila.network) to manage issues and
|
||||||
addressing (with `@...`) the maintainer of this repository (see
|
addressing (with `@...`) the maintainer of this repository (see
|
||||||
[MAINTAINERS.md](MAINTAINERS.md)) in the description of the pull request.
|
[MAINTAINERS.md](MAINTAINERS.md)) in the description of the pull request.
|
||||||
|
|
||||||
* If you plan to do something more involved, first please [send me a mail]( mailto:dev@lauka.net?subject=%5Bcertwarden-deploy%5D).
|
* If you plan to do something more involved, first please [send me a mail]( mailto:adora@lila.network?subject=%5Bcertwarden-deploy%5D).
|
||||||
|
|
||||||
# What to contribute
|
# What to contribute
|
||||||
|
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
* Adora Laura Kalb <dev@lauka.net> @adoralaura
|
* Adora Laura Kalb <adora@lila.network> @adoralaura
|
||||||
|
|
13
Makefile
13
Makefile
|
@ -1,13 +0,0 @@
|
||||||
# Set the default Go build flags
|
|
||||||
GOFLAGS = -ldflags='-w -s -X constants.Version=$(VERSION)'
|
|
||||||
|
|
||||||
# Build the application
|
|
||||||
build:
|
|
||||||
go build $(GOFLAGS) -o bin/certwarden-deploy cmd/certwarden-deploy/main.go
|
|
||||||
|
|
||||||
# Clean the build artifacts
|
|
||||||
clean:
|
|
||||||
rm -rf bin
|
|
||||||
|
|
||||||
# Set a version for the build
|
|
||||||
VERSION := $(shell git describe --tags --always)
|
|
75
README.md
75
README.md
|
@ -2,81 +2,10 @@
|
||||||
![status-badge](https://ci.lila.network/api/badges/22/status.svg)
|
![status-badge](https://ci.lila.network/api/badges/22/status.svg)
|
||||||
[![Please don't upload to GitHub](https://nogithub.codeberg.page/badge.svg)](https://nogithub.codeberg.page)
|
[![Please don't upload to GitHub](https://nogithub.codeberg.page/badge.svg)](https://nogithub.codeberg.page)
|
||||||
|
|
||||||
This is a simple binary to deploy certificates from a [CertWarden](https://www.certwarden.com/) instance.
|
This is a tool to deploy certificates from a [CertWarden](https://www.certwarden.com/) instance.
|
||||||
|
|
||||||
## Quick Start
|
|
||||||
|
|
||||||
Installation of the required CertWarden instance is out of scope of this documentation. For detailed instructions regarding CertWarden, please visit [it's documentation](https://www.certwarden.com/docs/introduction/)
|
|
||||||
|
|
||||||
|
|
||||||
To quickly get started with `certwarden-deploy`, just download the binary...
|
|
||||||
|
|
||||||
```shell
|
|
||||||
# this downloads certwarden-deploy version 0.2.2
|
|
||||||
# to /usr/local/bin/certwarden-deploy
|
|
||||||
sudo wget https://code.lila.network/adoralaura/certwarden-deploy/releases/download/0.2.2/certwarden-deploy-linux-amd64 -O /usr/local/bin/certwarden-deploy
|
|
||||||
|
|
||||||
sudo chmod +x /usr/local/bin/certwarden-deploy
|
|
||||||
```
|
|
||||||
|
|
||||||
... fill out the config file...
|
|
||||||
```shell
|
|
||||||
vi /etc/certwarden-deploy/config.yaml
|
|
||||||
```
|
|
||||||
```yaml
|
|
||||||
# Base URL of the CertWarden instance
|
|
||||||
# required
|
|
||||||
base_url: "https://certwarden.example.com"
|
|
||||||
|
|
||||||
# Set this to true if your CertWarden instance does not have a publicly trusted
|
|
||||||
# TLS certificate (e.g. it has a self signed one)
|
|
||||||
# default is false
|
|
||||||
disable_certificate_validation: false
|
|
||||||
|
|
||||||
# define all managed certificates here
|
|
||||||
certificates:
|
|
||||||
# name is a unique identifier that must start and end with an alphanumeric character,
|
|
||||||
# and can contain the following characters: a-zA-Z0-9._-
|
|
||||||
# required
|
|
||||||
- name: test-certificate.example.com
|
|
||||||
# Contains the API-Key to fetch the certificate from the server
|
|
||||||
# required
|
|
||||||
cert_secret: examplekey_notvalid_hrzjGDDw8z
|
|
||||||
# path where to save the certificate
|
|
||||||
# required
|
|
||||||
cert_path: "/path/to/test-certificate.example.com-cert.pem"
|
|
||||||
# Contains the API-Key to fetch the private key from the server
|
|
||||||
# required
|
|
||||||
key_secret: examplekey_notvalid_hrzbbDDw8z
|
|
||||||
# path where to save the private key
|
|
||||||
# required
|
|
||||||
key_path: "/path/to/test-certificate.example.com-key.pem"
|
|
||||||
# action to run when certificate was updated or --force is on
|
|
||||||
action: "/usr/bin/systemd reload caddy"
|
|
||||||
```
|
|
||||||
|
|
||||||
... and run it!
|
|
||||||
```shell
|
|
||||||
certwarden-deploy -v
|
|
||||||
```
|
|
||||||
## Contributing
|
|
||||||
|
|
||||||
I use my own [Forgejo](https://forgejo.org/) Instance [code.lila.network](https://code.lila.network) to manage issues, pull requests and CI/CD.
|
|
||||||
|
|
||||||
* If you have a trivial fix or improvement, go ahead and send a diff to the maintainer(s) of this repository (see
|
|
||||||
[MAINTAINERS.md](https://code.lila.network/adoralaura/certwarden-deploy/src/branch/main/MAINTAINERS.md)).
|
|
||||||
|
|
||||||
* If you plan to do something more involved, first please [send me a mail]( mailto:dev@lauka.net?subject=%5Bcertwarden-deploy%5D)mso I can create an account for you.
|
|
||||||
|
|
||||||
### Non-development Contibutions
|
|
||||||
|
|
||||||
The best way to help without speaking a lot of Go would be to share your
|
|
||||||
configuration, setup, and tips. If you have something
|
|
||||||
that works and is not in the repository, please pay it forward and
|
|
||||||
share what works.
|
|
||||||
|
|
||||||
## Changelog
|
## Changelog
|
||||||
You can find the Changelog here: [Changelog](https://code.lila.network/adoralaura/certwarden-deploy/src/branch/main/CHANGELOG.md)
|
You can find the Changelog here: [Changelog](https://code.lila.network/adoralaura/certwarden-deploy/src/branch/main/CHANGELOG.md)
|
||||||
|
|
||||||
## License
|
## License
|
||||||
`certwarden-deploy` is available under the MIT license. See the [LICENSE](https://code.lila.network/adoralaura/certwarden-deploy/src/branch/main/LICENSE) file for more info.
|
`certwarden-deploy` is available under the MIT license. See the LICENSE file for more info.
|
||||||
|
|
|
@ -2,20 +2,25 @@
|
||||||
Copyright © 2024 Laura Kalb <dev@lauka.net>
|
Copyright © 2024 Laura Kalb <dev@lauka.net>
|
||||||
The code of this project is available under the MIT license. See the LICENSE file for more info.
|
The code of this project is available under the MIT license. See the LICENSE file for more info.
|
||||||
*/
|
*/
|
||||||
package main
|
package cmd
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"os"
|
"os"
|
||||||
|
"time"
|
||||||
|
|
||||||
"code.lila.network/adoralaura/certwarden-deploy/internal/cli"
|
"code.lila.network/adoralaura/certwarden-deploy/internal/cli"
|
||||||
"code.lila.network/adoralaura/certwarden-deploy/internal/configuration"
|
"code.lila.network/adoralaura/certwarden-deploy/internal/configuration"
|
||||||
|
"github.com/getsentry/sentry-go"
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
// Execute adds all child commands to the root command and sets flags appropriately.
|
||||||
|
// This is called by main.main(). It only needs to happen once to the rootCmd.
|
||||||
|
func Execute() {
|
||||||
err := cli.RootCmd.Execute()
|
err := cli.RootCmd.Execute()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
|
defer sentry.Flush(2 * time.Second)
|
||||||
}
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
15
docs/.gitignore
vendored
15
docs/.gitignore
vendored
|
@ -1,15 +0,0 @@
|
||||||
# Generated files by hugo
|
|
||||||
/public/
|
|
||||||
/resources/_gen/
|
|
||||||
/assets/jsconfig.json
|
|
||||||
hugo_stats.json
|
|
||||||
|
|
||||||
# Executable may be added to repository
|
|
||||||
hugo.exe
|
|
||||||
hugo.darwin
|
|
||||||
hugo.linux
|
|
||||||
|
|
||||||
# Temporary lock file while building
|
|
||||||
/.hugo_build.lock
|
|
||||||
|
|
||||||
!**.html
|
|
|
@ -1,9 +0,0 @@
|
||||||
MIT License
|
|
||||||
|
|
||||||
Copyright 2024 Adora Laura Kalb <dev@lauka.net>
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
@ -1 +0,0 @@
|
||||||
# certwarden-deploy Documentation
|
|
|
@ -1,5 +0,0 @@
|
||||||
+++
|
|
||||||
title = '{{ replace .File.ContentBaseName "-" " " | title }}'
|
|
||||||
date = {{ .Date }}
|
|
||||||
draft = true
|
|
||||||
+++
|
|
|
@ -1,54 +0,0 @@
|
||||||
baseURL = 'https://certwarden-deploy.adora.codes/'
|
|
||||||
languageCode = 'en-us'
|
|
||||||
title = 'certwarden-deploy'
|
|
||||||
author = ""
|
|
||||||
|
|
||||||
theme = "github.com/McShelby/hugo-theme-relearn"
|
|
||||||
repo = "https://code.lila.network/adoralaura/certwarden-deploy"
|
|
||||||
|
|
||||||
enableGitInfo = true
|
|
||||||
enableRobotsTXT = true
|
|
||||||
uniqueHomePage = false # change to false to add sidebar to homepage
|
|
||||||
|
|
||||||
|
|
||||||
[params]
|
|
||||||
disableLandingPageButton = false
|
|
||||||
disableLanguageSwitchingButton = false
|
|
||||||
editURL = "https://code.lila.network/adoralaura/certwarden-deploy/_edit/main/docs/content/${FilePath}"
|
|
||||||
externalLinkTarget = "_blank"
|
|
||||||
headingPre = '<script defer src="https://esseles.adora.codes/script.js" data-website-id="fe4ec517-25b2-4e0d-b502-6bd3a7420849"></script>'
|
|
||||||
disableExplicitIndexURLs = true
|
|
||||||
|
|
||||||
[params.author]
|
|
||||||
name = 'Adora Laura Kalb'
|
|
||||||
|
|
||||||
[outputs]
|
|
||||||
home = ['html', 'rss', 'search']
|
|
||||||
|
|
||||||
[menu]
|
|
||||||
[[menu.shortcuts]]
|
|
||||||
identifier = 'ds'
|
|
||||||
name = "<i class='fa-fw fas fa-code-branch'></i> certwarden-deploy Git Repository"
|
|
||||||
url = 'https://code.lila.network/adoralaura/certwarden-deploy'
|
|
||||||
weight = 10
|
|
||||||
|
|
||||||
[[menu.shortcuts]]
|
|
||||||
name = "<i class='fa-fw fas fa-arrow-up-right-from-square'></i> CertWarden GitHub"
|
|
||||||
url = 'showcase/'
|
|
||||||
weight = 11
|
|
||||||
|
|
||||||
[[menu.shortcuts]]
|
|
||||||
identifier = 'hugodoc'
|
|
||||||
name = "<i class='fa-fw fas fa-arrow-up-right-from-square'></i> CertWarden Website"
|
|
||||||
url = 'https://gohugo.io/'
|
|
||||||
weight = 20
|
|
||||||
|
|
||||||
# [[menu.shortcuts]]
|
|
||||||
# name = "<i class='fa-fw fas fa-bullhorn'></i> Credits"
|
|
||||||
# url = 'more/credits/'
|
|
||||||
# weight = 30
|
|
||||||
#
|
|
||||||
# [[menu.shortcuts]]
|
|
||||||
# name = "<i class='fa-fw fas fa-tags'></i> Tags"
|
|
||||||
# url = 'tags/'
|
|
||||||
# weight = 40
|
|
|
@ -1,93 +0,0 @@
|
||||||
---
|
|
||||||
title: CertWarden-Deploy
|
|
||||||
type: docs
|
|
||||||
---
|
|
||||||
|
|
||||||
[CertWarden](https://www.certwarden.com/) is a self-hosted Centralized ACME Certificate Management platform. With it you can manage and aquire Let's Encrypt certificates.
|
|
||||||
|
|
||||||
However, to deploy them to your hosts, for now there only was a docker client, and that was too bloated for me.
|
|
||||||
|
|
||||||
So I built `certwarden-deploy`, a dependency-less binary that can run via crontab/systemd timers and that can fetch new certificates and run actions after new certificates got rolled out.
|
|
||||||
|
|
||||||
## Quick Start
|
|
||||||
|
|
||||||
Installation of the required CertWarden instance is out of scope of this documentation. For detailed instructions regarding CertWarden, please visit [it's documentation](https://www.certwarden.com/docs/introduction/)
|
|
||||||
|
|
||||||
|
|
||||||
To quickly get started with `certwarden-deploy`, just download the binary...
|
|
||||||
|
|
||||||
```shell
|
|
||||||
# this downloads certwarden-deploy version 0.2.2
|
|
||||||
# to /usr/local/bin/certwarden-deploy
|
|
||||||
sudo wget https://code.lila.network/adoralaura/certwarden-deploy/releases/download/0.2.2/certwarden-deploy-linux-amd64 -O /usr/local/bin/certwarden-deploy
|
|
||||||
|
|
||||||
sudo chmod +x /usr/local/bin/certwarden-deploy
|
|
||||||
```
|
|
||||||
|
|
||||||
... fill out the config file...
|
|
||||||
|
|
||||||
|
|
||||||
`vi /etc/certwarden-deploy/config.yaml`
|
|
||||||
```yaml
|
|
||||||
# Base URL of the CertWarden instance
|
|
||||||
# required
|
|
||||||
base_url: "https://certwarden.example.com"
|
|
||||||
|
|
||||||
# Set this to true if your CertWarden instance does not have a publicly trusted
|
|
||||||
# TLS certificate (e.g. it has a self signed one)
|
|
||||||
# default is false
|
|
||||||
disable_certificate_validation: false
|
|
||||||
|
|
||||||
# define all managed certificates here
|
|
||||||
certificates:
|
|
||||||
|
|
||||||
# name is a unique identifier that must start and end with an alphanumeric character,
|
|
||||||
# and can contain the following characters: a-zA-Z0-9._-
|
|
||||||
# required
|
|
||||||
- name: test-certificate.example.com
|
|
||||||
|
|
||||||
# Contains the API-Key to fetch the certificate from the server
|
|
||||||
# required
|
|
||||||
cert_secret: examplekey_notvalid_hrzjGDDw8z
|
|
||||||
|
|
||||||
# path where to save the certificate
|
|
||||||
# required
|
|
||||||
cert_path: "/path/to/test-certificate.example.com-cert.pem"
|
|
||||||
|
|
||||||
# Contains the API-Key to fetch the private key from the server
|
|
||||||
# required
|
|
||||||
key_secret: examplekey_notvalid_hrzbbDDw8z
|
|
||||||
|
|
||||||
# path where to save the private key
|
|
||||||
# required
|
|
||||||
key_path: "/path/to/test-certificate.example.com-key.pem"
|
|
||||||
|
|
||||||
# action to run when certificate was updated or --force is on
|
|
||||||
action: "/usr/bin/systemd reload caddy"
|
|
||||||
```
|
|
||||||
|
|
||||||
... and run it!
|
|
||||||
```shell
|
|
||||||
certwarden-deploy -v
|
|
||||||
```
|
|
||||||
## Contributing
|
|
||||||
|
|
||||||
I use my own [Forgejo](https://forgejo.org/) Instance [code.lila.network](https://code.lila.network) to manage issues, pull requests and CI/CD.
|
|
||||||
|
|
||||||
* If you have a trivial fix or improvement, go ahead and send a diff to the maintainer(s) of this repository (see
|
|
||||||
[MAINTAINERS.md](https://code.lila.network/adoralaura/certwarden-deploy/src/branch/main/MAINTAINERS.md)).
|
|
||||||
|
|
||||||
* If you plan to do something more involved, first please [send me a mail](mailto:dev@lauka.net?subject=%5Bcertwarden-deploy%5D) so I can create an account for you.
|
|
||||||
|
|
||||||
### Non-development Contibutions
|
|
||||||
|
|
||||||
The best way to help without speaking a lot of Go would be to share your
|
|
||||||
configuration, setup, and tips. If you have something
|
|
||||||
that works and is not in the repository, please pay it forward and
|
|
||||||
share what works.
|
|
||||||
|
|
||||||
## Changelog
|
|
||||||
You can find the Changelog here: [Changelog](https://code.lila.network/adoralaura/certwarden-deploy/src/branch/main/CHANGELOG.md)
|
|
||||||
|
|
||||||
## License
|
|
||||||
`certwarden-deploy` is available under the MIT license. See the [License page](/license/) for more info.
|
|
|
@ -1,85 +0,0 @@
|
||||||
---
|
|
||||||
title: Configuration
|
|
||||||
weight: 20
|
|
||||||
---
|
|
||||||
|
|
||||||
|
|
||||||
This document describes how to configure `certwarden-deploy` and which certificates should be managed by it. The configuration file uses the [YAML format](https://yaml.org/) for a human-readable and easy-to-maintain structure.
|
|
||||||
|
|
||||||
## certwarden-deploy CLI Options
|
|
||||||
```plaintext
|
|
||||||
$ ./certwarden-deploy --help
|
|
||||||
certwarden-deploy is a CLI utility to deploy certificates managed by CertWarden.
|
|
||||||
Configuration is handled by a single YAML file, so you can get started quickly.
|
|
||||||
|
|
||||||
For more information on how to configure this tool, visit the docs at https://certwarden-deploy.adora.codes
|
|
||||||
|
|
||||||
Usage:
|
|
||||||
certwarden-deploy [flags]
|
|
||||||
|
|
||||||
Flags:
|
|
||||||
-c, --config string Path to config file (default is /etc/certwarden-deploy/config.yaml) (default "/etc/certwarden-deploy/config.yaml")
|
|
||||||
-d, --dry-run Just show the would-be changes without changing the file system (turns on verbose logging)
|
|
||||||
-f, --force Force overwriting and execution action to occur, regardless if certificate already exists
|
|
||||||
-h, --help help for certwarden-deploy
|
|
||||||
-q, --quiet Disable any logging (if both -q and -v are set, quiet wins)
|
|
||||||
-v, --verbose Enable verbose logging
|
|
||||||
--version version for certwarden-deploy
|
|
||||||
```
|
|
||||||
|
|
||||||
## Configuration File Options
|
|
||||||
|
|
||||||
`base_url` (required):
|
|
||||||
This string specifies the base URL of your CertWarden instance.
|
|
||||||
|
|
||||||
`disable_certificate_validation` (optional, default: false):
|
|
||||||
This boolean flag indicates whether to disable certificate validation for the CertWarden instance. Set this to true only if your CertWarden instance uses a self-signed certificate and you trust it explicitly. **Disabling validation weakens security, so use it with caution.**
|
|
||||||
|
|
||||||
`certificates:` (required):
|
|
||||||
This is a list that defines each certificate to be managed.
|
|
||||||
Each certificate definition is a nested YAML block with the following properties:
|
|
||||||
|
|
||||||
Each certificate configuration consists of:
|
|
||||||
|
|
||||||
`name` (required):
|
|
||||||
This string is a unique identifier for the certificate and must be the same as in you CertWarden instance.
|
|
||||||
It must start and end with an alphanumeric character and can contain letters (a-zA-Z), numbers (0-9), underscore (_), hyphen (-), and period (.).
|
|
||||||
|
|
||||||
`cert_secret` (required):
|
|
||||||
This string holds the API key used to fetch the certificate data from the CertWarden server.
|
|
||||||
|
|
||||||
`cert_path` (required):
|
|
||||||
This string defines the file path where the downloaded certificate will be saved.
|
|
||||||
|
|
||||||
`key_secret` (required):
|
|
||||||
This string holds the API key used to fetch the private key data from the CertWarden server.
|
|
||||||
|
|
||||||
`key_path` (required):
|
|
||||||
This string defines the file path where the downloaded private key will be saved.
|
|
||||||
|
|
||||||
`action` (optional):
|
|
||||||
This string specifies a command to run after a certificate is updated or when the --force flag is used during execution.
|
|
||||||
The example uses a systemd reload command for the popular reverse proxy named "caddy".
|
|
||||||
|
|
||||||
Example Configuration:
|
|
||||||
```yaml
|
|
||||||
# Base URL of the CertWarden instance
|
|
||||||
base_url: "https://certwarden.example.com"
|
|
||||||
|
|
||||||
# Disable certificate validation (not recommended for production)
|
|
||||||
disable_certificate_validation: false
|
|
||||||
|
|
||||||
# Define all managed certificates here
|
|
||||||
certificates:
|
|
||||||
- name: test-certificate.example.com
|
|
||||||
cert_secret: examplekey_notvalid_hrzjGDDw8z # Replace with your actual key
|
|
||||||
cert_path: "/path/to/test-certificate.example.com-cert.pem"
|
|
||||||
key_secret: examplekey_notvalid_hrzbbDDw8z # Replace with your actual key
|
|
||||||
key_path: "/path/to/test-certificate.example.com-key.pem"
|
|
||||||
action: "/usr/bin/systemctl reload caddy"
|
|
||||||
```
|
|
||||||
Use code with caution.
|
|
||||||
|
|
||||||
## Notes
|
|
||||||
- This documentation assumes you have a basic understanding of YAML syntax. Resources for learning YAML are readily available online.
|
|
||||||
- Replace placeholder values like `examplekey_notvalid_hrzjGDDw8z` with your actual API keys.
|
|
|
@ -1,30 +0,0 @@
|
||||||
---
|
|
||||||
title: Installation
|
|
||||||
weight: 10
|
|
||||||
---
|
|
||||||
|
|
||||||
## Prerequisites
|
|
||||||
|
|
||||||
Before building the project, ensure you have the following installed:
|
|
||||||
- make: A build automation tool
|
|
||||||
- Go: Version 1.22 or later
|
|
||||||
|
|
||||||
## Building the Project from Source
|
|
||||||
|
|
||||||
To build the project, first clone the projects git repository, then navigate to the project's root directory and run the following command:
|
|
||||||
```shell
|
|
||||||
make build
|
|
||||||
```
|
|
||||||
This command will generate the `certwarden-deploy` binary in the `bin/` folder.
|
|
||||||
|
|
||||||
## Getting pre-built Binaries
|
|
||||||
You can also get pre-built binaries from the [releases page](https://code.lila.network/adoralaura/certwarden-deploy/releases). Make sure you get the binaries fitting your architecture!
|
|
||||||
|
|
||||||
## Setting up automatic Certificate Renewals
|
|
||||||
Although not required for `certwarden-deploy` to work, it's highly rrecommended to set up automatic renewals for `certwarden-deploy`, so that you don't need to worry about rolling out your certificates every time they get renewed by CertWarden.
|
|
||||||
|
|
||||||
To do that, there are example `systemd` Service and Timer files included in the `examples/` directory of the `certwarden-deploy` repository.
|
|
||||||
|
|
||||||
Please make sure to customize them to your requirements (path to `certwarden-deploy` binary, user and group, execution interval...) and then drop them into the `/etc/systemd/system/` directory, then enable the timer with `systemctl enable --now certwarden-deploy.timer`
|
|
||||||
|
|
||||||
If you kept the example schedule, `certwarden-deploy` will run every saturday at ~4am.
|
|
|
@ -1,33 +0,0 @@
|
||||||
---
|
|
||||||
title: License
|
|
||||||
weight: 99
|
|
||||||
---
|
|
||||||
|
|
||||||
## Documentation
|
|
||||||
This documentation is available under the [CC BY-SA 4.0](https://creativecommons.org/licenses/by-sa/4.0/)
|
|
||||||
|
|
||||||
## Source Code
|
|
||||||
The source code of `certwarden-deploy` is available under the MIT license:
|
|
||||||
|
|
||||||
```plaintext
|
|
||||||
MIT License
|
|
||||||
|
|
||||||
Copyright © 2024 Adora Laura Kalb <dev@lauka.net>
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
|
||||||
this software and associated documentation files (the "Software"), to deal in
|
|
||||||
the Software without restriction, including without limitation the rights to use,
|
|
||||||
copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the
|
|
||||||
Software, and to permit persons to whom the Software is furnished to do so,
|
|
||||||
subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all
|
|
||||||
copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
|
|
||||||
INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
|
|
||||||
PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
|
||||||
HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
||||||
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
|
||||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
```
|
|
|
@ -1,5 +0,0 @@
|
||||||
module code.lila.network/adoralaura/certwarden-deploy-docs
|
|
||||||
|
|
||||||
go 1.22.2
|
|
||||||
|
|
||||||
require github.com/McShelby/hugo-theme-relearn v0.0.0-20240721222908-7aec99b38dc2 // indirect
|
|
|
@ -1,2 +0,0 @@
|
||||||
github.com/McShelby/hugo-theme-relearn v0.0.0-20240721222908-7aec99b38dc2 h1:022HGVq2CBuTftLgNRiU3rxqh+w3M3ZcschnXbjgomc=
|
|
||||||
github.com/McShelby/hugo-theme-relearn v0.0.0-20240721222908-7aec99b38dc2/go.mod h1:mKQQdxZNIlLvAj8X3tMq+RzntIJSr9z7XdzuMomt0IM=
|
|
|
@ -1,2 +0,0 @@
|
||||||
{{ .Params.headingPost | safeHTML }}
|
|
||||||
<script defer src="https://esseles.adora.codes/script.js" data-website-id="fe4ec517-25b2-4e0d-b502-6bd3a7420849"></script>
|
|
|
@ -1 +0,0 @@
|
||||||
<img src="/images/logo.svg"/>
|
|
BIN
docs/static/images/favicon.ico
vendored
BIN
docs/static/images/favicon.ico
vendored
Binary file not shown.
Before Width: | Height: | Size: 15 KiB |
1
docs/static/images/logo.svg
vendored
1
docs/static/images/logo.svg
vendored
|
@ -1 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg width="100%" height="100%" viewBox="0 0 3246 924" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" xmlns:serif="http://www.serif.com/" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:2;"><g id="BG"></g><rect id="Artboard1" x="0" y="0" width="3245.03" height="923.786" style="fill:none;"/><rect x="142.173" y="142.589" width="513.711" height="659.756" style="fill:#96c8d1;fill-rule:nonzero;"/><rect x="207.956" y="204.786" width="380.629" height="533.018" style="fill:#cde9e3;fill-rule:nonzero;"/><path d="M518.389,552.593l-55.026,-0l0,109.913l27.444,-24.548l27.582,24.548l-0,-109.913Z" style="fill:#96c96c;fill-rule:nonzero;"/><path d="M536.731,543.491c-0,25.237 -20.549,45.785 -45.924,45.785c-25.375,0 -45.924,-20.548 -45.924,-45.785c0,-25.376 20.549,-45.786 45.924,-45.786c25.375,-0 45.924,20.548 45.924,45.786Z" style="fill:#fbba22;fill-rule:nonzero;"/><path d="M655.884,124.385l-513.711,0c-10.067,0 -18.342,8.275 -18.342,18.342l0,659.756c0,10.068 8.275,18.342 18.342,18.342l513.711,0c10.067,0 18.342,-8.274 18.342,-18.342l-0,-659.894c-0,-10.067 -8.275,-18.204 -18.342,-18.204Zm-18.342,659.757l-477.027,-0l0,-623.211l477.027,0l0,623.211Z" style="fill:#211f1e;fill-rule:nonzero;"/><path d="M206.439,747.458l385.179,-0c5.103,-0 9.24,-4.137 9.24,-9.102l0,-531.501c0,-5.103 -4.137,-9.102 -9.24,-9.102l-385.179,-0c-5.103,-0 -9.24,4.137 -9.24,9.102l-0,531.501c-0,4.965 4.137,9.102 9.24,9.102Zm9.102,-531.501l366.838,-0l-0,513.159l-366.838,-0l-0,-513.159Z" style="fill:#211f1e;fill-rule:nonzero;"/><path d="M341.728,600.723l-55.026,-0c-5.103,-0 -9.24,4.137 -9.24,9.102c-0,5.102 4.137,9.102 9.24,9.102l55.026,-0c5.102,-0 9.239,-4.138 9.239,-9.102c-0.138,-4.965 -4.275,-9.102 -9.239,-9.102Zm-61.922,-201.899l238.445,0c5.103,0 9.24,-4.137 9.24,-9.102c-0,-5.102 -4.137,-9.102 -9.24,-9.102l-238.445,0c-5.102,0 -9.239,4.137 -9.239,9.102c-0,4.965 4.137,9.102 9.239,9.102Zm119.154,36.684l-119.292,-0c-5.102,-0 -9.239,4.137 -9.239,9.102c-0,5.103 4.137,9.102 9.239,9.102l119.292,-0c5.102,-0 9.24,-4.137 9.24,-9.102c-0,-5.103 -4.138,-9.102 -9.24,-9.102Zm-119.154,-91.71l238.445,0c5.103,0 9.24,-4.137 9.24,-9.102c-0,-5.102 -4.137,-9.102 -9.24,-9.102l-238.445,0c-5.102,0 -9.239,4.138 -9.239,9.102c-0,4.965 4.137,9.102 9.239,9.102Zm0,-54.887l238.445,-0c5.103,-0 9.24,-4.138 9.24,-9.102c-0,-5.103 -4.137,-9.102 -9.24,-9.102l-238.445,-0c-5.102,-0 -9.239,4.137 -9.239,9.102c-0,4.964 4.137,9.102 9.239,9.102Zm201.899,201.485c-30.34,-0 -55.026,24.685 -55.026,55.025c0,16.274 7.172,30.754 18.342,40.821l0,78.195c0,3.585 2.069,6.895 5.379,8.412c3.31,1.517 7.171,0.828 9.929,-1.517l21.376,-19.169l21.376,19.169c1.655,1.517 3.861,2.345 6.068,2.345c1.241,-0 2.482,-0.276 3.723,-0.828c3.31,-1.517 5.379,-4.689 5.379,-8.412l-0,-78.195c11.171,-10.067 18.342,-24.685 18.342,-40.821c0.138,-30.34 -24.548,-55.025 -54.888,-55.025Zm18.342,153.492l-12.274,-10.895c-3.448,-3.171 -8.826,-3.171 -12.274,0l-12.274,10.895l0,-46.751c5.792,2.069 11.86,3.172 18.342,3.172c6.482,0 12.55,-1.103 18.342,-3.172l0,46.751l0.138,0Zm-18.342,-61.783c-20.273,0 -36.684,-16.411 -36.684,-36.684c0,-20.272 16.411,-36.683 36.684,-36.683c20.273,-0 36.684,16.411 36.684,36.683c-0,20.273 -16.411,36.684 -36.684,36.684Z" style="fill:#211f1e;fill-rule:nonzero;"/><g transform="matrix(283.53,0,0,283.53,3117.47,579.164)"></g><text x="784.992px" y="579.164px" style="font-family:'ArialMT', 'Arial', sans-serif;font-size:283.53px;fill:#fff;">certwarden-deploy</text></svg>
|
|
Before Width: | Height: | Size: 3.6 KiB |
3
go.mod
3
go.mod
|
@ -8,8 +8,11 @@ require (
|
||||||
)
|
)
|
||||||
|
|
||||||
require (
|
require (
|
||||||
|
github.com/getsentry/sentry-go v0.28.1 // indirect
|
||||||
github.com/inconshreveable/mousetrap v1.1.0 // indirect
|
github.com/inconshreveable/mousetrap v1.1.0 // indirect
|
||||||
github.com/kr/pretty v0.3.1 // indirect
|
github.com/kr/pretty v0.3.1 // indirect
|
||||||
github.com/spf13/pflag v1.0.5 // indirect
|
github.com/spf13/pflag v1.0.5 // indirect
|
||||||
|
golang.org/x/sys v0.18.0 // indirect
|
||||||
|
golang.org/x/text v0.14.0 // indirect
|
||||||
gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15 // indirect
|
gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15 // indirect
|
||||||
)
|
)
|
||||||
|
|
6
go.sum
6
go.sum
|
@ -1,5 +1,7 @@
|
||||||
github.com/cpuguy83/go-md2man/v2 v2.0.4/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o=
|
github.com/cpuguy83/go-md2man/v2 v2.0.4/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o=
|
||||||
github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E=
|
github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E=
|
||||||
|
github.com/getsentry/sentry-go v0.28.1 h1:zzaSm/vHmGllRM6Tpx1492r0YDzauArdBfkJRtY6P5k=
|
||||||
|
github.com/getsentry/sentry-go v0.28.1/go.mod h1:1fQZ+7l7eeJ3wYi82q5Hg8GqAPgefRq+FP/QhafYVgg=
|
||||||
github.com/inconshreveable/mousetrap v1.1.0 h1:wN+x4NVGpMsO7ErUn/mUI3vEoE6Jt13X2s0bqwp9tc8=
|
github.com/inconshreveable/mousetrap v1.1.0 h1:wN+x4NVGpMsO7ErUn/mUI3vEoE6Jt13X2s0bqwp9tc8=
|
||||||
github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw=
|
github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw=
|
||||||
github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE=
|
github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE=
|
||||||
|
@ -14,6 +16,10 @@ github.com/spf13/cobra v1.8.1 h1:e5/vxKd/rZsfSJMUX1agtjeTDf+qv1/JdBF8gg5k9ZM=
|
||||||
github.com/spf13/cobra v1.8.1/go.mod h1:wHxEcudfqmLYa8iTfL+OuZPbBZkmvliBWKIezN3kD9Y=
|
github.com/spf13/cobra v1.8.1/go.mod h1:wHxEcudfqmLYa8iTfL+OuZPbBZkmvliBWKIezN3kD9Y=
|
||||||
github.com/spf13/pflag v1.0.5 h1:iy+VFUOCP1a+8yFto/drg2CJ5u0yRoB7fZw3DKv/JXA=
|
github.com/spf13/pflag v1.0.5 h1:iy+VFUOCP1a+8yFto/drg2CJ5u0yRoB7fZw3DKv/JXA=
|
||||||
github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An2Bg=
|
github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An2Bg=
|
||||||
|
golang.org/x/sys v0.18.0 h1:DBdB3niSjOA/O0blCZBqDefyWNYveAYMNF1Wum0DYQ4=
|
||||||
|
golang.org/x/sys v0.18.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
|
||||||
|
golang.org/x/text v0.14.0 h1:ScX5w1eTa3QqT8oi6+ziP7dTV1S2+ALU0bI+0zXKWiQ=
|
||||||
|
golang.org/x/text v0.14.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU=
|
||||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||||
gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15 h1:YR8cESwS4TdDjEe65xsg0ogRM/Nc3DYOhEAlW+xobZo=
|
gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15 h1:YR8cESwS4TdDjEe65xsg0ogRM/Nc3DYOhEAlW+xobZo=
|
||||||
gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||||
|
|
|
@ -30,7 +30,7 @@ func handleRootCmd(cmd *cobra.Command, args []string) {
|
||||||
slog.Error("failed to initialize config", "error", err)
|
slog.Error("failed to initialize config", "error", err)
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
log := logger.Initialize()
|
log := logger.InitializeLogger()
|
||||||
config.SubstituteKeys(log)
|
config.SubstituteKeys(log)
|
||||||
|
|
||||||
validation := config.IsValid()
|
validation := config.IsValid()
|
||||||
|
|
|
@ -24,6 +24,7 @@ var Force bool
|
||||||
type ConfigFileData struct {
|
type ConfigFileData struct {
|
||||||
BaseURL string `yaml:"base_url"`
|
BaseURL string `yaml:"base_url"`
|
||||||
DisableCertificateValidation bool `yaml:"disable_certificate_validation"`
|
DisableCertificateValidation bool `yaml:"disable_certificate_validation"`
|
||||||
|
Sentry SentryData `yaml:"sentry,omitempty"`
|
||||||
Certificates []CertificateData `yaml:"certificates"`
|
Certificates []CertificateData `yaml:"certificates"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -37,6 +38,10 @@ type CertificateData struct {
|
||||||
Action string `yaml:"action"`
|
Action string `yaml:"action"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type SentryData struct {
|
||||||
|
DSN string `yaml:"dsn"`
|
||||||
|
}
|
||||||
|
|
||||||
type ConfigValidationError struct {
|
type ConfigValidationError struct {
|
||||||
ErrorMessages []string
|
ErrorMessages []string
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,7 @@
|
||||||
package constants
|
package constants
|
||||||
|
|
||||||
var Version string
|
const Version = "0.2.1"
|
||||||
|
|
||||||
var UserAgent = "certwarden-deploy/" + Version + " +https://code.lila.network/adoralaura/certwarden-deploy"
|
|
||||||
|
|
||||||
const CertificateApiPath = "/certwarden/api/v1/download/certificates/"
|
const CertificateApiPath = "/certwarden/api/v1/download/certificates/"
|
||||||
const KeyApiPath = "/certwarden/api/v1/download/privatekeys/"
|
const KeyApiPath = "/certwarden/api/v1/download/privatekeys/"
|
||||||
const ApiKeyHeaderName = "X-API-Key"
|
const ApiKeyHeaderName = "X-API-Key"
|
||||||
|
const UserAgent = "certwarden-deploy/" + Version + " +https://code.lila.network/adoralaura/certwarden-deploy"
|
||||||
|
|
|
@ -8,8 +8,7 @@ import (
|
||||||
"code.lila.network/adoralaura/certwarden-deploy/internal/configuration"
|
"code.lila.network/adoralaura/certwarden-deploy/internal/configuration"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Initialize initializes a *slog.Logger with the right log level and options.
|
func InitializeLogger() *slog.Logger {
|
||||||
func Initialize() *slog.Logger {
|
|
||||||
logLevel := slog.LevelInfo
|
logLevel := slog.LevelInfo
|
||||||
|
|
||||||
if configuration.VerboseLogging {
|
if configuration.VerboseLogging {
|
||||||
|
|
11
main.go
Normal file
11
main.go
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
/*
|
||||||
|
Copyright © 2024 Laura Kalb <dev@lauka.net>
|
||||||
|
The code of this project is available under the MIT license. See the LICENSE file for more info.
|
||||||
|
*/
|
||||||
|
package main
|
||||||
|
|
||||||
|
import cmd "code.lila.network/adoralaura/certwarden-deploy/cmd/certwarden-deploy"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
cmd.Execute()
|
||||||
|
}
|
Loading…
Reference in a new issue