PingOne Platform APIs

Create External OAuth Server

 

POST {{apiPath}}/environments/{{envID}}/externalOAuthServers

The following sample shows the POST {{apiPath}}/environments/{{envID}}/externalOAuthServers operation to create a new external OAuth server resource associated with the environment specified in the request URL.

When successful, a 201 CREATED message and the new external OAuth server resource is returned.

Prerequisites

Request Model

For property descriptions, refer to External OAuth server data model

Property Type Required?

description

String

Optional

issuers

Array

Optional

name

String

Required

type

String

Required

validation

Object

Required

validation.clockSkewTolerance

Number

Optional

validation.jwks

String

Optional

validation.jwksUrl

String

Optional

validation.type

String

Required

Headers

Authorization      Bearer {{accessToken}}

Content-Type      application/json

Body

raw ( application/json )

{
  "name": "Example_2",
  "description": "OAuth server resource example",
  "type": "EXTERNAL",
  "issuers": [
    "https://example.com/as"
  ],
  "validation": {
    "type": "JWKS_URL",
    "jwksUrl": "https://example.com/as/jwks",
    "clockSkewTolerance": 5
  }
}

Example Request

  • cURL

  • C#

  • Go

  • HTTP

  • Java

  • jQuery

  • NodeJS

  • Python

  • PHP

  • Ruby

  • Swift

curl --location --globoff '{{apiPath}}/environments/{{envID}}/externalOAuthServers' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer {{accessToken}}' \
--data '{
  "name": "Example_2",
  "description": "OAuth server resource example",
  "type": "EXTERNAL",
  "issuers": [
    "https://example.com/as"
  ],
  "validation": {
    "type": "JWKS_URL",
    "jwksUrl": "https://example.com/as/jwks",
    "clockSkewTolerance": 5
  }
}'
var options = new RestClientOptions("{{apiPath}}/environments/{{envID}}/externalOAuthServers")
{
  MaxTimeout = -1,
};
var client = new RestClient(options);
var request = new RestRequest("", Method.Post);
request.AddHeader("Content-Type", "application/json");
request.AddHeader("Authorization", "Bearer {{accessToken}}");
var body = @"{" + "\n" +
@"  ""name"": ""Example_2""," + "\n" +
@"  ""description"": ""OAuth server resource example""," + "\n" +
@"  ""type"": ""EXTERNAL""," + "\n" +
@"  ""issuers"": [" + "\n" +
@"    ""https://example.com/as""" + "\n" +
@"  ]," + "\n" +
@"  ""validation"": {" + "\n" +
@"    ""type"": ""JWKS_URL""," + "\n" +
@"    ""jwksUrl"": ""https://example.com/as/jwks""," + "\n" +
@"    ""clockSkewTolerance"": 5" + "\n" +
@"  }" + "\n" +
@"}";
request.AddStringBody(body, DataFormat.Json);
RestResponse response = await client.ExecuteAsync(request);
Console.WriteLine(response.Content);
package main

import (
  "fmt"
  "strings"
  "net/http"
  "io"
)

func main() {

  url := "{{apiPath}}/environments/{{envID}}/externalOAuthServers"
  method := "POST"

  payload := strings.NewReader(`{
  "name": "Example_2",
  "description": "OAuth server resource example",
  "type": "EXTERNAL",
  "issuers": [
    "https://example.com/as"
  ],
  "validation": {
    "type": "JWKS_URL",
    "jwksUrl": "https://example.com/as/jwks",
    "clockSkewTolerance": 5
  }
}`)

  client := &http.Client {
  }
  req, err := http.NewRequest(method, url, payload)

  if err != nil {
    fmt.Println(err)
    return
  }
  req.Header.Add("Content-Type", "application/json")
  req.Header.Add("Authorization", "Bearer {{accessToken}}")

  res, err := client.Do(req)
  if err != nil {
    fmt.Println(err)
    return
  }
  defer res.Body.Close()

  body, err := io.ReadAll(res.Body)
  if err != nil {
    fmt.Println(err)
    return
  }
  fmt.Println(string(body))
}
POST /environments/{{envID}}/externalOAuthServers HTTP/1.1
Host: {{apiPath}}
Content-Type: application/json
Authorization: Bearer {{accessToken}}

