commit
						21b2ffa42e
					
				| 
						 | 
				
			
			@ -275,3 +275,24 @@ acme.sh --deploy -d haproxy.example.com --deploy-hook haproxy
 | 
			
		|||
```
 | 
			
		||||
 | 
			
		||||
The path for the PEM file will be stored with the domain configuration and will be available when renewing, so that deploy will happen automatically when renewed.
 | 
			
		||||
 | 
			
		||||
## 11. Deploy your cert to Gitlab pages
 | 
			
		||||
 | 
			
		||||
You must define the API key and the informations for the project and Gitlab page you are updating the certificate for.
 | 
			
		||||
 | 
			
		||||
```sh
 | 
			
		||||
# The token can be created in your user settings under "Access Tokens"
 | 
			
		||||
export GITLAB_TOKEN="xxxxxxxxxxx"
 | 
			
		||||
 | 
			
		||||
# The project ID is displayed on the home page of the project
 | 
			
		||||
export GITLAB_PROJECT_ID=12345678
 | 
			
		||||
 | 
			
		||||
# The domain must match the one defined for the Gitlab page, without "https://"
 | 
			
		||||
export GITLAB_DOMAIN="www.mydomain.com"
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
You can then deploy the certificate as follows
 | 
			
		||||
 | 
			
		||||
```sh
 | 
			
		||||
acme.sh --deploy -d www.mydomain.com --deploy-hook gitlab
 | 
			
		||||
```
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,80 @@
 | 
			
		|||
#!/usr/bin/env sh
 | 
			
		||||
 | 
			
		||||
# Script to deploy certificate to a Gitlab hosted page
 | 
			
		||||
 | 
			
		||||
# The following variables exported from environment will be used.
 | 
			
		||||
# If not set then values previously saved in domain.conf file are used.
 | 
			
		||||
 | 
			
		||||
# All the variables are required
 | 
			
		||||
 | 
			
		||||
# export GITLAB_TOKEN="xxxxxxx"
 | 
			
		||||
# export GITLAB_PROJECT_ID=012345
 | 
			
		||||
# export GITLAB_DOMAIN="mydomain.com"
 | 
			
		||||
 | 
			
		||||
gitlab_deploy() {
 | 
			
		||||
  _cdomain="$1"
 | 
			
		||||
  _ckey="$2"
 | 
			
		||||
  _ccert="$3"
 | 
			
		||||
  _cca="$4"
 | 
			
		||||
  _cfullchain="$5"
 | 
			
		||||
 | 
			
		||||
  _debug _cdomain "$_cdomain"
 | 
			
		||||
  _debug _ckey "$_ckey"
 | 
			
		||||
  _debug _ccert "$_ccert"
 | 
			
		||||
  _debug _cca "$_cca"
 | 
			
		||||
  _debug _cfullchain "$_cfullchain"
 | 
			
		||||
 | 
			
		||||
  if [ -z "$GITLAB_TOKEN" ]; then
 | 
			
		||||
    if [ -z "$Le_Deploy_gitlab_token" ]; then
 | 
			
		||||
      _err "GITLAB_TOKEN not defined."
 | 
			
		||||
      return 1
 | 
			
		||||
    fi
 | 
			
		||||
  else
 | 
			
		||||
    Le_Deploy_gitlab_token="$GITLAB_TOKEN"
 | 
			
		||||
    _savedomainconf Le_Deploy_gitlab_token "$Le_Deploy_gitlab_token"
 | 
			
		||||
  fi
 | 
			
		||||
 | 
			
		||||
  if [ -z "$GITLAB_PROJECT_ID" ]; then
 | 
			
		||||
    if [ -z "$Le_Deploy_gitlab_project_id" ]; then
 | 
			
		||||
      _err "GITLAB_PROJECT_ID not defined."
 | 
			
		||||
      return 1
 | 
			
		||||
    fi
 | 
			
		||||
  else
 | 
			
		||||
    Le_Deploy_gitlab_project_id="$GITLAB_PROJECT_ID"
 | 
			
		||||
    _savedomainconf Le_Deploy_gitlab_project_id "$Le_Deploy_gitlab_project_id"
 | 
			
		||||
  fi
 | 
			
		||||
 | 
			
		||||
  if [ -z "$GITLAB_DOMAIN" ]; then
 | 
			
		||||
    if [ -z "$Le_Deploy_gitlab_domain" ]; then
 | 
			
		||||
      _err "GITLAB_DOMAIN not defined."
 | 
			
		||||
      return 1
 | 
			
		||||
    fi
 | 
			
		||||
  else
 | 
			
		||||
    Le_Deploy_gitlab_domain="$GITLAB_DOMAIN"
 | 
			
		||||
    _savedomainconf Le_Deploy_gitlab_domain "$Le_Deploy_gitlab_domain"
 | 
			
		||||
  fi
 | 
			
		||||
 | 
			
		||||
  string_fullchain=$(_url_encode <"$_cfullchain")
 | 
			
		||||
  string_key=$(_url_encode <"$_ckey")
 | 
			
		||||
 | 
			
		||||
  body="certificate=$string_fullchain&key=$string_key"
 | 
			
		||||
 | 
			
		||||
  export _H1="PRIVATE-TOKEN: $Le_Deploy_gitlab_token"
 | 
			
		||||
 | 
			
		||||
  gitlab_url="https://gitlab.com/api/v4/projects/$Le_Deploy_gitlab_project_id/pages/domains/$Le_Deploy_gitlab_domain"
 | 
			
		||||
 | 
			
		||||
  _response=$(_post "$body" "$gitlab_url" 0 PUT | _dbase64 "multiline")
 | 
			
		||||
 | 
			
		||||
  error_response="error"
 | 
			
		||||
 | 
			
		||||
  if test "${_response#*$error_response}" != "$_response"; then
 | 
			
		||||
    _err "Error in deploying certificate:"
 | 
			
		||||
    _err "$_response"
 | 
			
		||||
    return 1
 | 
			
		||||
  fi
 | 
			
		||||
 | 
			
		||||
  _debug response "$_response"
 | 
			
		||||
  _info "Certificate successfully deployed"
 | 
			
		||||
 | 
			
		||||
  return 0
 | 
			
		||||
}
 | 
			
		||||
		Loading…
	
		Reference in New Issue