Report this

What is the reason for this report?

V2 create API POST call with Google Apps scripts

Posted on January 31, 2020

I am trying to make a POST call work from within Google Apps scripts into the V2 create API.

I have it working, but it doesn’t execute the user_data formatted in either cloud-init or just as shell commands. Nothing shows in the logs either. Any help is appreciated!

function createDroplet(){
  var url = "https://api.digitalocean.com/v2/droplets";
  var payload = {
    "name":"NAMEOFHOST",
    "region":"sfo2",
    "size":"s-1vcpu-1gb",
    "image":"ubuntu-18-04-x64",
    "tags":["TAG1", "TAG2"],
    "user_data": "curl -s https://Script.sh | sh"
  };
  var options = { "method": "post", "headers": { "Authorization": "Bearer " + DOToken, "Content-Type": "application/json"},"payload": JSON.stringify(payload) };
  
  var response = UrlFetchApp.fetch(url, options); 
}


This textbox defaults to using Markdown to format your answer.

You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!

These answers are provided by our Community. If you find them useful, show some love by clicking the heart. If you run into issues leave a comment, or add your own answer to help others.

I discovered that you can use the Unicode encoding to put the LF in the json, and all it well now. For those wondering the code is :

\u000A

so “user_data” needed to look like this

"user_data": "#!/bin/bash \u000A \
    /usr/bin/curl -s https://SCRIPT | sh

The developer cloud

Scale up as you grow — whether you're running one virtual machine or ten thousand.

Start building today

From GPU-powered inference and Kubernetes to managed databases and storage, get everything you need to build, scale, and deploy intelligent applications.

Dark mode is coming soon.