shoelaces(8) # NAME shoelaces - automated server bootstrapping # SYNOPSIS *shoelaces* [options...] # OPTIONS *-base-url* Optional parameter. Specifies the base address that will be used when generating URLs. If it's not specified, the value of "-bind-addr" will be used. *-bind-addr* The address where Shoelaces will listen for requests. Defaults to "localhost:8081". *-config* Specifies a config file. All the following options can be specified in the config. *-data-dir* Specifies a directory with mappings, configs, templates, etc. *-debug* Enables debug mode. *-env-dir* Specifies a directory with environment overrides. Refer to the README of the project for more information about environment overrides. *-mappings-file* Specifies a mappings YAML file. Defaults to "mappings.yaml". Refer to the README of the project for more information about mappings. *-static-dir* Specifies a custom web directory with static files. Defaults to "web". *-template-extension* Shoelaces template extension. Defaults to ".slc". # DESCRIPTION Shoelaces serves over HTTP iPXE boot scripts, cloud-init configuration, and any other configuration files to baremetal or virtual machines booting using iPXE. It also does a few other things to make easier managing server deployments: - Has a simple but nice UI to show the current configuration, and history of servers that booted. - Uses Go templates to handle complex configurations. - Allows specifying the boot entry point for a given server based on its IP address or DNS PTR record. - Supports the notion of environments for Development and Production environment configurations, while trying to minimize template duplication. - Puts unknown servers into iPXE script boot retry loop, while at the same time showing them in the UI allowing the user to select a specific boot configuration. Shoelaces is better when used along a DHCP server. Refer to the *CONFIGURATION* section for examples on how to configure a DHCP server for hooking it with Shoelaces. # CONFIGURATION Shoelaces searches for a config file whenever the *-config* flag is specified. Here is example config file: ``` bind-addr=localhost:8081 data-dir=/etc/shoelaces/data-dir/ template-extension=.slc mappings-file=mappings.yaml debug=true ``` *dhcpd*(8) can be hooked with Shoelaces by adding the following snippet in *dhcpd.conf*(5): ``` # dhcp.conf next-server ; if exists user-class and option user-class = "iPXE" { filename "http:///poll/1/${netX/mac:hexhyp}"; } else { filename "undionly.kpxe"; } ``` Similarly, *dnsmasq*(8) can be configured for working with Shoelaces with the following snippet: ``` dhcp-match=set:ipxe,175 # iPXE sends a 175 option. dhcp-boot=tag:!ipxe,undionly.kpxe dhcp-boot=http:///poll/1/${netX/mac:hexhyp} ``` A TFTP server such as *tftpd*(8) must be configured to serve the IPXE ROM, *undionly.kpxe*. # SEE ALSO *dhcpd*(8) *dhcpd.conf*(5) *dnsmasq*(8) *tftpd*(8) # AUTHORS Maintained by ThousandEyes Inc. . Up-to-date sources can be found at https://github.com/thousandeyes/shoelaces. Bugs reports and patches can be submitted via GitHub's interface or contacting the maintainers directly via email.