{
  "name": "Example_2",
  "description": "OAuth server resource example",
  "type": "EXTERNAL",
  "issuers": [
    "https://example.com/as"
  ],
  "validation": {
    "type": "JWKS_URL",
    "jwksUrl": "https://example.com/as/jwks",
    "clockSkewTolerance": 5
  }
}
OkHttpClient client = new OkHttpClient().newBuilder()
  .build();
MediaType mediaType = MediaType.parse("application/json");
RequestBody body = RequestBody.create(mediaType, "{\n  \"name\": \"Example_2\",\n  \"description\": \"OAuth server resource example\",\n  \"type\": \"EXTERNAL\",\n  \"issuers\": [\n    \"https://example.com/as\"\n  ],\n  \"validation\": {\n    \"type\": \"JWKS_URL\",\n    \"jwksUrl\": \"https://example.com/as/jwks\",\n    \"clockSkewTolerance\": 5\n  }\n}");
Request request = new Request.Builder()
  .url("{{apiPath}}/environments/{{envID}}/externalOAuthServers")
  .method("POST", body)
  .addHeader("Content-Type", "application/json")
  .addHeader("Authorization", "Bearer {{accessToken}}")
  .build();
Response response = client.newCall(request).execute();
var settings = {
  "url": "{{apiPath}}/environments/{{envID}}/externalOAuthServers",
  "method": "POST",
  "timeout": 0,
  "headers": {
    "Content-Type": "application/json",
    "Authorization": "Bearer {{accessToken}}"
  },
  "data": JSON.stringify({
    "name": "Example_2",
    "description": "OAuth server resource example",
    "type": "EXTERNAL",
    "issuers": [
      "https://example.com/as"
    ],
    "validation": {
      "type": "JWKS_URL",
      "jwksUrl": "https://example.com/as/jwks",
      "clockSkewTolerance": 5
    }
  }),
};

$.ajax(settings).done(function (response) {
  console.log(response);
});
var request = require('request');
var options = {
  'method': 'POST',
  'url': '{{apiPath}}/environments/{{envID}}/externalOAuthServers',
  'headers': {
    'Content-Type': 'application/json',
    'Authorization': 'Bearer {{accessToken}}'
  },
  body: JSON.stringify({
    "name": "Example_2",
    "description": "OAuth server resource example",
    "type": "EXTERNAL",
    "issuers": [
      "https://example.com/as"
    ],
    "validation": {
      "type": "JWKS_URL",
      "jwksUrl": "https://example.com/as/jwks",
      "clockSkewTolerance": 5
    }
  })

};
request(options, function (error, response) {
  if (error) throw new Error(error);
  console.log(response.body);
});
import requests
import json

url = "{{apiPath}}/environments/{{envID}}/externalOAuthServers"

payload = json.dumps({
  "name": "Example_2",
  "description": "OAuth server resource example",
  "type": "EXTERNAL",
  "issuers": [
    "https://example.com/as"
  ],
  "validation": {
    "type": "JWKS_URL",
    "jwksUrl": "https://example.com/as/jwks",
    "clockSkewTolerance": 5
  }
})
headers = {
  'Content-Type': 'application/json',
  'Authorization': 'Bearer {{accessToken}}'
}

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

