feat(jfrog): add JFrog vscode extension, CLI completion and docker support (#115)
This commit is contained in:
committed by
GitHub
parent
382933aece
commit
357bd41252
@@ -21,7 +21,6 @@ module "jfrog" {
|
|||||||
source = "https://registry.coder.com/modules/jfrog-oauth"
|
source = "https://registry.coder.com/modules/jfrog-oauth"
|
||||||
agent_id = coder_agent.example.id
|
agent_id = coder_agent.example.id
|
||||||
jfrog_url = "https://jfrog.example.com"
|
jfrog_url = "https://jfrog.example.com"
|
||||||
auth_method = "oauth"
|
|
||||||
username_field = "username" # If you are using GitHub to login to both Coder and Artifactory, use username_field = "username"
|
username_field = "username" # If you are using GitHub to login to both Coder and Artifactory, use username_field = "username"
|
||||||
package_managers = {
|
package_managers = {
|
||||||
"npm": "npm",
|
"npm": "npm",
|
||||||
@@ -106,6 +105,25 @@ jf pip install requests
|
|||||||
pip install requests
|
pip install requests
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### Configure code-server with JFrog extension
|
||||||
|
|
||||||
|
The [JFrog extension](https://open-vsx.org/extension/JFrog/jfrog-vscode-extension) for VS Code allows you to interact with Artifactory from within the IDE.
|
||||||
|
|
||||||
|
```hcl
|
||||||
|
module "jfrog" {
|
||||||
|
source = "https://registry.coder.com/modules/jfrog-oauth"
|
||||||
|
agent_id = coder_agent.example.id
|
||||||
|
jfrog_url = "https://jfrog.example.com"
|
||||||
|
username_field = "username" # If you are using GitHub to login to both Coder and Artifactory, use username_field = "username"
|
||||||
|
configure_code_server = true # Add JFrog extension configuration for code-server
|
||||||
|
package_managers = {
|
||||||
|
"npm": "npm",
|
||||||
|
"go": "go",
|
||||||
|
"pypi": "pypi"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
### Using the access token in other terraform resources
|
### Using the access token in other terraform resources
|
||||||
|
|
||||||
JFrog Access token is also available as a terraform output. You can use it in other terraform resources. For example, you can use it to configure an [Artifactory docker registry](https://jfrog.com/help/r/jfrog-artifactory-documentation/docker-registry) with the [docker terraform provider](https://registry.terraform.io/providers/kreuzwerker/docker/latest/docs).
|
JFrog Access token is also available as a terraform output. You can use it in other terraform resources. For example, you can use it to configure an [Artifactory docker registry](https://jfrog.com/help/r/jfrog-artifactory-documentation/docker-registry) with the [docker terraform provider](https://registry.terraform.io/providers/kreuzwerker/docker/latest/docs).
|
||||||
|
|||||||
@@ -4,14 +4,19 @@ terraform {
|
|||||||
required_providers {
|
required_providers {
|
||||||
coder = {
|
coder = {
|
||||||
source = "coder/coder"
|
source = "coder/coder"
|
||||||
version = ">= 0.12"
|
version = ">= 0.12.4"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
variable "jfrog_url" {
|
variable "jfrog_url" {
|
||||||
type = string
|
type = string
|
||||||
description = "JFrog instance URL. e.g. https://jfrog.example.com"
|
description = "JFrog instance URL. e.g. https://myartifactory.jfrog.io"
|
||||||
|
# ensue the URL is HTTPS or HTTP
|
||||||
|
validation {
|
||||||
|
condition = can(regex("^(https|http)://", var.jfrog_url))
|
||||||
|
error_message = "jfrog_url must be a valid URL starting with either 'https://' or 'http://'"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
variable "username_field" {
|
variable "username_field" {
|
||||||
@@ -35,15 +40,22 @@ variable "agent_id" {
|
|||||||
description = "The ID of a Coder agent."
|
description = "The ID of a Coder agent."
|
||||||
}
|
}
|
||||||
|
|
||||||
|
variable "configure_code_server" {
|
||||||
|
type = bool
|
||||||
|
description = "Set to true to configure code-server to use JFrog."
|
||||||
|
default = false
|
||||||
|
}
|
||||||
|
|
||||||
variable "package_managers" {
|
variable "package_managers" {
|
||||||
type = map(string)
|
type = map(string)
|
||||||
description = <<EOF
|
description = <<EOF
|
||||||
A map of package manager names to their respective artifactory repositories.
|
A map of package manager names to their respective artifactory repositories.
|
||||||
For example:
|
For example:
|
||||||
{
|
{
|
||||||
"npm": "npm-local",
|
"npm": "YOUR_NPM_REPO_KEY",
|
||||||
"go": "go-local",
|
"go": "YOUR_GO_REPO_KEY",
|
||||||
"pypi": "pypi-local"
|
"pypi": "YOUR_PYPI_REPO_KEY",
|
||||||
|
"docker": "YOUR_DOCKER_REPO_KEY"
|
||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
}
|
}
|
||||||
@@ -51,6 +63,7 @@ EOF
|
|||||||
locals {
|
locals {
|
||||||
# The username field to use for artifactory
|
# The username field to use for artifactory
|
||||||
username = var.username_field == "email" ? data.coder_workspace.me.owner_email : data.coder_workspace.me.owner
|
username = var.username_field == "email" ? data.coder_workspace.me.owner_email : data.coder_workspace.me.owner
|
||||||
|
jfrog_host = replace(var.jfrog_url, "https://", "")
|
||||||
}
|
}
|
||||||
|
|
||||||
data "coder_workspace" "me" {}
|
data "coder_workspace" "me" {}
|
||||||
@@ -65,17 +78,47 @@ resource "coder_script" "jfrog" {
|
|||||||
icon = "/icon/jfrog.svg"
|
icon = "/icon/jfrog.svg"
|
||||||
script = templatefile("${path.module}/run.sh", {
|
script = templatefile("${path.module}/run.sh", {
|
||||||
JFROG_URL : var.jfrog_url,
|
JFROG_URL : var.jfrog_url,
|
||||||
JFROG_HOST : replace(var.jfrog_url, "https://", ""),
|
JFROG_HOST : local.jfrog_host,
|
||||||
ARTIFACTORY_USERNAME : local.username,
|
ARTIFACTORY_USERNAME : local.username,
|
||||||
ARTIFACTORY_EMAIL : data.coder_workspace.me.owner_email,
|
ARTIFACTORY_EMAIL : data.coder_workspace.me.owner_email,
|
||||||
ARTIFACTORY_ACCESS_TOKEN : data.coder_external_auth.jfrog.access_token,
|
ARTIFACTORY_ACCESS_TOKEN : data.coder_external_auth.jfrog.access_token,
|
||||||
|
CONFIGURE_CODE_SERVER : var.configure_code_server,
|
||||||
REPOSITORY_NPM : lookup(var.package_managers, "npm", ""),
|
REPOSITORY_NPM : lookup(var.package_managers, "npm", ""),
|
||||||
REPOSITORY_GO : lookup(var.package_managers, "go", ""),
|
REPOSITORY_GO : lookup(var.package_managers, "go", ""),
|
||||||
REPOSITORY_PYPI : lookup(var.package_managers, "pypi", ""),
|
REPOSITORY_PYPI : lookup(var.package_managers, "pypi", ""),
|
||||||
|
REPOSITORY_DOCKER : lookup(var.package_managers, "docker", ""),
|
||||||
})
|
})
|
||||||
run_on_start = true
|
run_on_start = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
resource "coder_env" "jfrog_ide_url" {
|
||||||
|
count = var.configure_code_server ? 1 : 0
|
||||||
|
agent_id = var.agent_id
|
||||||
|
name = "JFROG_IDE_URL"
|
||||||
|
value = var.jfrog_url
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "coder_env" "jfrog_ide_access_token" {
|
||||||
|
count = var.configure_code_server ? 1 : 0
|
||||||
|
agent_id = var.agent_id
|
||||||
|
name = "JFROG_IDE_ACCESS_TOKEN"
|
||||||
|
value = data.coder_external_auth.jfrog.access_token
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "coder_env" "jfrog_ide_store_connection" {
|
||||||
|
count = var.configure_code_server ? 1 : 0
|
||||||
|
agent_id = var.agent_id
|
||||||
|
name = "JFROG_IDE_STORE_CONNECTION"
|
||||||
|
value = true
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "coder_env" "goproxy" {
|
||||||
|
count = lookup(var.package_managers, "go", "") == "" ? 0 : 1
|
||||||
|
agent_id = var.agent_id
|
||||||
|
name = "GOPROXY"
|
||||||
|
value = "https://${local.username}:${data.coder_external_auth.jfrog.access_token}@${local.jfrog_host}/artifactory/api/go/${lookup(var.package_managers, "go", "")}"
|
||||||
|
}
|
||||||
|
|
||||||
output "access_token" {
|
output "access_token" {
|
||||||
description = "value of the JFrog access token"
|
description = "value of the JFrog access token"
|
||||||
value = data.coder_external_auth.jfrog.access_token
|
value = data.coder_external_auth.jfrog.access_token
|
||||||
|
|||||||
@@ -7,7 +7,6 @@ if command -v jf > /dev/null 2>&1; then
|
|||||||
echo "✅ JFrog CLI is already installed, skipping installation."
|
echo "✅ JFrog CLI is already installed, skipping installation."
|
||||||
else
|
else
|
||||||
echo "📦 Installing JFrog CLI..."
|
echo "📦 Installing JFrog CLI..."
|
||||||
# Install the JFrog CLI.
|
|
||||||
curl -fL https://install-cli.jfrog.io | sudo sh
|
curl -fL https://install-cli.jfrog.io | sudo sh
|
||||||
sudo chmod 755 /usr/local/bin/jf
|
sudo chmod 755 /usr/local/bin/jf
|
||||||
fi
|
fi
|
||||||
@@ -15,30 +14,31 @@ fi
|
|||||||
# The jf CLI checks $CI when determining whether to use interactive
|
# The jf CLI checks $CI when determining whether to use interactive
|
||||||
# flows.
|
# flows.
|
||||||
export CI=true
|
export CI=true
|
||||||
# Authenticate with the JFrog CLI.
|
# Authenticate JFrog CLI with Artifactory.
|
||||||
jf c rm 0 || true
|
echo "${ARTIFACTORY_ACCESS_TOKEN}" | jf c add --access-token-stdin --url "${JFROG_URL}" --overwrite 0
|
||||||
echo "${ARTIFACTORY_ACCESS_TOKEN}" | jf c add --access-token-stdin --url "${JFROG_URL}" 0
|
# Set the configured server as the default.
|
||||||
|
jf c use 0
|
||||||
|
|
||||||
|
# Configure npm to use the Artifactory "npm" repository.
|
||||||
if [ -z "${REPOSITORY_NPM}" ]; then
|
if [ -z "${REPOSITORY_NPM}" ]; then
|
||||||
echo "🤔 REPOSITORY_NPM is not set, skipping npm configuration."
|
echo "🤔 no npm repository is set, skipping npm configuration."
|
||||||
|
echo "You can configure an npm repository by providing the a key for 'npm' in the 'package_managers' input."
|
||||||
else
|
else
|
||||||
# check if npm is installed and configure it to use the Artifactory "npm" repository.
|
|
||||||
if command -v npm > /dev/null 2>&1; then
|
|
||||||
echo "📦 Configuring npm..."
|
echo "📦 Configuring npm..."
|
||||||
jf npmc --global --repo-resolve "${REPOSITORY_NPM}"
|
jf npmc --global --repo-resolve "${REPOSITORY_NPM}"
|
||||||
fi
|
|
||||||
cat << EOF > ~/.npmrc
|
cat << EOF > ~/.npmrc
|
||||||
email = ${ARTIFACTORY_EMAIL}
|
email=${ARTIFACTORY_EMAIL}
|
||||||
registry = ${JFROG_URL}/artifactory/api/npm/${REPOSITORY_NPM}
|
registry=${JFROG_URL}/artifactory/api/npm/${REPOSITORY_NPM}
|
||||||
EOF
|
EOF
|
||||||
jf rt curl /api/npm/auth >> ~/.npmrc
|
echo "//${JFROG_HOST}/artifactory/api/npm/${REPOSITORY_NPM}/:_authToken=${ARTIFACTORY_ACCESS_TOKEN}" >> ~/.npmrc
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Configure the `pip` to use the Artifactory "python" repository.
|
# Configure the `pip` to use the Artifactory "python" repository.
|
||||||
if [ -z "${REPOSITORY_PYPI}" ]; then
|
if [ -z "${REPOSITORY_PYPI}" ]; then
|
||||||
echo "🤔 REPOSITORY_PYPI is not set, skipping pip configuration."
|
echo "🤔 no pypi repository is set, skipping pip configuration."
|
||||||
|
echo "You can configure a pypi repository by providing the a key for 'pypi' in the 'package_managers' input."
|
||||||
else
|
else
|
||||||
echo "🐍 Configuring pip..."
|
echo "📦 Configuring pip..."
|
||||||
jf pipc --global --repo-resolve "${REPOSITORY_PYPI}"
|
jf pipc --global --repo-resolve "${REPOSITORY_PYPI}"
|
||||||
mkdir -p ~/.pip
|
mkdir -p ~/.pip
|
||||||
cat << EOF > ~/.pip/pip.conf
|
cat << EOF > ~/.pip/pip.conf
|
||||||
@@ -47,12 +47,76 @@ index-url = https://${ARTIFACTORY_USERNAME}:${ARTIFACTORY_ACCESS_TOKEN}@${JFROG_
|
|||||||
EOF
|
EOF
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Set GOPROXY to use the Artifactory "go" repository.
|
# Configure Artifactory "go" repository.
|
||||||
if [ -z "${REPOSITORY_GO}" ]; then
|
if [ -z "${REPOSITORY_GO}" ]; then
|
||||||
echo "🤔 REPOSITORY_GO is not set, skipping go configuration."
|
echo "🤔 no go repository is set, skipping go configuration."
|
||||||
|
echo "You can configure a go repository by providing the a key for 'go' in the 'package_managers' input."
|
||||||
else
|
else
|
||||||
echo "🐹 Configuring go..."
|
echo "🐹 Configuring go..."
|
||||||
jf go-config --global --repo-resolve "${REPOSITORY_GO}"
|
jf goc --global --repo-resolve "${REPOSITORY_GO}"
|
||||||
export GOPROXY="https://${ARTIFACTORY_USERNAME}:${ARTIFACTORY_ACCESS_TOKEN}@${JFROG_HOST}/artifactory/api/go/${REPOSITORY_GO}"
|
|
||||||
fi
|
fi
|
||||||
echo "🥳 Configuration complete!"
|
echo "🥳 Configuration complete!"
|
||||||
|
|
||||||
|
# Configure the JFrog CLI to use the Artifactory "docker" repository.
|
||||||
|
if [ -z "${REPOSITORY_DOCKER}" ]; then
|
||||||
|
echo "🤔 no docker repository is set, skipping docker configuration."
|
||||||
|
echo "You can configure a docker repository by providing the a key for 'docker' in the 'package_managers' input."
|
||||||
|
else
|
||||||
|
if command -v docker > /dev/null 2>&1; then
|
||||||
|
echo "🔑 Configuring 🐳 docker credentials..."
|
||||||
|
mkdir -p ~/.docker
|
||||||
|
echo -n "${ARTIFACTORY_ACCESS_TOKEN}" | docker login ${JFROG_HOST} --username ${ARTIFACTORY_USERNAME} --password-stdin
|
||||||
|
else
|
||||||
|
echo "🤔 no docker is installed, skipping docker configuration."
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Install the JFrog vscode extension for code-server.
|
||||||
|
if [ "${CONFIGURE_CODE_SERVER}" == "true" ]; then
|
||||||
|
while ! [ -x /tmp/code-server/bin/code-server ]; do
|
||||||
|
counter=0
|
||||||
|
if [ $counter -eq 60 ]; then
|
||||||
|
echo "Timed out waiting for /tmp/code-server/bin/code-server to be installed."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
echo "Waiting for /tmp/code-server/bin/code-server to be installed..."
|
||||||
|
sleep 1
|
||||||
|
((counter++))
|
||||||
|
done
|
||||||
|
echo "📦 Installing JFrog extension..."
|
||||||
|
/tmp/code-server/bin/code-server --install-extension jfrog.jfrog-vscode-extension
|
||||||
|
echo "🥳 JFrog extension installed!"
|
||||||
|
else
|
||||||
|
echo "🤔 Skipping JFrog extension installation. Set configure_code_server to true to install the JFrog extension."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Configure the JFrog CLI completion
|
||||||
|
echo "📦 Configuring JFrog CLI completion..."
|
||||||
|
# Get the user's shell
|
||||||
|
SHELLNAME=$(grep "^$USER" /etc/passwd | awk -F':' '{print $7}' | awk -F'/' '{print $NF}')
|
||||||
|
# Generate the completion script
|
||||||
|
jf completion $SHELLNAME --install
|
||||||
|
# Add the completion script to the user's shell profile
|
||||||
|
if [ "$SHELLNAME" == "bash" ] && [ -f ~/.bashrc ]; then
|
||||||
|
if ! grep -q "# jf CLI shell completion" ~/.bashrc; then
|
||||||
|
echo "" >> ~/.bashrc
|
||||||
|
echo "# BEGIN: jf CLI shell completion (added by coder module jfrog-oauth)" >> ~/.bashrc
|
||||||
|
echo 'source "$HOME/.jfrog/jfrog_bash_completion"' >> ~/.bashrc
|
||||||
|
echo "# END: jf CLI shell completion" >> ~/.bashrc
|
||||||
|
else
|
||||||
|
echo "🥳 ~/.bashrc already contains jf CLI shell completion configuration, skipping."
|
||||||
|
fi
|
||||||
|
elif [ "$SHELLNAME" == "zsh" ] && [ -f ~/.zshrc ]; then
|
||||||
|
if ! grep -q "# jf CLI shell completion" ~/.zshrc; then
|
||||||
|
echo "" >> ~/.zshrc
|
||||||
|
echo "# BEGIN: jf CLI shell completion (added by coder module jfrog-oauth)" >> ~/.zshrc
|
||||||
|
echo "autoload -Uz compinit" >> ~/.zshrc
|
||||||
|
echo "compinit" >> ~/.zshrc
|
||||||
|
echo 'source "$HOME/.jfrog/jfrog_zsh_completion"' >> ~/.zshrc
|
||||||
|
echo "# END: jf CLI shell completion" >> ~/.zshrc
|
||||||
|
else
|
||||||
|
echo "🥳 ~/.zshrc already contains jf CLI shell completion configuration, skipping."
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "🤔 ~/.bashrc or ~/.zshrc does not exist, skipping jf CLI shell completion configuration."
|
||||||
|
fi
|
||||||
|
|||||||
@@ -72,6 +72,25 @@ go get github.com/golang/example/hello
|
|||||||
pip install requests
|
pip install requests
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### Configure code-server with JFrog extension
|
||||||
|
|
||||||
|
The [JFrog extension](https://open-vsx.org/extension/JFrog/jfrog-vscode-extension) for VS Code allows you to interact with Artifactory from within the IDE.
|
||||||
|
|
||||||
|
```hcl
|
||||||
|
module "jfrog" {
|
||||||
|
source = "https://registry.coder.com/modules/jfrog-token"
|
||||||
|
agent_id = coder_agent.example.id
|
||||||
|
jfrog_url = "https://XXXX.jfrog.io"
|
||||||
|
artifactory_access_token = var.artifactory_access_token
|
||||||
|
configure_code_server = true # Add JFrog extension configuration for code-server
|
||||||
|
package_managers = {
|
||||||
|
"npm": "npm",
|
||||||
|
"go": "go",
|
||||||
|
"pypi": "pypi"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
### Using the access token in other terraform resources
|
### Using the access token in other terraform resources
|
||||||
|
|
||||||
JFrog Access token is also available as a terraform output. You can use it in other terraform resources. For example, you can use it to configure an [Artifactory docker registry](https://jfrog.com/help/r/jfrog-artifactory-documentation/docker-registry) with the [docker terraform provider](https://registry.terraform.io/providers/kreuzwerker/docker/latest/docs).
|
JFrog Access token is also available as a terraform output. You can use it in other terraform resources. For example, you can use it to configure an [Artifactory docker registry](https://jfrog.com/help/r/jfrog-artifactory-documentation/docker-registry) with the [docker terraform provider](https://registry.terraform.io/providers/kreuzwerker/docker/latest/docs).
|
||||||
|
|||||||
@@ -4,18 +4,23 @@ terraform {
|
|||||||
required_providers {
|
required_providers {
|
||||||
coder = {
|
coder = {
|
||||||
source = "coder/coder"
|
source = "coder/coder"
|
||||||
version = ">= 0.12"
|
version = ">= 0.12.4"
|
||||||
}
|
}
|
||||||
artifactory = {
|
artifactory = {
|
||||||
source = "registry.terraform.io/jfrog/artifactory"
|
source = "registry.terraform.io/jfrog/artifactory"
|
||||||
version = "~> 9.8.0"
|
version = "~> 10.0.2"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
variable "jfrog_url" {
|
variable "jfrog_url" {
|
||||||
type = string
|
type = string
|
||||||
description = "JFrog instance URL. e.g. https://YYY.jfrog.io"
|
description = "JFrog instance URL. e.g. https://myartifactory.jfrog.io"
|
||||||
|
# ensue the URL is HTTPS or HTTP
|
||||||
|
validation {
|
||||||
|
condition = can(regex("^(https|http)://", var.jfrog_url))
|
||||||
|
error_message = "jfrog_url must be a valid URL starting with either 'https://' or 'http://'"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
variable "artifactory_access_token" {
|
variable "artifactory_access_token" {
|
||||||
@@ -56,15 +61,22 @@ variable "agent_id" {
|
|||||||
description = "The ID of a Coder agent."
|
description = "The ID of a Coder agent."
|
||||||
}
|
}
|
||||||
|
|
||||||
|
variable "configure_code_server" {
|
||||||
|
type = bool
|
||||||
|
description = "Set to true to configure code-server to use JFrog."
|
||||||
|
default = false
|
||||||
|
}
|
||||||
|
|
||||||
variable "package_managers" {
|
variable "package_managers" {
|
||||||
type = map(string)
|
type = map(string)
|
||||||
description = <<EOF
|
description = <<EOF
|
||||||
A map of package manager names to their respective artifactory repositories.
|
A map of package manager names to their respective artifactory repositories.
|
||||||
For example:
|
For example:
|
||||||
{
|
{
|
||||||
"npm": "npm-local",
|
"npm": "YOUR_NPM_REPO_KEY",
|
||||||
"go": "go-local",
|
"go": "YOUR_GO_REPO_KEY",
|
||||||
"pypi": "pypi-local"
|
"pypi": "YOUR_PYPI_REPO_KEY",
|
||||||
|
"docker": "YOUR_DOCKER_REPO_KEY"
|
||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
}
|
}
|
||||||
@@ -72,6 +84,7 @@ EOF
|
|||||||
locals {
|
locals {
|
||||||
# The username field to use for artifactory
|
# The username field to use for artifactory
|
||||||
username = var.username_field == "email" ? data.coder_workspace.me.owner_email : data.coder_workspace.me.owner
|
username = var.username_field == "email" ? data.coder_workspace.me.owner_email : data.coder_workspace.me.owner
|
||||||
|
jfrog_host = replace(var.jfrog_url, "https://", "")
|
||||||
}
|
}
|
||||||
|
|
||||||
# Configure the Artifactory provider
|
# Configure the Artifactory provider
|
||||||
@@ -98,17 +111,47 @@ resource "coder_script" "jfrog" {
|
|||||||
icon = "/icon/jfrog.svg"
|
icon = "/icon/jfrog.svg"
|
||||||
script = templatefile("${path.module}/run.sh", {
|
script = templatefile("${path.module}/run.sh", {
|
||||||
JFROG_URL : var.jfrog_url,
|
JFROG_URL : var.jfrog_url,
|
||||||
JFROG_HOST : replace(var.jfrog_url, "https://", ""),
|
JFROG_HOST : local.jfrog_host,
|
||||||
ARTIFACTORY_USERNAME : local.username,
|
ARTIFACTORY_USERNAME : local.username,
|
||||||
ARTIFACTORY_EMAIL : data.coder_workspace.me.owner_email,
|
ARTIFACTORY_EMAIL : data.coder_workspace.me.owner_email,
|
||||||
ARTIFACTORY_ACCESS_TOKEN : artifactory_scoped_token.me.access_token,
|
ARTIFACTORY_ACCESS_TOKEN : artifactory_scoped_token.me.access_token,
|
||||||
|
CONFIGURE_CODE_SERVER : var.configure_code_server,
|
||||||
REPOSITORY_NPM : lookup(var.package_managers, "npm", ""),
|
REPOSITORY_NPM : lookup(var.package_managers, "npm", ""),
|
||||||
REPOSITORY_GO : lookup(var.package_managers, "go", ""),
|
REPOSITORY_GO : lookup(var.package_managers, "go", ""),
|
||||||
REPOSITORY_PYPI : lookup(var.package_managers, "pypi", ""),
|
REPOSITORY_PYPI : lookup(var.package_managers, "pypi", ""),
|
||||||
|
REPOSITORY_DOCKER : lookup(var.package_managers, "docker", ""),
|
||||||
})
|
})
|
||||||
run_on_start = true
|
run_on_start = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
resource "coder_env" "jfrog_ide_url" {
|
||||||
|
count = var.configure_code_server ? 1 : 0
|
||||||
|
agent_id = var.agent_id
|
||||||
|
name = "JFROG_IDE_URL"
|
||||||
|
value = var.jfrog_url
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "coder_env" "jfrog_ide_access_token" {
|
||||||
|
count = var.configure_code_server ? 1 : 0
|
||||||
|
agent_id = var.agent_id
|
||||||
|
name = "JFROG_IDE_ACCESS_TOKEN"
|
||||||
|
value = artifactory_scoped_token.me.access_token
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "coder_env" "jfrog_ide_store_connection" {
|
||||||
|
count = var.configure_code_server ? 1 : 0
|
||||||
|
agent_id = var.agent_id
|
||||||
|
name = "JFROG_IDE_STORE_CONNECTION"
|
||||||
|
value = true
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "coder_env" "goproxy" {
|
||||||
|
count = lookup(var.package_managers, "go", "") == "" ? 0 : 1
|
||||||
|
agent_id = var.agent_id
|
||||||
|
name = "GOPROXY"
|
||||||
|
value = "https://${local.username}:${artifactory_scoped_token.me.access_token}@${local.jfrog_host}/artifactory/api/go/${lookup(var.package_managers, "go", "")}"
|
||||||
|
}
|
||||||
|
|
||||||
output "access_token" {
|
output "access_token" {
|
||||||
description = "value of the JFrog access token"
|
description = "value of the JFrog access token"
|
||||||
value = artifactory_scoped_token.me.access_token
|
value = artifactory_scoped_token.me.access_token
|
||||||
|
|||||||
@@ -7,7 +7,6 @@ if command -v jf > /dev/null 2>&1; then
|
|||||||
echo "✅ JFrog CLI is already installed, skipping installation."
|
echo "✅ JFrog CLI is already installed, skipping installation."
|
||||||
else
|
else
|
||||||
echo "📦 Installing JFrog CLI..."
|
echo "📦 Installing JFrog CLI..."
|
||||||
# Install the JFrog CLI.
|
|
||||||
curl -fL https://install-cli.jfrog.io | sudo sh
|
curl -fL https://install-cli.jfrog.io | sudo sh
|
||||||
sudo chmod 755 /usr/local/bin/jf
|
sudo chmod 755 /usr/local/bin/jf
|
||||||
fi
|
fi
|
||||||
@@ -15,28 +14,29 @@ fi
|
|||||||
# The jf CLI checks $CI when determining whether to use interactive
|
# The jf CLI checks $CI when determining whether to use interactive
|
||||||
# flows.
|
# flows.
|
||||||
export CI=true
|
export CI=true
|
||||||
# Authenticate with the JFrog CLI.
|
# Authenticate JFrog CLI with Artifactory.
|
||||||
jf c rm 0 || true
|
echo "${ARTIFACTORY_ACCESS_TOKEN}" | jf c add --access-token-stdin --url "${JFROG_URL}" --overwrite 0
|
||||||
echo "${ARTIFACTORY_ACCESS_TOKEN}" | jf c add --access-token-stdin --url "${JFROG_URL}" 0
|
# Set the configured server as the default.
|
||||||
|
jf c use 0
|
||||||
|
|
||||||
|
# Configure npm to use the Artifactory "npm" repository.
|
||||||
if [ -z "${REPOSITORY_NPM}" ]; then
|
if [ -z "${REPOSITORY_NPM}" ]; then
|
||||||
echo "🤔 REPOSITORY_NPM is not set, skipping npm configuration."
|
echo "🤔 no npm repository is set, skipping npm configuration."
|
||||||
|
echo "You can configure an npm repository by providing the a key for 'npm' in the 'package_managers' input."
|
||||||
else
|
else
|
||||||
# check if npm is installed and configure it to use the Artifactory "npm" repository.
|
|
||||||
if command -v npm > /dev/null 2>&1; then
|
|
||||||
echo "📦 Configuring npm..."
|
echo "📦 Configuring npm..."
|
||||||
jf npmc --global --repo-resolve "${REPOSITORY_NPM}"
|
jf npmc --global --repo-resolve "${REPOSITORY_NPM}"
|
||||||
fi
|
|
||||||
cat << EOF > ~/.npmrc
|
cat << EOF > ~/.npmrc
|
||||||
email = ${ARTIFACTORY_EMAIL}
|
email=${ARTIFACTORY_EMAIL}
|
||||||
registry = ${JFROG_URL}/artifactory/api/npm/${REPOSITORY_NPM}
|
registry=${JFROG_URL}/artifactory/api/npm/${REPOSITORY_NPM}
|
||||||
EOF
|
EOF
|
||||||
jf rt curl /api/npm/auth >> ~/.npmrc
|
echo "//${JFROG_HOST}/artifactory/api/npm/${REPOSITORY_NPM}/:_authToken=${ARTIFACTORY_ACCESS_TOKEN}" >> ~/.npmrc
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Configure the `pip` to use the Artifactory "python" repository.
|
# Configure the `pip` to use the Artifactory "python" repository.
|
||||||
if [ -z "${REPOSITORY_PYPI}" ]; then
|
if [ -z "${REPOSITORY_PYPI}" ]; then
|
||||||
echo "🤔 REPOSITORY_PYPI is not set, skipping pip configuration."
|
echo "🤔 no pypi repository is set, skipping pip configuration."
|
||||||
|
echo "You can configure a pypi repository by providing the a key for 'pypi' in the 'package_managers' input."
|
||||||
else
|
else
|
||||||
echo "🐍 Configuring pip..."
|
echo "🐍 Configuring pip..."
|
||||||
jf pipc --global --repo-resolve "${REPOSITORY_PYPI}"
|
jf pipc --global --repo-resolve "${REPOSITORY_PYPI}"
|
||||||
@@ -47,12 +47,76 @@ index-url = https://${ARTIFACTORY_USERNAME}:${ARTIFACTORY_ACCESS_TOKEN}@${JFROG_
|
|||||||
EOF
|
EOF
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Set GOPROXY to use the Artifactory "go" repository.
|
# Configure Artifactory "go" repository.
|
||||||
if [ -z "${REPOSITORY_GO}" ]; then
|
if [ -z "${REPOSITORY_GO}" ]; then
|
||||||
echo "🤔 REPOSITORY_GO is not set, skipping go configuration."
|
echo "🤔 no go repository is set, skipping go configuration."
|
||||||
|
echo "You can configure a go repository by providing the a key for 'go' in the 'package_managers' input."
|
||||||
else
|
else
|
||||||
echo "🐹 Configuring go..."
|
echo "🐹 Configuring go..."
|
||||||
jf go-config --global --repo-resolve "${REPOSITORY_GO}"
|
jf goc --global --repo-resolve "${REPOSITORY_GO}"
|
||||||
export GOPROXY="https://${ARTIFACTORY_USERNAME}:${ARTIFACTORY_ACCESS_TOKEN}@${JFROG_HOST}/artifactory/api/go/${REPOSITORY_GO}"
|
|
||||||
fi
|
fi
|
||||||
echo "🥳 Configuration complete!"
|
echo "🥳 Configuration complete!"
|
||||||
|
|
||||||
|
# Configure the JFrog CLI to use the Artifactory "docker" repository.
|
||||||
|
if [ -z "${REPOSITORY_DOCKER}" ]; then
|
||||||
|
echo "🤔 no docker repository is set, skipping docker configuration."
|
||||||
|
echo "You can configure a docker repository by providing the a key for 'docker' in the 'package_managers' input."
|
||||||
|
else
|
||||||
|
if command -v docker > /dev/null 2>&1; then
|
||||||
|
echo "🔑 Configuring 🐳 docker credentials..."
|
||||||
|
mkdir -p ~/.docker
|
||||||
|
echo -n "${ARTIFACTORY_ACCESS_TOKEN}" | docker login ${JFROG_HOST} --username ${ARTIFACTORY_USERNAME} --password-stdin
|
||||||
|
else
|
||||||
|
echo "🤔 no docker is installed, skipping docker configuration."
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Install the JFrog vscode extension for code-server.
|
||||||
|
if [ "${CONFIGURE_CODE_SERVER}" == "true" ]; then
|
||||||
|
while ! [ -x /tmp/code-server/bin/code-server ]; do
|
||||||
|
counter=0
|
||||||
|
if [ $counter -eq 60 ]; then
|
||||||
|
echo "Timed out waiting for /tmp/code-server/bin/code-server to be installed."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
echo "Waiting for /tmp/code-server/bin/code-server to be installed..."
|
||||||
|
sleep 1
|
||||||
|
((counter++))
|
||||||
|
done
|
||||||
|
echo "📦 Installing JFrog extension..."
|
||||||
|
/tmp/code-server/bin/code-server --install-extension jfrog.jfrog-vscode-extension
|
||||||
|
echo "🥳 JFrog extension installed!"
|
||||||
|
else
|
||||||
|
echo "🤔 Skipping JFrog extension installation. Set configure_code_server to true to install the JFrog extension."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Configure the JFrog CLI completion
|
||||||
|
echo "📦 Configuring JFrog CLI completion..."
|
||||||
|
# Get the user's shell
|
||||||
|
SHELLNAME=$(grep "^$USER" /etc/passwd | awk -F':' '{print $7}' | awk -F'/' '{print $NF}')
|
||||||
|
# Generate the completion script
|
||||||
|
jf completion $SHELLNAME --install
|
||||||
|
# Add the completion script to the user's shell profile
|
||||||
|
if [ "$SHELLNAME" == "bash" ] && [ -f ~/.bashrc ]; then
|
||||||
|
if ! grep -q "# jf CLI shell completion" ~/.bashrc; then
|
||||||
|
echo "" >> ~/.bashrc
|
||||||
|
echo "# BEGIN: jf CLI shell completion (added by coder module jfrog-token)" >> ~/.bashrc
|
||||||
|
echo 'source "$HOME/.jfrog/jfrog_bash_completion"' >> ~/.bashrc
|
||||||
|
echo "# END: jf CLI shell completion" >> ~/.bashrc
|
||||||
|
else
|
||||||
|
echo "🥳 ~/.bashrc already contains jf CLI shell completion configuration, skipping."
|
||||||
|
fi
|
||||||
|
elif [ "$SHELLNAME" == "zsh" ] && [ -f ~/.zshrc ]; then
|
||||||
|
if ! grep -q "# jf CLI shell completion" ~/.zshrc; then
|
||||||
|
echo "" >> ~/.zshrc
|
||||||
|
echo "# BEGIN: jf CLI shell completion (added by coder module jfrog-token)" >> ~/.zshrc
|
||||||
|
echo "autoload -Uz compinit" >> ~/.zshrc
|
||||||
|
echo "compinit" >> ~/.zshrc
|
||||||
|
echo 'source "$HOME/.jfrog/jfrog_zsh_completion"' >> ~/.zshrc
|
||||||
|
echo "# END: jf CLI shell completion" >> ~/.zshrc
|
||||||
|
else
|
||||||
|
echo "🥳 ~/.zshrc already contains jf CLI shell completion configuration, skipping."
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "🤔 ~/.bashrc or ~/.zshrc does not exist, skipping jf CLI shell completion configuration."
|
||||||
|
fi
|
||||||
|
|||||||
Reference in New Issue
Block a user