이 콘텐츠는 선택한 언어로 제공되지 않습니다.
Chapter 28. Knowledge Store REST API for Business Central spaces and projects
Red Hat Process Automation Manager provides a Knowledge Store REST API that you can use to interact with your projects and spaces in Red Hat Process Automation Manager without using the Business Central user interface. The Knowledge Store is the artifact repository for assets in Red Hat Process Automation Manager. This API support enables you to facilitate and automate maintenance of Business Central projects and spaces.
With the Knowledge Store REST API, you can perform the following actions:
- Retrieve information about all projects and spaces
- Create, update, or delete projects and spaces
- Build, deploy, and test projects
- Retrieve information about previous Knowledge Store REST API requests, or jobs
Knowledge Store REST API requests require the following components:
- Authentication
- The Knowledge Store REST API requires HTTP Basic authentication or token-based authentication for the user role - rest-all. To view configured user roles for your Red Hat Process Automation Manager distribution, navigate to- ~/$SERVER_HOME/standalone/configuration/application-roles.propertiesand- ~/application-users.properties.- To add a user with the - rest-allrole, navigate to- ~/$SERVER_HOME/binand run the following command:- ./add-user.sh -a --user <USERNAME> --password <PASSWORD> --role rest-all - $ ./add-user.sh -a --user <USERNAME> --password <PASSWORD> --role rest-all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - For more information about user roles and Red Hat Process Automation Manager installation options, see Planning a Red Hat Process Automation Manager installation. 
- HTTP headers
- The Knowledge Store REST API requires the following HTTP headers for API requests: - Accept: Data format accepted by your requesting client:- 
											application/json(JSON)
 
- 
											
- Content-Type: Data format of your- POSTor- PUTAPI request data:- 
											application/json(JSON)
 
- 
											
 
- HTTP methods
- The Knowledge Store REST API supports the following HTTP methods for API requests: - 
									GET: Retrieves specified information from a specified resource endpoint
- 
									POST: Creates or updates a resource
- 
									PUT: Updates a resource
- 
									DELETE: Deletes a resource
 
- 
									
- Base URL
- The base URL for Knowledge Store REST API requests is - http://SERVER:PORT/business-central/rest/, such as- http://localhost:8080/business-central/rest/.Note- The REST API base URL for the Knowledge Store and for the Process Automation Manager controller built in to Business Central are the same because both are considered part of Business Central REST services. 
- Endpoints
- Knowledge Store REST API endpoints, such as - /spaces/{spaceName}for a specified space, are the URIs that you append to the Knowledge Store REST API base URL to access the corresponding resource or type of resource in Red Hat Process Automation Manager.- Example request URL for - /spaces/{spaceName}endpoint- http://localhost:8080/business-central/rest/spaces/MySpace
- Request data
- HTTP - POSTrequests in the Knowledge Store REST API may require a JSON request body with data to accompany the request.- Example POST request URL and JSON request body data - http://localhost:8080/business-central/rest/spaces/MySpace/projects- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
28.1. Sending requests with the Knowledge Store REST API using a REST client or curl utility
The Knowledge Store REST API enables you to interact with your projects and spaces in Red Hat Process Automation Manager without using the Business Central user interface. You can send Knowledge Store REST API requests using any REST client or curl utility.
Prerequisites
- Business Central is installed and running.
- 
							You have rest-alluser role access to Business Central.
Procedure
- 
							Identify the relevant API endpoint to which you want to send a request, such as [GET] /spacesto retrieve spaces in Business Central.
- In a REST client or curl utility, enter the following components for a - GETrequest to- /spaces. Adjust any request details according to your use case.- For REST client: - 
									Authentication: Enter the user name and password of the Business Central user with the rest-allrole.
- HTTP Headers: Set the following header: - 
											Accept:application/json
 
- 
											
- 
									HTTP method: Set to GET.
- 
									URL: Enter the Knowledge Store REST API base URL and endpoint, such as http://localhost:8080/business-central/rest/spaces.
 - For curl utility: - 
									-u: Enter the user name and password of the Business Central user with therest-allrole.