print(response.text)
<?php
require_once 'HTTP/Request2.php';
$request = new HTTP_Request2();
$request->setUrl('{{apiPath}}/environments/{{envID}}/externalOAuthServers');
$request->setMethod(HTTP_Request2::METHOD_POST);
$request->setConfig(array(
  'follow_redirects' => TRUE
));
$request->setHeader(array(
  'Content-Type' => 'application/json',
  'Authorization' => 'Bearer {{accessToken}}'
));
$request->setBody('{\n  "name": "Example_2",\n  "description": "OAuth server resource example",\n  "type": "EXTERNAL",\n  "issuers": [\n    "https://example.com/as"\n  ],\n  "validation": {\n    "type": "JWKS_URL",\n    "jwksUrl": "https://example.com/as/jwks",\n    "clockSkewTolerance": 5\n  }\n}');
try {
  $response = $request->send();
  if ($response->getStatus() == 200) {
    echo $response->getBody();
  }
  else {
    echo 'Unexpected HTTP status: ' . $response->getStatus() . ' ' .
    $response->getReasonPhrase();
  }
}
catch(HTTP_Request2_Exception $e) {
  echo 'Error: ' . $e->getMessage();
}
require "uri"
require "json"
require "net/http"

url = URI("{{apiPath}}/environments/{{envID}}/externalOAuthServers")

http = Net::HTTP.new(url.host, url.port);
request = Net::HTTP::Post.new(url)
request["Content-Type"] = "application/json"
request["Authorization"] = "Bearer {{accessToken}}"
request.body = JSON.dump({
  "name": "Example_2",
  "description": "OAuth server resource example",
  "type": "EXTERNAL",
  "issuers": [
    "https://example.com/as"
  ],
  "validation": {
    "type": "JWKS_URL",
    "jwksUrl": "https://example.com/as/jwks",
    "clockSkewTolerance": 5
  }
})

response = http.request(request)
puts response.read_body
let parameters = "{\n  \"name\": \"Example_2\",\n  \"description\": \"OAuth server resource example\",\n  \"type\": \"EXTERNAL\",\n  \"issuers\": [\n    \"https://example.com/as\"\n  ],\n  \"validation\": {\n    \"type\": \"JWKS_URL\",\n    \"jwksUrl\": \"https://example.com/as/jwks\",\n    \"clockSkewTolerance\": 5\n  }\n}"
let postData = parameters.data(using: .utf8)

var request = URLRequest(url: URL(string: "{{apiPath}}/environments/{{envID}}/externalOAuthServers")!,timeoutInterval: Double.infinity)
request.addValue("application/json", forHTTPHeaderField: "Content-Type")
request.addValue("Bearer {{accessToken}}", forHTTPHeaderField: "Authorization")

request.httpMethod = "POST"
request.httpBody = postData

let task = URLSession.shared.dataTask(with: request) { data, response, error in
  guard let data = data else {
    print(String(describing: error))
    return
  }
  print(String(data: data, encoding: .utf8)!)
}

task.resume()

Example Response

201 Created

{
    "_links": {
        "self": {
            "href": "https://api.pingone.com/v1/environments/abfba8f6-49eb-49f5-a5d9-80ad5c98f9f6/externalOAuthServers/29e4c577-fea1-490c-a537-97264419ca81"
        },
        "environment": {
            "href": "https://api.pingone.com/v1/environments/abfba8f6-49eb-49f5-a5d9-80ad5c98f9f6"
        },
        "apiServers": {
            "href": "https://api.pingone.com/v1/environments/abfba8f6-49eb-49f5-a5d9-80ad5c98f9f6/apiServers?filter=authorizationServer.externalOAuthServer.id%20eq%20%2229e4c577-fea1-490c-a537-97264419ca81%22"
        }
    },
    "id": "29e4c577-fea1-490c-a537-97264419ca81",
    "environment": {
        "id": "abfba8f6-49eb-49f5-a5d9-80ad5c98f9f6"
    },
    "name": "Example_1",
    "description": "OAuth server resource example",
    "type": "EXTERNAL",
    "issuers": [
        "https://example.com/as"
    ],
    "validation": {
        "type": "JWKS_URL",
        "jwksUrl": "https://example.com/as/jwks",
        "clockSkewTolerance": 5
    }
}