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 ObjectThe extension object
-
name
required stringName of the Extension
-
slug
required stringThe slug specific to this Extension
-
icon
stringIcon image path of the Extension from the Extension Details
-
preview_video
stringDefine the video URL in the extension configured on the Extension Details in the settings
-
description
stringA description of your extension
-
intro
stringA short description of your extension
-
screenshot
stringA screenshot image path of your extension
-
website
stringWebsite URL of your extension
-
author
stringAuthor of the extension
-
field_type_ids
number[]An array of field type ids
-
embedded_app_url
stringAn embedded Space app or Tool Plugin URL
-
dev_embedded_app_url
stringA developer mode of embedded Space Plugin or Tool Plugin URL
-
dev_oauth_redirect_uri
stringA developer mode of OAuth Space Plugin or Tool Plugin URI
-
in_sidebar
booleanA status in the sidebar if your plugin is a space app
-
in_toolbar
booleanA status in the toolbar if your plugin is tool plugin
-
sidebar_icon
stringYour space app sidebar icon image path
-
oauth_redirect_uri
stringOAuth Space Plugin or Tool Plugin URI
-
enable_space_settings
booleanA status to show whether your extension is enabled for space level settings or not
-
Response Properties
-
app
The Extension ObjectThe extension object
-
id
numberNumeric ID of the Extension
-
name
stringName of the Extension
-
slug
stringThe slug specific to this Extension
-
icon
stringIcon image path of the Extension from the Extension Details
-
plan_level
numberPlan Level of Space
-
preview_video
stringDefine the video URL in the extension configured on the Extension Details in the settings
-
app_url
stringExtension URL
-
description
stringA description of your extension
-
intro
stringA short description of your extension
-
screenshot
stringA screenshot image path of your extension
-
status
stringStatus of the extension
-
website
stringWebsite URL of your extension
-
author
stringAuthor of the extension
-
updated_at
stringLatest update date (Format:
yyyy-MM-dd'T'HH:mm:ssZ
) -
field_type_ids
number[]An array of field type ids
-
embedded_app_url
stringAn embedded Space app or Tool Plugin URL
-
dev_embedded_app_url
stringA developer mode of embedded Space Plugin or Tool Plugin URL
-
dev_oauth_redirect_uri
stringA developer mode of OAuth Space Plugin or Tool Plugin URI
-
in_sidebar
booleanA status in the sidebar if your plugin is a space app
-
in_toolbar
booleanA status in the toolbar if your plugin is tool plugin
-
sidebar_icon
stringYour space app sidebar icon image path
-
oauth_redirect_uri
stringOAuth Space Plugin or Tool Plugin URI
-
enable_space_settings
booleanA status to show whether your extension is enabled for space level settings or not
-
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\"}}"
// 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)
})
$client = new \Storyblok\ManagementClient('YOUR_OAUTH_TOKEN');
$payload = [
"app" => [
"name" => "My extension",
"slug" => "storyblok-gmbh@extension-1"
]
];
$client->post('/org_apps', $payload)->getBody();
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)
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();
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);
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()
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)