- -H: Set the following header:- 
											Accept:application/json
 
- 
											
- 
									-X: Set toGET.
- 
									URL: Enter the Knowledge Store REST API base URL and endpoint, such as http://localhost:8080/business-central/rest/spaces.
 - curl -u 'baAdmin:password@1' -H "Accept: application/json" -X GET "http://localhost:8080/business-central/rest/spaces" - curl -u 'baAdmin:password@1' -H "Accept: application/json" -X GET "http://localhost:8080/business-central/rest/spaces"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
									Authentication: Enter the user name and password of the Business Central user with the 
- Execute the request and review the KIE Server response. - Example server response (JSON): - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- In your REST client or curl utility, send another API request with the following components for a - POSTrequest to- /spaces/{spaceName}/projectsto create a project within a space. Adjust any request details according to your use case.- For REST client: - 
									Authentication: Enter the user name and password of the Business Central user with the rest-allrole.
- HTTP Headers: Set the following header: - 
											Accept:application/json
- 
											Accept-Language:en-US
- 
											Content-Type:application/json
 
- 
											
- 
									HTTP method: Set to POST.
- 
									URL: Enter the Knowledge Store REST API base URL and endpoint, such as http://localhost:8080/business-central/rest/spaces/MySpace/projects.
- Request body: Add a JSON request body with the identification data for the new project:
 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - For curl utility: - 
									-u: Enter the user name and password of the Business Central user with therest-allrole.
- -H: Set the following headers:- 
											Accept:application/json
- 
											Accept-Language:en-US(If not defined, the default locale from the JVM is reflected)
- 
											Content-Type:application/json
 
- 
											
- 
									-X: Set toPOST.
- 
									URL: Enter the Knowledge Store REST API base URL and endpoint, such as http://localhost:8080/business-central/rest/spaces/MySpace/projects.
- 
									-d: Add a JSON request body or file (@file.json) with the identification data for the new project:
 - curl -u 'baAdmin:password@1' -H "Accept: application/json" -H "Accept-Language: en-US" -H "Content-Type: application/json" -X POST "http://localhost:8080/business-central/rest/spaces/MySpace/projects" -d "{ \"name\": \"Employee_Rostering\", \"groupId\": \"employeerostering\", \"version\": \"1.0.0-SNAPSHOT\", \"description\": \"Employee rostering problem optimisation using Planner. Assigns employees to shifts based on their skill.\"}"- curl -u 'baAdmin:password@1' -H "Accept: application/json" -H "Accept-Language: en-US" -H "Content-Type: application/json" -X POST "http://localhost:8080/business-central/rest/spaces/MySpace/projects" -d "{ \"name\": \"Employee_Rostering\", \"groupId\": \"employeerostering\", \"version\": \"1.0.0-SNAPSHOT\", \"description\": \"Employee rostering problem optimisation using Planner. Assigns employees to shifts based on their skill.\"}"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - curl -u 'baAdmin:password@1' -H "Accept: application/json" -H "Accept-Language: en-US" -H "Content-Type: application/json" -X POST "http://localhost:8080/business-central/rest/spaces/MySpace/projects" -d @my-project.json - curl -u 'baAdmin:password@1' -H "Accept: application/json" -H "Accept-Language: en-US" -H "Content-Type: application/json" -X POST "http://localhost:8080/business-central/rest/spaces/MySpace/projects" -d @my-project.json- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
									Authentication: Enter the user name and password of the Business Central user with the 
- Execute the request and review the KIE Server response. - Example server response (JSON): - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - If you encounter request errors, review the returned error code messages and adjust your request accordingly. 
28.2. Supported Knowledge Store REST API endpoints
The Knowledge Store REST API provides endpoints for managing spaces and projects in Red Hat Process Automation Manager and for retrieving information about previous Knowledge Store REST API requests, or jobs.
28.2.1. Spaces
						The Knowledge Store REST API supports the following endpoints for managing spaces in Business Central. The Knowledge Store REST API base URL is http://SERVER:PORT/business-central/rest/. All requests require HTTP Basic authentication or token-based authentication for the rest-all user role.
					
