in lib/ec2macosinit/userdata.go [23:61]
func (m *UserDataModule) Do(mctx *ModuleContext) (message string, err error) {
const scriptFileName = "userdata"
userdataScript := filepath.Join(mctx.InstanceHistoryPath(), scriptFileName)
// Get user data from IMDS
ud, respCode, err := mctx.IMDS.getIMDSProperty("user-data")
if err != nil {
return "", fmt.Errorf("ec2macosinit: error getting user data from IMDS: %s\n", err)
}
if respCode == 404 { // 404 = no user data provided, exit nicely
return "no user data provided through IMDS", nil
}
if respCode != 200 { // 200 = ok
return "", fmt.Errorf("ec2macosinit: received an unexpected response code from IMDS: %d - %s\n", respCode, err)
}
err = writeShellScript(userdataScript, userdataReader(ud))
if err != nil {
return "", fmt.Errorf("userdata script: %w", err)
}
// If we don't want to execute the user data, exit nicely - we're done
if !m.ExecuteUserData {
return "successfully handled user data with no execution request", nil
}
// Execute user data script
out, err := executeCommand([]string{userdataScript}, "", []string{})
if err != nil {
if strings.Contains(err.Error(), "exec format error") {
contentType := http.DetectContentType([]byte(ud))
return fmt.Sprintf("provided user data is not executable (detected type: %s)", contentType), nil
} else {
return fmt.Sprintf("error while running user data with stdout: [%s] and stderr: [%s]", out.stdout, out.stderr), err
}
}
return fmt.Sprintf("successfully ran user data with stdout: [%s] and stderr: [%s]", out.stdout, out.stderr), nil
}