#!/bin/bash # Prompt the user to start the installation process echo "This script will install Knative Serving, Knative Eventing, and install the sample app bookstore on your cluster" read -p "Press ENTER to continue or Ctrl+C to abort..." # Install Knative Serving echo "Installing Knative Serving..." kubectl apply -f https://github.com/knative/serving/releases/download/knative-v1.14.0/serving-crds.yaml kubectl apply -f https://github.com/knative/serving/releases/download/knative-v1.14.0/serving-core.yaml kubectl apply -f https://github.com/knative/net-kourier/releases/download/knative-v1.14.0/kourier.yaml # Configure Kourier as the default ingress kubectl patch configmap/config-network --namespace knative-serving --type merge --patch '{"data":{"ingress-class":"kourier.ingress.networking.knative.dev"}}' echo "Knative Serving installed successfully." # Install Knative Eventing echo "Installing Knative Eventing..." kubectl apply -f https://github.com/knative/eventing/releases/download/knative-v1.14.0/eventing-crds.yaml kubectl apply -f https://github.com/knative/eventing/releases/download/knative-v1.14.0/eventing-core.yaml echo "Knative Eventing installed successfully." # Install Knative imc Broker kubectl apply -f https://github.com/knative/eventing/releases/download/knative-v1.14.0/in-memory-channel.yaml kubectl apply -f https://github.com/knative/eventing/releases/download/knative-v1.14.0/mt-channel-broker.yaml echo "Knative in-memory Channel and Broker installed successfully." # Detect whether the user has knative function "func" installed if ! command -v func &> /dev/null then echo "Knative CLI 'func' not found. Please install the Knative CLI by following the instructions at https://knative.dev/docs/admin/install/kn-cli/." exit fi # Detect whether the user has kamel CLI installed if ! command -v kamel &> /dev/null then echo "Kamel CLI not found. Please install the Kamel CLI by following the instructions at https://camel.apache.org/camel-k/latest/installation/installation.html." exit fi # Prompt for the Docker registry details echo "Please provide the details of your Container registry to install the Camel-K." read -p "Enter the registry hostname (e.g., docker.io or quay.io): " REGISTRY_HOST read -p "Enter the registry username: " REGISTRY_USER read -s -p "Enter the registry password: " REGISTRY_PASSWORD echo "All the required details have been captured and saved locally." # Set the registry details as environment variables export REGISTRY_HOST=$REGISTRY_HOST export REGISTRY_USER=$REGISTRY_USER export REGISTRY_PASSWORD=$REGISTRY_PASSWORD # Set the KO_DOCKER_REPO environment variable export KO_DOCKER_REPO=$REGISTRY_HOST/$REGISTRY_USER # Install the camel-K kamel install --registry $REGISTRY_HOST--organization $REGISTRY_USER --registry-auth-username $REGISTRY_USER --registry-auth-password $REGISTRY_PASSWORD # Install the Sample Bookstore App echo "Installing the Sample Bookstore App..., but please follow the instruction below to tell us your registry details" read -p "Press ENTER to continue..." # Install the front end first cd frontend kubectl apply -f config # Install the node-server cd ../node-server kubectl apply -f config # Deploy the ML services cd ../ML-bad-word-filter func deploy -b=s2i -v cd ../ML-sentiment-analysis func deploy -b=s2i -v # Install the db cd .. kubectl apply -f db-service # Install the sequence kubectl apply -f sequence/config # Ask the user to edit the properties file echo "Please edit slack-sink/application.properties to provide the webhook URL for Slack." read -p "Press ENTER to continue..." # Create the secret kubectl create secret generic slack-credentials --from-file=slack-sink/application.properties # Install the slack-sink kubectl apply -f slack-sink/config # Ask user to open a new terminal to set the minikube tunnel echo "If you are using minikube: Please open a new terminal and run 'sudo minikube tunnel' to expose the services to the outside world." read -p "Press ENTER to continue..." # FIXME: @pierDipi something wrong here. If run minikube tunnel before bookstore is installed, the localhost:80 will not be accessible # End of script