Integrating the JSONPlaceholder Posts API Using the Toolkit’s OpenAPI Feature
This tutorial demonstrates how to integrate an external HTTP-based REST API using the OpenAPI integration support in the ComUnity Developer Toolkit. While the target API—JSONPlaceholder—is a public test API that does not natively provide an OpenAPI definition, we’ve prepared a compliant OpenAPI 3.1 specification to enable its integration into the Toolkit.
The ComUnity Developer Toolkit supports OpenAPI-based integrations via Azure API Management (APIM). When registering an API, the Toolkit expects a specification document that adheres to Azure’s OpenAPI requirements. Once registered, this allows developers to expose endpoints, define Virtual Entities, and render structured data inside the application using the Toolkit’s OData-compatible pipeline.
Before You Begin
If you’re new to the APIs feature in the ComUnity Developer Toolkit, we recommend first reviewing the JSONPlaceholder Todos API tutorial, which introduces key concepts for integrating external APIs using the Toolkit. This tutorial builds upon the same foundational workflow but focuses specifically on integrating APIs using an OpenAPI specification, including steps to register, validate, and expose an API via Azure API Management (APIM).
What You’ll Learn
By the end of this tutorial, you’ll be able to:
Register a public REST API using an OpenAPI 3.1 specification
Configure and validate the API in Azure API Management (APIM) via the ComUnity Developer Toolkit.
Define a Virtual Entity to model post data from the JSONPlaceholder API.
Use Custom Classes and Controllers to:
Fetch all posts
Retrieve a specific post by ID
Create a new post using a POST request
Build custom UI to:
Display a dynamic list of all posts
Enable click-to-navigate functionality, allowing users to tap on a post and view its details on a dedicated screen.
Add a basic input form allowing users to submit new posts from within the app
Prerequisites
Access Requirements
A ComUnity user account with the necessary permissions (contact ComUnity Support if required).
A single-tenant environment is required for API integration (organisations must host their own instance of the Toolkit in Azure).
If a single-tenant instance is unavailable, users can request access to the shared ComUnity Platform environment (API management is not supported in this environment).
Technical Knowledge
C# programming skills
Familiarity with WCF Data Services, Entity Framework, and OData
Development Tools
Visual Studio 2022 (Community, Professional, or Enterprise)
Project Setup Before proceeding with the GraphQL API integration, ensure that you have:
Created a project from a sample – Follow the Create a Project section to set up a new project using a sample of your choice.
Built and launched the project successfully.
Registered a user account in your app – Sign up and log in within your app
Once your project is ready, you can proceed with configuring the OpenAPI integration.
Resources
OpenAPI specification file for JSON placeholder Posts
Step-by-Step Tutorial: Integrating an API Using an OpenAPI Specification
To configure the OpenAPI API in the ComUnity Developer Toolkit, follow these steps:
Register the OpenAPI API in the Toolkit:
In the ComUnity Developer Toolkit, navigate to Third Party Services > APIs.
Provide a name and an optional description for your API.
In the Provide Service URL field, enter:
Click the Select file button and upload the OpenAPI specification file for JSONPlaceholder Posts, which is provided in the Resources section.
Click the Add Azure API to your project button to register and configure the API in Azure API Management (APIM).
This process ensures the API is properly registered and available for further integration within the Toolkit.
Verify the API Registration in Azure:
After the API is registered, click the ellipsis (⋮) button next to the API in the Toolkit and select View in Azure Portal.
You will be redirected to Azure API Management (APIM).
Locate your newly created API under APIs (use the search function if needed).
Open the Settings tab and check for any schema validation errors to confirm the API was successfully registered.
Test the JSONPlaceholder API in Azure:
In Azure API Management (APIM ) under APIs, navigate to the Test tab.
Select one of the available operations listed under the API, such as GET /posts, GET /posts/{id}, or POST /posts.
Enter appropriate test data if required (e.g., provide a valid post ID or request body).
Click Send to execute the request and verify that a successful response is returned from the backend service.
Configure Properties and Security of the Post Virtual Entity in the Data Model: Go back to the ComUnity Developer Toolkit under Data. Create a Virtual Entity named Post. For detailed instructions on creating Virtual Entities in the Toolkit, refer to the Virtual Entities section.
Take note to include the following properties for the entity:
UserId → int
Id → string
Title → string
Body → string
For guidance on configuring table security and surfacing entity data to user roles, refer to:
Ensure that the Insert and View permissions are granted to your User role.
Expose the Posts API via Virtual Entities and Custom Classes:
Go to Custom Classes in the Toolkit. Select the WebApiConfig class and register your Post Virtual Entity as shown below (line 23):
WebApiConfigUpdate the Post entity class as shown below:
PostCreate a new class named PostsAPI, where you will define the logic for communicating with the API via Azure API Management, as shown below ensure that you also update your packages as shown:
PostsAPIUpdate your controller class as shown below, ensure that you also update all your packages on your file:
Post ControllerBuild your project after updating your Data model and Custom Classes so as to publish your changes and as well as to confirm that there are no errors in your build, if any exist debug and resolve them before proceeding to the next step.
Build the UI: In this step we will outline how to build the Posts screen that shows all posts as a list and supports the ability to click to navigate to the Post by ID screen, which shows dynamic details of the selected list item, and finally the Add a Post screen, which shows a simple form to create a post.
Navigate to Screens in the Toolkit and create a Posts navigation page.
Set an icon of your choice.
Add a List control to your screen.
Click the List item to activate it.
In the Properties Editor, set the following fields:
Data Path:
Item Title:
Click the Save button to persist your changes.
Launch your project to see your list of the titles of posts fetched from the JsonPlaceholder API server in the Posts page.
To enable click-to-navigate functionality to a Post by ID screen:
Click to select the List in the Posts screen configured in step 6.a.
Supported screen controls will appear under List Navigation under the Screen Structure tab.
Drag and drop a Form screen control into the List.
A subpage of Form type will be inserted under the Posts page in the navigation hierarchy under Screen View.
Navigate to the subpage and update its title to Post by ID:
Set its Target URL to:
Click Save.
Insert an Auto Input screen control into the Post by ID page.
Copy the Name value of the Post by ID from the Properties Editor.
Go back to the Posts page screen configured in step 6a, select the List we configured in step 6.a.iii, and set its Target URL to:
These actions enable click-to-navigate functionality from List items to the Post by ID screen.
For more information, see the section Dynamic List Rendering in Navigation pages.
To creat a Add a Post screen:
Select the Posts screen we made in step 6.a in the navigation hierarchy under Screen View.
This action will display supported screen controls under the Screen Structure tab.
Add a Page Link control onto it just above the List we configured in step 6a. A subpage will be created in the hierarchy.
Select the subpage and configure the following values:
Title:
Icon:
Target URL:
Click Save.
Drag and drop Auto Input screen controls into the screen structure of Add Post page.
Add a Button control and configure the following settings:
Navigate URL:
Click to select each Auto Input and set its Exclude field to:
Click Save.
These actions complete the UI by enabling users to view a list of posts, navigate to a screen displaying the details of a selected post, and submit new posts using a form.
Build and launch your project to view your posts in the application. Click Add Post to navigate to the Add Post screen, where you can fill out a form to create a new post. Click on any post in the list to be redirected to the Post by ID page, where you can view the post’s details.
Last updated