Skip to main content

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'

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

Overview page

Next go to 'API permissions' > 'Add a permission', then request 'ArupComputeAPI'.

API permissions

Request API permission

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.

Delegated application

Registering a client secret

Go to the 'Certificates & secrets' page and create a 'new client secret'.

Client secret

Give the secret a descriptive name, set an expiry date, and copy it somewhere secure.

Secret

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 POSTrequest 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.