Policy templates allow you to efficiently create and update policies for common LUSID features and data points.
Providing you are a LUSID user with sufficient privileges, you can create a policy template, for example to grant a user access to read portfolios within a particular scope. You can then generate or update a policy on-the-fly using one or more policy templates.
Currently, you can create your own policy templates and use them to generate and update policies. In future, LUSID will provide pre-built templates for common features and data, which you will be able to use to efficiently generate and update your own policies from.
Using the Access REST API
Currently, you can create one policy template per API call.
- Call the CreatePolicyTemplate API for your LUSID domain, passing in your API access token and: - A - codeto uniquely identify the template.
- A friendly - displayNameand- description.
- An array of - templatedSelectorscontaining the selectors to be included in policies generated from the template, with each item including:- The - applicationthe policy relates to.
- A - tagto identify whether this is a- Featureand/or- Datapolicy template. This allows you to track the policy types and create different feature and/or data policies from the same template.
- A - selectortype, structured in the same way as a selector in a data or feature policy, of either:- metadataSelectorDefinition
- matchAllSelectorDefinition
- IdSelectorDefinition; for this example, this selector type should contain:- An - identifier, for example a- scopeto assign access to.
- Optionally, a - nameand- descriptionto help identify the selector.
- actionsfor the policy, including:- A - scopevalue, for example- default.
- An - entityvalue, for example- Portfolio.
- The - activityto grant access to, for example- Read.
 
 
 - Note - The - selectorparameters required vary depending on the selector type and whether you are creating a template for a feature policy or a data policy. Read the corresponding articles to learn more about the required structure for each- selectortype.
 
 
The following example creates a policy template containing selectors for reading portfolios in the Finbourne-Examples scope:
curl -X POST "https://<your-domain>.lusid.com/access/api/policytemplates"
  -H "Authorization: Bearer <your-API-access-token>"
  -d "{
  "code": "read-portfolio-scope",
  "displayName": "Read portfolios in scope",
  "description": "Policy template that grants read access to portfolio data within the Finbourne-Examples scope",
  "templatedSelectors": [
    {
      "application": "LUSID",
      "tag": "Data",
      "selector": {
        "idSelectorDefinition": {
          "identifier": {
            "scope": "Finbourne-Examples"
          },
          "actions": [
            {
              "scope": "default",
              "activity": "Read",
              "entity": "Portfolio"
            }
          ],
          "name": "access-Finbourne-Examples-scope",
          "description": "Allow readonly access to the Finbourne-Examples portfolio scope"
        }
      }
    }
  ]
}"You can now use the GeneratePolicyFromTemplate API to combine selectors defined in the policy template above with other policy template selectors and efficiently create or update policies. See how to do this.
Using the LUSID web app
Coming soon