FINBOURNE’s Bloomberg Data License Per Security (BBG DLPS) integration allows you to select the Bloomberg content you need to meet your business priorities, and schedule delivery into LUSID.
Bloomberg Data License Per Security allows requests for individual securities on a pay-per-use model across:
Reference
ESG
Pricing
Risk
Regulation
Fundamentals
Estimates
Historical data
More information on Bloomberg Data License.
Prerequisites
Before getting started, ensure you have:
An active BBG DLPS contract with Bloomberg
Contacted your FINBOURNE representative to:
Enable the integration in your LUSID domain
Provide you with the IP addresses you’ll need to whitelist for the application in your Bloomberg Enterprise Console
Supported data types and methods
Instrument enrichment
You can use the Integrations dashboard to enrich existing LUSID instruments with the data points you need, including groups of data points such as shareholding disclosure. Keep reading this article to learn more.
Entities and instrument creation
You can use our suite of Luminesce providers to build bespoke data import requests, which you can schedule or run on demand. Read more.
Setting up the integration
Step 1: Obtain Bloomberg application credentials
First, you must create an application in the Bloomberg Enterprise Console to get your credentials for LUSID:
Sign in to your Bloomberg Enterprise Console portal.
Navigate to Connectivity > WEB API > Monitor and manage.
Select Create new application.
Specify the following values for the application:
Product:
DATA LICENSE
Product ID: Your Bloomberg account number
Application Name:
LUSID
Create the application and securely store the generated credentials. Note the client_id and client_secret values - you’ll need to provide these in LUSID.
Add the Allowed IPs provided by your FINBOURNE representative.
Step 2: Create an integration instance
An integration instance is a configuration of data points to import from Bloomberg.
Navigate to Integrations > Dashboard.
Select Create instance.
Specify the following:
Name: A friendly name for this integration instance
Description: A detailed description of the instance
Client Id and Client Secret: Your Bloomberg credentials retrieved in step 1
Download Drive File Path: Optional; a path starting with
LUSID-Horizon
to download data import troubleshooting files inOptionally, Bloomberg Professional Services users can complete the following fields to link your Bloomberg Terminal personal defaults:
User Number: You can locate this (and the following fields) by running
IAM<GO>
in Bloomberg TerminalSerial Number: The number to the left of
-
within the S/N. For example,<Serial Number>-<Work Station>
Work Station: The number to the right of
-
within the S/NPrice Source: Optionally, a pricing source to apply to all instruments in the request, for example
BGN
,EXCH
, orCMPN
Click Edit imported properties > Add properties and select which Bloomberg data fields to import.
Click Save to create the integration instance. Note the Instance ID, which you need for the next step.
Step 3: Select the instruments to import data for
LUSID selects instruments to import Bloomberg data for using the Instrument/LUSIDConfig-Bloomberg-DLPerSecurity/RefreshReferenceData
property.
Ensure your instruments have at least one of the following identifiers:
BloombergUniqueId
(recommended, ensures result is unambiguous)Figi
Cusip
Sedol
Isin
Ticker
(must include the Bloomberg yellow key suffix, for exampleVOD LN Equity
)
Note: All of the above identifier types have a three-stage key beginning with
Instrument/default/<identifier-type>
, for exampleInstrument/default/BloombergUniqueId
.Follow these steps to add the instrument property with scope
LUSIDConfig-Bloomberg-DLPerSecurity
and codeRefreshReferenceData
to one or more instruments you want to include in the Bloomberg integration instance import.Set the property value to your integration Instance ID from step 2. You can enter more than one ID if you want to include the instrument in multiple integration instances.
Running the integration
Call the ExecuteInstance API, for example:
curl -X POST 'https://<your-domain>.lusid.com/horizon/api/integrations/instances/<your-integration-instance-ID>/execute'
-H 'Content-Type: application/json'
-H 'Authorization: Bearer <your-API-access-token>'
Write a Luminesce SQL query using the Integration.Execute
provider and execute it using a tool such as the LUSID web app, for example:
select * from Integration.Execute where InstanceId ='<your-integration-instance-ID>';
Monitoring and troubleshooting integration runs
See how to monitor integrations and troubleshoot general issues.
Note
The Bloomberg integration utilises the Bloomberg once/snapshot trigger type, so runs take a minimum of 15 minutes to complete.
LUSID adds Bloomberg data to instruments as properties in the LUSID-Bloomberg-DLPerSecurity
scope. The Instrument/LUSID-Bloomberg-DLPerSecurity/BBG_Retrieval_Date
property tells you when data was last extracted for each instrument.
Monitoring run details
The Log ID data in the below screen-shot has the following usage for monitoring purposes.
1
: You can enter the Source Primary ID Value within Insights > Request Logs to view the request made to LUSID to locate instruments to include for the run, and LUSID’s response.2
or3
: Details the LUSID instruments included in this integration run and the identifier used to locate the data in BBG DLPS.4
: You can use the Source Primary ID Value to view the request within the Bloomberg Data Portal athttps://data.bloomberg.com/per-security/<Bloomberg Account ID>/requests/<Source Primary ID Value>
. You can expand the row to view details of the response file from Bloomberg; LUSID saves this file to your specified Download Drive File Path.5
or6
: Details the data mapping between each instrument identifier in the Bloomberg response and the updated LUSID instrument.
Troubleshooting
Error: Unauthorized
Unauthorized
UnexpectedException
Failed when calling Bloomberg HAPI
Uri : https://api.bloomberg.com/eap/catalogs/
Errored with : Unauthorized
Details : {"errors":[{...
"errorCode":"unauthorized-client",
"status":401,
"detail":"Invalid IP, IP 123.12.123.12 not whitelisted"}],
"error":"unauthorized_client"}
If you experience this error, check that the IP listed in the detail has been added to the authorised set in step 1.
Error: Forbidden
Forbidden
UnexpectedException
Failed when calling Bloomberg HAPI
Uri : https://api.bloomberg.com/eap/catalogs/
Errored with : Forbidden
Details : {"error_description":"Error verifying JWT signature.",
"error":"access_denied",
"errors":[{"title":"access_denied",
"detail":"Error verifying JWT signature.",
"meta":{"server-time":1757436416},
"errorCode":"forbidden",
"id":"2c9da3aa-390e-87b3-63a6-b261313587f3",
"status":403}]}
If you experience this error, check the values you’ve entered for your Bloomberg credentials in step 2.
Final Status: ResourceFailed
Description: Unable to process row
ResourceFailed
Description: Unable to process row
Bloomberg provides a Return Code (RC) to LUSID in each response:
A value of
0
represents a successA non-zero value sets the Final Status column to
ResourceFailed
For such errors, view the logs Description column to see the RC code and a description, if known, of the related error.
Final Status: PayloadExtracted
Description: Extracted 0 record(s) from LUSID.
PayloadExtracted
Description: Extracted 0 record(s) from LUSID.
If you experience this error, check the following:
Instruments have at least one valid identifier
The
Instrument/LUSIDConfig-Bloomberg-DLPerSecurity/RefreshReferenceData
property value is set to the correct instance ID
No Bloomberg data imported for instruments
Check the following:
Your connection to Bloomberg is working
Instruments are configured correctly. See troubleshooting, “PayloadExtracted : Extracted 0 record(s) from LUSID”.
The integration instance is configured to import the relevant fields
A minimum of 15 mins have elapsed since the integration instance was triggered
Appendix: Usage and cost management
Usage costs incurred from Bloomberg can depend on a variety of factors. LUSID’s BBG DLPS integration can help you to manage your usage costs by:
Processing your requests in cost-effective batches
Allowing you to:
Create different integration instances for different update frequencies, such as static reference data versus intraday pricing
Choose which instruments or commercial categories you want to receive data for
Select and import only the data fields you want
Contact your Bloomberg account representative for more details on your usage.