REST API
ArupCompute automatically generates a REST API for each library hosted. You can use it to list the calculations and execute them.
For a full description of the ArupCompute API see the swagger documentation here.
Authentication
Calls to ArupCompute need to be authenticated against the Arup Azure AD Authentication and provide an OAuth 2.0 Bearer Token.
If you are using .NET you can use the arupcompute-connect-dotnet library.
If you are using Python have a look at arupcomputepy.
For other languages check out the Azure AD Authentication Libraries.
Authentication flows
See the Microsoft documentation for a thorough explanation of all of the flows, however some commonly used ones are listed below:
Integrated Windows authentication flow
This flow is used by desktop applications (for instance the ArupCompute Grasshopper component) which uses the account information on your Windows device to verify your identity. This is the most user friendly flow as the user is unlikely to be aware that it is even happening. Because of the tight integration with Windows systems this flow is currently only available from .NET languages.
Interactive or implicit grant flows
This flow prompts the user for a username and password to verify that they have access to ArupCompute. Most typically encountered in web applications (e.g. ArupCompute web interface).
Device code flow
This is used where the application has limited access to user accounts and cannot send password information securely. In this flow the user is given a code to enter into a website for verification purposes. This is the default authentication flow in arupcomputepy.
Client secret flow
This flow uses a pre-registered secret value to authenticate against ArupCompute. Because this flow allows any person with the client secret to access ArupCompute it is the most risky of all of the mentioned flows. To safeguard against unintended access this secret must be stored securely. For this reason this flow is not available from web browsers.
Registering an application for API access
To register an application (website, service etc.) for ArupCompute API access you will need access to the Arup Azure account. This can be arranged with IT.
Firstly, head to the Arup Azure portal
Create a new 'App Registration'
Choose 'public client' and use a redirect uri of the form 'myapp://auth'
Important info to keep a note of from the overview page is:
- Application (client) ID
- Directory (tenant) ID
Next go to 'API permissions' > 'Add a permission', then request 'ArupComputeAPI'.
If your application will be using an 'on-behalf-of' flow (e.g. a website) select 'delegated permissions' and you are done.
If your application is using a client secret flow (e.g. python process running on a server) you will need to select 'application permissions'. Application permissions require Arup IT approval - raise a service now request with the cloud computing team.
Registering a client secret
Go to the 'Certificates & secrets' page and create a 'new client secret'.
Give the secret a descriptive name, set an expiry date, and copy it somewhere secure.
When access has been approved by Arup IT you will now be able to set up your application to use the ArupCompute API via a client secret flow. This flow is supported by both arupcompute-connect-dotnet and arupcomputepy.
Resources
Generally, see the swagger docs for documentation of the resources and enpoints available on the ArupCompute API. Refer to this section for details which are not made obvious by the swagger docs. This section will not repeat information which can be understood from the swagger docs.
Manually publishing a library
New Library
If creating a new library simply make a POST
request to:
https://arupcomputefunctions.azurewebsites.net/api/library
with the following information:
{
"Name":"Sample Library",
"Slug":"samplelibrary",
"Assembly":"SampleLibrary.dll",
"UserId": 1
}
The UserId
corresponding to your user can be found by hitting the secured endpoint /api/users/me
.
A sample response is:
{
"libraryId": 1,
"name": "Sample Library",
"slug": "samplelibrary",
"assembly": "SampleLibrary.dll",
"repository": "",
"provider": "netframework",
"visibility": "public",
"userId": 1,
"user": null,
"libraryVersions": []
}
You can now proceed to create a new version for this library.
New Library Version
To publish a new version of a library, make a POST
request to:
https://arupcomputefunctions.azurewebsites.net/api/version?libraryid=1&version=1.0.0&description=MyStringEncodedDescription&userid=1&framework=1
With the appropriate query parameters libraryid
, version
, description
, userid
, framework
and with body the library zip file (use framework=1
for .NET Framework and framework=2
for .NET Core).
A sample response is:
{
"libraryId": 1,
"libraryVersionId": 1,
"date": "2019-12-03T18:44:39.3381965+00:00",
"major": 1,
"minor": 0,
"patch": 0,
"suffix": "",
"description": "MyStringEncodedDescription",
"sPrerelease": false,
"version": "1.0.0",
"libraryStatusId": 3,
"userId": 1,
"user": null,
"invokeUrl": "https://arupcompute-tf-samplelibrary1-0-0.azurewebsites.net/api/invoke"
}
The libraryStatusId
value corresponds to:
- 1 = successfully published
- 2 = unsuccessfully published
- 3 = publishing in process
You can refresh the libraryStatusId
by hitting the secured libraryVersion endpoint.