Search Storyblok's Documentation
  1. Create an Extension

Create an Extension

This endpoint allows you to create an extension inside the organization or partner extensions.

https://mapi.storyblok.com/v1/org_apps
/partner_apps

Request Body Properties

  • app

    The Extension Object
    • name

      required string

      Name of the Extension

    • slug

      required string

      The slug specific to this Extension

    • icon

      string

      Icon image path of the Extension from the Extension Details

    • preview_video

      string

      Define the video URL in the extension configured on the Extension Details in the settings

    • description

      string

      A description of your extension

    • intro

      string

      A short description of your extension

    • screenshot

      string

      A screenshot image path of your extension

    • website

      string

      Website URL of your extension

    • author

      string

      Author of the extension

    • field_type_ids

      number[]

      An array of field type ids

    • embedded_app_url

      string

      An embedded Space app or Tool Plugin URL

    • dev_embedded_app_url

      string

      A developer mode of embedded Space Plugin or Tool Plugin URL

    • dev_oauth_redirect_uri

      string

      A developer mode of OAuth Space Plugin or Tool Plugin URI

    • in_sidebar

      boolean

      A status in the sidebar if your plugin is a space app

    • in_toolbar

      boolean

      A status in the toolbar if your plugin is tool plugin

    • sidebar_icon

      string

      Your space app sidebar icon image path

    • oauth_redirect_uri

      string

      OAuth Space Plugin or Tool Plugin URI

    • enable_space_settings

      boolean

      A status to show whether your extension is enabled for space level settings or not

Response Properties

  • app

    The Extension Object
    • id

      number

      Numeric ID of the Extension

    • name

      string

      Name of the Extension

    • slug

      string

      The slug specific to this Extension

    • icon

      string

      Icon image path of the Extension from the Extension Details

    • plan_level

      number

      Plan Level of Space

    • preview_video

      string

      Define the video URL in the extension configured on the Extension Details in the settings

    • app_url

      string

      Extension URL

    • description

      string

      A description of your extension

    • intro

      string

      A short description of your extension

    • screenshot

      string

      A screenshot image path of your extension

    • status

      string

      Status of the extension

    • website

      string

      Website URL of your extension

    • author

      string

      Author of the extension

    • updated_at

      string

      Latest update date (Format: yyyy-MM-dd'T'HH:mm:ssZ)

    • field_type_ids

      number[]

      An array of field type ids

    • embedded_app_url

      string

      An embedded Space app or Tool Plugin URL

    • dev_embedded_app_url

      string

      A developer mode of embedded Space Plugin or Tool Plugin URL

    • dev_oauth_redirect_uri

      string

      A developer mode of OAuth Space Plugin or Tool Plugin URI

    • in_sidebar

      boolean

      A status in the sidebar if your plugin is a space app

    • in_toolbar

      boolean

      A status in the toolbar if your plugin is tool plugin

    • sidebar_icon

      string

      Your space app sidebar icon image path

    • oauth_redirect_uri

      string

      OAuth Space Plugin or Tool Plugin URI

    • enable_space_settings

      boolean

      A status to show whether your extension is enabled for space level settings or not

Request
curl "https://mapi.storyblok.com/v1/org_apps" \
  -X POST \
  -H "Content-Type: application/json" \
  -H "Authorization: YOUR_OAUTH_TOKEN" \
  -d "{\"app\": {\"name\": \"My extension\",\"slug\": \"storyblok-gmbh@extension-1\"}}"
Request
// Using the Universal JavaScript Client:
// https://github.com/storyblok/storyblok-js-client
Storyblok.post('/org_apps', {
    "app": {
        "name": "My extension",
        "slug": "storyblok-gmbh@extension-1"
    }
})
  .then(response => {
    console.log(response)
  }).catch(error => { 
    console.log(error)
  })
Request
$client = new \Storyblok\ManagementClient('YOUR_OAUTH_TOKEN');

$payload = [
    "app" =>  [
        "name" =>  "My extension",
        "slug" =>  "storyblok-gmbh@extension-1"
    ]
];

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

payload = {
    "app" =>  {
        "name" =>  "My extension",
        "slug" =>  "storyblok-gmbh@extension-1"
    }
}

client.post('/org_apps', payload)
Request
HttpResponse<String> response = Unirest.post("https://mapi.storyblok.com/v1/org_apps")
  .header("Content-Type", "application/json")
  .header("Authorization", "YOUR_OAUTH_TOKEN")
  .body("{\"app\": {\"name\": \"My extension\",\"slug\": \"storyblok-gmbh@extension-1\"}}")
  .asString();
Request
var client = new RestClient("https://mapi.storyblok.com/v1/org_apps");
var request = new RestRequest(Method.POST);

request.AddHeader("Content-Type", "application/json");
request.AddHeader("Authorization", "YOUR_OAUTH_TOKEN");
request.AddParameter("application/json", "{\"app\": {\"name\": \"My extension\",\"slug\": \"storyblok-gmbh@extension-1\"}}", ParameterType.RequestBody);
IRestResponse response = client.Execute(request);
Request
import Foundation

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

let postData = NSData(data: "{\"app\": {\"name\": \"My extension\",\"slug\": \"storyblok-gmbh@extension-1\"}}".data(using: String.Encoding.utf8)!)
let request = NSMutableURLRequest(url: NSURL(string: "https://mapi.storyblok.com/v1/org_apps")! 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/org_apps"

querystring = {}

payload = "{\"app\": {\"name\": \"My extension\",\"slug\": \"storyblok-gmbh@extension-1\"}}"
headers = {
  'Content-Type': "application/json",
  'Authorization': "YOUR_OAUTH_TOKEN"
}

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

print(response.text)