- [GET] /spaces
- Returns all spaces in Business Central. - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [GET] /spaces/{spaceName}
- Returns information about a specified space. - Expand - Table 28.1. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space to be retrieved - String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [POST] /spaces
- Creates a space in Business Central. - Expand - Table 28.2. Request parameters - Name - Description - Type - Requirement - body - The - name,- description,- owner,- defaultGroupId, and any other components of the new space- Request body - Required - Example request body (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [PUT] /spaces
- Updates - description,- owner, and- defaultGroupIdof a space in Business Central.- Example request body (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [DELETE] /spaces/{spaceName}
- Deletes a specified space from Business Central. - Expand - Table 28.3. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space to be deleted - String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
28.2.2. Projects
						The Knowledge Store REST API supports the following endpoints for managing, building, and deploying projects in Business Central. The Knowledge Store REST API base URL is http://SERVER:PORT/business-central/rest/. All requests require HTTP Basic authentication or token-based authentication for the rest-all user role.
					
- [GET] /spaces/{spaceName}/projects
- Returns projects in a specified space. - Expand - Table 28.4. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space for which you are retrieving projects - String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [GET] /spaces/{spaceName}/projects/{projectName}
- Returns information about a specified project in a specified space. - Expand - Table 28.5. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space where the project is located - String - Required - projectName- Name of the project to be retrieved - String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [POST] /spaces/{spaceName}/projects
- Creates a project in a specified space. - Expand - Table 28.6. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space in which the new project will be created - String - Required - body - The - name,- groupId,- version,- description, and any other components of the new project- Request body - Required - Example request body (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [DELETE] /spaces/{spaceName}/projects/{projectName}
- Deletes a specified project from a specified space. - Expand - Table 28.7. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space where the project is located - String - Required - projectName- Name of the project to be deleted - String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [POST] /spaces/{spaceName}/git/clone
- Clones a project into a specified space from a specified Git address. - Expand - Table 28.8. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space to which you are cloning a project - String - Required - body - The - name,- description, and Git repository- userName,- password, and- gitURLfor the project to be cloned- Request body - Required - Example request body (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [POST] /spaces/{spaceName}/projects/{projectName}/maven/compile
- Compiles a specified project in a specified space (equivalent to - mvn compile).- Expand - Table 28.9. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space where the project is located - String - Required - projectName- Name of the project to be compiled - String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [POST] /spaces/{spaceName}/projects/{projectName}/maven/test
- Tests a specified project in a specified space (equivalent to - mvn test).- Expand - Table 28.10. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space where the project is located - String - Required - projectName- Name of the project to be tested - String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [POST] /spaces/{spaceName}/projects/{projectName}/maven/install
- Installs a specified project in a specified space (equivalent to - mvn install).- Expand - Table 28.11. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space where the project is located - String - Required - projectName- Name of the project to be installed - String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [POST] /spaces/{spaceName}/projects/{projectName}/maven/deploy
- Deploys a specified project in a specified space (equivalent to - mvn deploy).- Expand - Table 28.12. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space where the project is located - String - Required - projectName- Name of the project to be deployed - String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
28.2.3. Jobs (API requests)
						All POST and DELETE requests in the Knowledge Store REST API return a job ID associated with each request, in addition to the returned request details. You can use a job ID to view the request status or delete a sent request.
					
Knowledge Store REST API requests, or jobs, can have the following statuses:
| Status | Description | 
|---|---|
| 
										 | The request was accepted and is being processed. | 
| 
										 | The request contained incorrect content and was not accepted. | 
| 
										 | The requested resource (path) does not exist. | 
| 
										 | The resource already exists. | 
| 
										 | An error occurred in KIE Server. | 
| 
										 | The request finished successfully. | 
| 
										 | The request failed. | 
| 
										 | The request was approved. | 
| 
										 | The request was denied. | 
| 
										 | The job ID for the request could not be found due to one of the following reasons: 
 | 
						The Knowledge Store REST API supports the following endpoints for retrieving or deleting sent API requests. The Knowledge Store REST API base URL is http://SERVER:PORT/business-central/rest/. All requests require HTTP Basic authentication or token-based authentication for the rest-all user role.
					
- [GET] /jobs/{jobId}
- Returns the status of a specified job (a previously sent API request). - Expand - Table 28.14. Request parameters - Name - Description - Type - Requirement - jobId- ID of the job to be retrieved (example: - 1541010216919-1)- String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [DELETE] /jobs/{jobId}
- Deletes a specified job (a previously sent API request). If the job is not being processed yet, this request removes the job from the job queue. This request does not cancel or stop an ongoing job. - Expand - Table 28.15. Request parameters - Name - Description - Type - Requirement - jobId- ID of the job to be deleted (example: - 1541010216919-1)- String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
28.2.4. Branches
						The Knowledge Store REST API supports the following endpoints for managing branches in Business Central. The Knowledge Store REST API base URL is http://SERVER:PORT/business-central/rest/. All requests require HTTP Basic authentication or token-based authentication for the rest-all user role.
					
- [GET] /spaces/{spaceName}/projects/{projectName}/branches
- Returns all branches in a specified project and space. - Expand - Table 28.16. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space for which you are retrieving projects - String - Required - projectName- Name of the project for which you are retrieving branches - String - Required - Example server response (JSON) - [ { "name":"master" } ]- [ { "name":"master" } ]- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [POST] /spaces/{spaceName}/projects/{projectName}/branches
- Adds a specified branch in a specified project and space. - Expand - Table 28.17. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space where the project is located - String - Required - projectName- Name of the project in which the new branch needs to be created - String - Required - body - The - newBranchNameand- baseBranchNameof a project- Request body - Required - Example request body (JSON) - { "newBranchName": "branch01", "baseBranchName": "master" }- { "newBranchName": "branch01", "baseBranchName": "master" }- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [DELETE] /spaces/{spaceName}/projects/{projectName}/branches/{branchName}
- Deletes a specified branch in a specified project and space. - Expand - Table 28.18. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space where the project is located - String - Required - projectName- Name of the project where the branch is located - String - Required - branchName- Name of the branch to be deleted - String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [POST] /spaces/{spaceName}/projects/{projectName}/branches/{branchName}/maven/compile
- Compiles a specified branch in a specified project and space. If - branchNameis not specified, then request applies to the master branch.- Expand - Table 28.19. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space where the project is located - String - Required - projectName- Name of the project where the branch is located - String - Required - branchName- Name of the branch to be compiled - String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [POST] /spaces/{spaceName}/projects/{projectName}/branches/{branchName}/maven/install
- Installs a specified branch in a specified project and space. If - branchNameis not specified, then request applies to the master branch.- Expand - Table 28.20. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space where the project is located - String - Required - projectName- Name of the project where the branch is located - String - Required - branchName- Name of the branch to be installed - String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [POST] /spaces/{spaceName}/projects/{projectName}/branches/{branchName}/maven/test
- Tests a specified branch in a specified project and space. If - branchNameis not specified, then request applies to the master branch.- Expand - Table 28.21. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space where the project located - String - Required - projectName- Name of the project where the branch is located - String - Required - branchName- Name of the branch to be tested - String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- [POST] /spaces/{spaceName}/projects/{projectName}/branches/{branchName}/maven/deploy
- Deploys a specified branch in a specified project and space. If - branchNameis not specified, then request applies to the master branch.- Expand - Table 28.22. Request parameters - Name - Description - Type - Requirement - spaceName- Name of the space where the project is located - String - Required - projectName- Name of the project where the branch is located - String - Required - branchName- Name of the branch to be deployed - String - Required - Example server response (JSON) - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow