1. Create Release Approval

Create Release Approval

The Approval feature mentioned is exclusive to Storyblok v1 and discontinued in v2.

/spaces/:space_id/approvals/

Path Parameters

  • :space_id

    required number

    Numeric id of a space

Request Body Properties

  • approval

    The Approval Object
    • story_id

      required number

      ID of content entry that should be approved

    • approver_id

      required number

      ID of the User that should be the approver

  • release_id

    number

    ID of the release that should be approved

Response Properties

  • approval

    The Approval Object
    • id

      number

      The numeric ID

    • status

      string

      Status of approval

    • story_id

      number

      ID of content entry that should be approved

    • approver_id

      number

      ID of the User that should be the approver

Example Request Object

{
  "approval": {
    "story_id": 1067,
    "approver_id": 1030
  },
  "release_id": 16
}

Example Request

Request
curl "https://mapi.storyblok.com/v1/spaces/606/approvals/" \
  -X POST \
  -H "Content-Type: application/json" \
  -H "Authorization: YOUR_OAUTH_TOKEN" \
  -d "{\"approval\": {\"story_id\": 1067,\"approver_id\": 1030},\"release_id\": 16}"
Request
// Using the Universal JavaScript Client:
// https://github.com/storyblok/storyblok-js-client
Storyblok.post('/spaces/606/approvals/', {
  "approval": {
    "story_id": 1067,
    "approver_id": 1030
  },
  "release_id": 16
})
  .then(response => {
    console.log(response)
  }).catch(error => { 
    console.log(error)
  })
Request
$client = new \Storyblok\Client('YOUR_STORYBLOK_SPACE_ACCESS_TOKEN');

$payload = [
  "approval" =>  [
    "story_id" =>  1067,
    "approver_id" =>  1030
  ],
  "release_id" =>  16
];

$client->post('/spaces/606/approvals/', $payload)->getBody();
Request
require 'storyblok'
client = Storyblok::Client.new(oauth_token: 'YOUR_OAUTH_TOKEN')

payload = {
  "approval" =>  {
    "story_id" =>  1067,
    "approver_id" =>  1030
  },
  "release_id" =>  16
}

client.post('/spaces/606/approvals/', payload)
Request
HttpResponse<String> response = Unirest.post("https://mapi.storyblok.com/v1/spaces/606/approvals/")
  .header("Content-Type", "application/json")
  .header("Authorization", "YOUR_OAUTH_TOKEN")
  .body("{\"approval\": {\"story_id\": 1067,\"approver_id\": 1030},\"release_id\": 16}")
  .asString();
Request
var client = new RestClient("https://mapi.storyblok.com/v1/spaces/606/approvals/");
var request = new RestRequest(Method.POST);

request.AddHeader("Content-Type", "application/json");
request.AddHeader("Authorization", "YOUR_OAUTH_TOKEN");
request.AddParameter("application/json", "{\"approval\": {\"story_id\": 1067,\"approver_id\": 1030},\"release_id\": 16}", ParameterType.RequestBody);
IRestResponse response = client.Execute(request);
Request
import Foundation

let headers = [
  "Content-Type": "application/json",
  "Authorization": "YOUR_OAUTH_TOKEN"
]

let postData = NSData(data: "{\"approval\": {\"story_id\": 1067,\"approver_id\": 1030},\"release_id\": 16}".data(using: String.Encoding.utf8)!)
let request = NSMutableURLRequest(url: NSURL(string: "https://mapi.storyblok.com/v1/spaces/606/approvals/")! as URL, cachePolicy: .useProtocolCachePolicy, timeoutInterval: 10.0)

request.method = "POST"
request.allHTTPHeaderFields = headers
request.httpBody = postData as Data

let session = URLSession.shared
let dataTask = session.dataTask(with: request as URLRequest, completionHandler: { (data, response, error) -> Void in
  if (error != nil) {
    print(error)
  } else {
    let httpResponse = response as? HTTPURLResponse
    print(httpResponse)
  }
})

dataTask.resume()
Request
import requests

url = "https://mapi.storyblok.com/v1/spaces/606/approvals/"

querystring = {}

payload = "{\"approval\": {\"story_id\": 1067,\"approver_id\": 1030},\"release_id\": 16}"
headers = {
  'Content-Type': "application/json",
  'Authorization': "YOUR_OAUTH_TOKEN"
}

response = requests.request("POST", url, data=payload, headers=headers, params=querystring)

print(response.text)

Example Response Object

{
  "approval": {
    "id": 12,
    "status": "pending"
  }
}