OCI image to make claude code portable; the model is being setup to use through Google Vertex AI API.
The image also contains a list of curated mcp servers setup and a base memory for claude ensuring it uses them as expected.
To manage slack integration claudio will use https://github.com/korotovsky/slack-mcp-server,
To get values for them the easiest way is to authenticate to your slack workspace in chrome/chromium browser
On same page go to More Tools -> Developer Tools
On Developer Tools go to:
- XOXC: Application -> Storage -> Local Storage -> https>//app.slack.com -> localConfig_v2 (key) -> 'token' key inside the json value
- XOXD: Application -> Storage -> Cookies -> https>//app.slack.com -> d (key)
Since it is slack enterpise we need to get value for User-Agent. To get it from same place we check Networking and check request headers to get the value,
it should be something similar to Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/139.0.0.0 Safari/537.36
Disclaimer, the first time you reuse those Tokens you will probably be signed off as precaution, the second time you sign in the tokens should last.
To manage gitlab CICD integration claudio will use https://gitlab.com/fforster/gitlab-mcp
For Auth check https://gitlab.com/fforster/gitlab-mcp#authentication
To manage Openshift / K8s integration claudio will use https://github.com/containers/kubernetes-mcp-server
We will need to add the kubeconfig as part of the execution and set its path with K8S_MCP_KUBECONFIG_PATH
To build the container run the command:
make oci-buildThis builds for the native architecture of the current platform.
You can customize the image name and tag:
IMAGE_REPO=ghcr.io/myorg/claudio IMAGE_TAG=latest make oci-buildBy default, the Makefile uses Podman. To use Docker instead:
CONTAINER_MANAGER=docker make oci-buildAvailable targets:
oci-build- Build container image for native architectureoci-push- Push container imageoci-tag- Tag existing image with new tagoci-manifest-build- Create multi-arch manifest from arch-tagged imagesoci-manifest-push- Push manifest to registry
In order to make claudio OpenShift compliant the default user for the container is default, it is also part of the root group, under some circumstances when mapping host volumes podman is not able to access the volume (even with the right permissions), to avoid that siatuion we suggest when running locally to use --user 0 to enforce default behavior by podman.
# Create a volume to hold the auth for gcloud
podman volume create claudio-gcp
# Create a volume to hold cache for mcp slack
podman volume create claudio-mcp-slack
# Run claudio
podman run -it --rm --user 0 \
-v ${PWD}/kubecofing:/opt/k8s/kubeconfig:z \
# Optional
-v claudio-gcp:/root/.config/gcloud:Z \
# Optional
-v claudio-mcp-slack:/root/claude/mcp/slack:Z \
-e GITLAB_URL='https://gitlab.com' \
-e GITLAB_TOKEN='...' \
-e ANTHROPIC_VERTEX_PROJECT_ID=... \
-e ANTHROPIC_VERTEX_PROJECT_QUOTA=... \
-e SLACK_MCP_XOXC_TOKEN='xoxc-...' \
-e SLACK_MCP_XOXD_TOKEN='xoxd-...' \
-e K8S_MCP_KUBECONFIG_PATH=/opt/k8s/kubeconfig \
quay.io/redhat-aipcc/claudio:v1.0.0-devClaudio on a host where user is already logged in on gcloud:
# Run claudio
podman run -it --rm -user 0 \
-v ${PWD}/kubecofing:/opt/k8s/kubeconfig:z \
-v /home/$USER/.conf/gcloud:/root/.config/gcloud:z \
-e GITLAB_URL='https://gitlab.com' \
-e GITLAB_TOKEN='...' \
-e ANTHROPIC_VERTEX_PROJECT_ID=... \
-e ANTHROPIC_VERTEX_PROJECT_QUOTA=... \
-e SLACK_MCP_XOXC_TOKEN='xoxc-...' \
-e SLACK_MCP_XOXD_TOKEN='xoxd-...' \
-e K8S_MCP_KUBECONFIG_PATH=/opt/k8s/kubeconfig \
quay.io/redhat-aipcc/claudio:v1.0.0-devClaudio one-time prompt
# Run claudio
podman run -it --rm -user 0 \
-v ${PWD}/kubecofing:/opt/k8s/kubeconfig:z \
-v /home/$USER/.conf/gcloud:/root/.config/gcloud:z \
-e GITLAB_URL='https://gitlab.com' \
-e GITLAB_TOKEN='...' \
-e ANTHROPIC_VERTEX_PROJECT_ID=... \
-e ANTHROPIC_VERTEX_PROJECT_QUOTA=... \
-e SLACK_MCP_XOXC_TOKEN='xoxc-...' \
-e SLACK_MCP_XOXD_TOKEN='xoxd-...' \
-e K8S_MCP_KUBECONFIG_PATH=/opt/k8s/kubeconfig \
quay.io/redhat-aipcc/claudio:v1.0.0-dev \
-p "do something for me Claudio"