4 # shellcheck disable=SC1091
6 # shellcheck disable=SC1091
11 DEPLOYDIR="$(dirname "$PWD")"
12 BMODIR=$DEPLOYDIR/metal3/scripts/bmo
14 # Environment variables
15 # M3PATH : Path to clone the metal3 dev env repo
16 # BMOPATH : Path to clone the baremetal operator repo
18 # BMOREPO : Baremetal operator repository URL
19 # BMOBRANCH : Baremetal operator repository branch to checkout
20 # FORCE_REPO_UPDATE : discard existing directories
22 # BMO_RUN_LOCAL : run the baremetal operator locally (not in Kubernetes cluster)
24 M3PATH="${GOPATH}/src/github.com/metal3-io"
25 BMOPATH="${M3PATH}/baremetal-operator"
27 BMOREPO="${BMOREPO:-https://github.com/metal3-io/baremetal-operator.git}"
28 BMOBRANCH="${BMOBRANCH:-10eb5aa3e614d0fdc6315026ebab061cbae6b929}"
29 FORCE_REPO_UPDATE="${FORCE_REPO_UPDATE:-true}"
31 BMO_RUN_LOCAL="${BMO_RUN_LOCAL:-false}"
32 COMPUTE_NODE_PASSWORD="${COMPUTE_NODE_PASSWORD:-mypasswd}"
33 BM_IMAGE=${BM_IMAGE:-"bionic-server-cloudimg-amd64.img"}
34 IMAGE_URL=http://172.22.0.1/images/${BM_IMAGE}
35 IMAGE_CHECKSUM=http://172.22.0.1/images/${BM_IMAGE}.md5sum
37 function clone_repos {
39 if [[ -d ${BMOPATH} && "${FORCE_REPO_UPDATE}" == "true" ]]; then
42 if [ ! -d "${BMOPATH}" ] ; then
44 git clone "${BMOREPO}"
48 git checkout "${BMOBRANCH}"
53 function launch_baremetal_operator {
54 docker pull $IRONIC_BAREMETAL_IMAGE
55 kubectl apply -f $BMODIR/namespace/namespace.yaml
56 kubectl apply -f $BMODIR/rbac/service_account.yaml -n metal3
57 kubectl apply -f $BMODIR/rbac/role.yaml -n metal3
58 kubectl apply -f $BMODIR/rbac/role_binding.yaml
59 kubectl apply -f $BMODIR/crds/metal3.io_baremetalhosts_crd.yaml
60 kubectl apply -f $BMODIR/operator/no_ironic/operator.yaml -n metal3
63 # documentation for the values below may be found at
64 # https://cloudinit.readthedocs.io/en/latest/topics/modules.html
65 function create_userdata {
67 COMPUTE_NODE_FQDN="$name.akraino.icn.org"
68 printf "#cloud-config\n" > $name-userdata.yaml
69 if [ -n "$COMPUTE_NODE_PASSWORD" ]; then
70 printf "password: ""%s" "$COMPUTE_NODE_PASSWORD" >> $name-userdata.yaml
71 printf "\nchpasswd: {expire: False}\n" >> $name-userdata.yaml
72 printf "ssh_pwauth: True\n" >> $name-userdata.yaml
75 if [ -n "$COMPUTE_NODE_FQDN" ]; then
76 printf "fqdn: ""%s" "$COMPUTE_NODE_FQDN" >> $name-userdata.yaml
77 printf "\n" >> $name-userdata.yaml
79 printf "disable_root: false\n" >> $name-userdata.yaml
80 printf "ssh_authorized_keys:\n - " >> $name-userdata.yaml
82 if [ ! -f $HOME/.ssh/id_rsa.pub ]; then
83 yes y | ssh-keygen -t rsa -N "" -f $HOME/.ssh/id_rsa
86 cat $HOME/.ssh/id_rsa.pub >> $name-userdata.yaml
87 cloud_init_scripts >> $name-userdata.yaml
88 printf "\n" >> $name-userdata.yaml
91 function cloud_init_scripts {
92 # set_dhcp_indentifier.sh:
93 # The IP address assigned to the provisioning NIC will change
94 # due to IPA using the MAC address as the client ID and systemd
95 # using a different ID. Tell systemd to use the MAC as the
96 # client ID. We can't do this in the network data as only the
97 # JSON format is supported by metal3, and the JSON format does
98 # not support the dhcp-identifier field.
101 - path: /var/lib/cloud/scripts/per-instance/set_dhcp_identifier.sh
107 sed -i -e '/dhcp4: true$/!b' -e 'h;s/\S.*/dhcp-identifier: mac/;H;g' /etc/netplan/50-cloud-init.yaml
112 function apply_userdata_credential {
114 cat <<EOF > ./$name-user-data-credential.yaml
117 userData: $(base64 -w 0 $name-userdata.yaml)
120 name: $name-user-data
124 kubectl apply -n metal3 -f $name-user-data-credential.yaml
127 function create_networkdata {
129 node_networkdata $name > $name-networkdata.json
132 function apply_networkdata_credential {
134 cat <<EOF > ./$name-network-data-credential.yaml
137 networkData: $(base64 -w 0 $name-networkdata.json)
140 name: $name-network-data
144 kubectl apply -n metal3 -f $name-network-data-credential.yaml
147 function make_bm_hosts {
148 while IFS=',' read -r name address user password mac; do
149 create_userdata $name
150 apply_userdata_credential $name
151 create_networkdata $name
152 apply_networkdata_credential $name
153 GO111MODULE=auto go run "${BMOPATH}"/cmd/make-bm-worker/main.go \
154 -address "$address" \
155 -password "$password" \
158 "$name" > $name-bm-node.yaml
159 printf " image:" >> $name-bm-node.yaml
160 printf "\n url: ""%s" "${IMAGE_URL}" >> $name-bm-node.yaml
161 printf "\n checksum: ""%s" "${IMAGE_CHECKSUM}" >> $name-bm-node.yaml
162 printf "\n userData:" >> $name-bm-node.yaml
163 printf "\n name: ""%s" "$name""-user-data" >> $name-bm-node.yaml
164 printf "\n namespace: metal3" >> $name-bm-node.yaml
165 printf "\n networkData:" >> $name-bm-node.yaml
166 printf "\n name: ""%s" "$name""-network-data" >> $name-bm-node.yaml
167 printf "\n namespace: metal3" >> $name-bm-node.yaml
168 printf "\n rootDeviceHints:" >> $name-bm-node.yaml
169 printf "\n minSizeGigabytes: 48\n" >> $name-bm-node.yaml
170 kubectl apply -f $name-bm-node.yaml -n metal3
174 function apply_bm_hosts {
175 list_nodes | make_bm_hosts
179 launch_baremetal_operator