This documentation describes the endpoints available in the AutoDNOExternal controller and provides details on the request models, including which fields are required and which are optional. The API supports operations for searching for ENA/EV charger/heat pump details, generating various documents (such as LOA and SLD), submitting ENA applications, and generating EV/HP documents.
API Key Authentication
All endpoints in the AutoDNOExternal API require authentication via an API key. This key must be included in every request using the HTTP header X-API-KEY.
- Header Name: X-API-KEY
- Value: Your assigned API key (for example, YOUR_API_KEY).
In Postman, set up an environment or global variable (e.g. {{api-key}}) and include it in the request headers. For example:
X-API-KEY: {{api-key}}
  
  This header must be sent with every API call to ensure proper authentication.
Endpoints Overview
1. Generate Documents
Endpoint: POST /api/AutoDNOExternal/GenerateDocuments
Description: Accepts a GenerateDocumentRequest that contains a solar form and a list of form types to generate (e.g., "G98", "A1-2", "LOA", "SLD"). The endpoint validates the data, generates the requested documents using PDF generation and document replacement logic, and returns the results as either a file URL or raw file data.
Request Model: GenerateDocumentRequest
| Field | Type | Required? | Description | 
|---|---|---|---|
| SolarForm | SolarFormExternal | Yes | Contains installation details (Company, Project, Inverters, Connection, AdvancedSettings). See the SolarFormExternal section for details. | 
| FormOutput | List<string> | No | Specifies which form types to generate. If omitted, the system chooses forms based on criteria (e.g., inverter capacity). Examples: "G98","LOA","SLD", etc. | 
| ReturnFileOption | string | Yes | Determines how the file(s) are returned. Options include "Server"(public URL),"S3"(stored on S3), or"raw"(Base64-encoded file data). | 
| Password | string | No | Optional password for encrypting generated PDF files (if applicable). | 
2. Generate LOA Document
Endpoint: POST /api/AutoDNOExternal/GenerateLOA
Description: Generates a Letter of Authority (LOA) document. This endpoint expects a SolarFormExternal object that includes company and project details. The Inverters list may be empty, as inverter details are not used for LOA generation. The project’s Boundary field is used to insert any necessary diagram/image data.
3. Generate SLD Document
Endpoint: POST /api/AutoDNOExternal/GenerateSLD
Description: Generates a Single Line Diagram (SLD) document. This endpoint expects a complete SolarFormExternal object with detailed inverter data (including optional PV panel and battery details). It returns two outputs: a PNG image of the diagram and a DrawIO XML string.
4. Submit ENA Application
Endpoint: POST /api/AutoDNOExternal/SubmitENAApplication
Description: Submits an ENA application for a solar installation. The request is an ExpandedFormExternal object that extends SolarFormExternal with additional fields for inverters (using InverterENADetails), heat pumps, EV chargers, and an optional cutout file attachment.
5. Generate EV/HP Documents
Endpoint: POST /api/AutoDNOExternal/GenerateEVHPDocuments
Description: Generates documents related to EV chargers and heat pumps. The request accepts an object that includes a form (of type ExpandedFormExternal), a list of form outputs, and options for file return and password protection.
Model Field Details
GenerateDocumentRequest
| Field | Type | Required? | Description | 
|---|---|---|---|
| SolarForm | SolarFormExternal | Yes | Contains installation details. See SolarFormExternal for a breakdown. | 
| FormOutput | List<string> | No | Determines which document types to generate. If not provided, forms are chosen based on inverter capacity and other criteria. | 
| ReturnFileOption | string | Yes | Options include "Server","S3", or"raw". | 
| Password | string | No | Optional password to encrypt generated PDF files. | 
SolarFormExternal
| Field | Type | Required? | Description | 
|---|---|---|---|
| Company | CompanyDetails | Yes | Contains installer/company details (name, contact, address). | 
| Project | ProjectDetails | Yes | Contains project or customer installation details (address, contact, boundary – optional). | 
| Inverters | List<InverterDetails> | Yes* | A list of inverter details. Required when generating SLD documents or submitting an ENA application. For LOA, this list may be empty. | 
| Connection | ConnectionDetails | Yes | Must include MpanandPhase(1 for single-phase; 3 for three-phase). | 
| AdvancedSettings | AdvancedSettings | No | Optional. Contains settings such as SaveNamefor file storage. | 
CompanyDetails
| Field | Type | Required? | Description | 
|---|---|---|---|
| CompanyName | string | Yes | Name of the installer/company. | 
| Address | SolarAddress | Yes | Address details. See below. | 
| Contact | Contact | Yes | Contact details including first name, last name, email and phone. | 
ProjectDetails
| Field | Type | Required? | Description | 
|---|---|---|---|
| CompanyName | string | No* | Typically the customer company name; may be required based on business rules. | 
| Address | SolarAddress | Yes | Project installation address details. | 
| Contact | Contact | Yes | Project contact details. | 
| Boundary | string | No | Optional field used by the LOA document generator (typically image data). | 
SolarAddress
| Field | Type | Required? | Description | 
|---|---|---|---|
| Street | string | Yes | The street address. | 
| SecondLine | string | No | Additional address line (optional). | 
| City | string | Yes | The city name. | 
| Postcode | string | Yes | The postal code. | 
| FormattedAddress | string (computed) | – | A concatenated address string in the format: Street, [SecondLine,] City, Postcode. | 
Contact
| Field | Type | Required? | Description | 
|---|---|---|---|
| FirstName | string | Yes | First name of the contact. | 
| LastName | string | Yes | Last name of the contact. | 
| Phone | string | Yes | Telephone number. | 
| string | Yes | Email address. | |
| FullName | string (computed) | – | Automatically computed as FirstName LastName. | 
| SignName | string (computed) | – | A shortened signature version (e.g. first letter of first name and full last name). | 
ConnectionDetails
| Field | Type | Required? | Description | 
|---|---|---|---|
| Mpan | string | Yes | The Meter Point Administration Number. | 
| Phase | int | Yes | Electrical phase (typically 1for single-phase or3for three-phase). | 
InverterDetails
| Field | Type | Required? | Description | 
|---|---|---|---|
| Manufacturer | string | Yes | Name of the inverter manufacturer. | 
| Capacity | string | Yes | Inverter capacity (numeric value as a string). | 
| Model | string | Yes | Model designation. | 
| ENACode | string | Yes* | Reference code for ENA/compliance. If missing, it may be auto-populated via a lookup. | 
| Remove | bool | No | If set to true, the inverter is to be removed on install. | 
| Existing | bool | Yes | Indicates if this inverter is part of an existing installation. | 
| Battery | BatteryDetails | No | Optional battery details associated with the inverter. | 
| StandardFormFields | StandardFormFields | No | Additional numeric parameters for PDF generation (e.g., max output currents). Only required for systems over 50KW. | 
| PVData | PVData[] | No | Optional panel string data used only for SLD generation. | 
BatteryDetails
| Field | Type | Required? | Description | 
|---|---|---|---|
| Manufacturer | string | No | Battery manufacturer name. | 
| Model | string | No | Battery model designation. | 
| Capacity | string | Yes | Battery capacity (e.g. in kWh). | 
AdvancedSettings
| Field | Type | Required? | Description | 
|---|---|---|---|
| SaveName | string | No | Optional file name suggestion used when saving generated documents. | 
StandardFormFields
| Field | Type | Required? | Description | 
|---|---|---|---|
| MaxApparentOutputPower | decimal | Yes | The maximum apparent output power of the inverter. | 
| RatedOutputCurrent | decimal | Yes | The rated output current of the inverter. | 
| MaxOutputCurrent | decimal | Yes | The maximum output current of the inverter. | 
ExpandedFormExternal
This model extends SolarFormExternal for ENA submission by adding additional component lists and file attachments.
| Field | Type | Required? | Description | 
|---|---|---|---|
| Inverters | List<InverterENADetails> | Yes | Inverter details for ENA submission. Similar to InverterDetails, but may include additional fields such as V2G. | 
| Heatpumps | List<HeatpumpDetails> | No | Optional list of heat pump details (used if the installation includes heat pumps). | 
| EVChargers | List<EVChargerDetails> | No | Optional list of EV charger details (used if the installation includes EV chargers). | 
| CutoutFile | byte[] | No | Optional binary file (typically an image) to be attached with the ENA application. | 
HeatpumpDetails
| Field | Type | Required? | Description | 
|---|---|---|---|
| HeatPumpManufacturer | string | Yes | Manufacturer of the heat pump. | 
| HeatPumpModel | string | Yes | Model designation of the heat pump. | 
| HeatPumpCapacity | string | Yes | Capacity of the heat pump. | 
| ENACode | string | Yes | Compliance reference code. | 
| Remove | bool | No | If true, this heat pump is excluded from processing. | 
| Existing | bool | Yes | Indicates whether this heat pump is part of an existing installation. | 
EVChargerDetails
| Field | Type | Required? | Description | 
|---|---|---|---|
| EVChargerManufacturer | string | Yes | Manufacturer of the EV charger. | 
| EVChargerModel | string | Yes | Model of the EV charger. | 
| EVChargerCapacity | string | Yes | Capacity of the EV charger. | 
| ENACode | string | Yes | Compliance reference code. | 
| Type | string | No | Specifies the type (e.g., AC/DC) if applicable. | 
| Remove | bool | No | If true, this EV charger is excluded. | 
| Existing | bool | Yes | Indicates if this charger is already installed. | 
Usage Examples
Example 1: Generating a Set of Documents
Call GenerateDocuments with a JSON body that includes a valid SolarFormExternal (with company, project, inverter, and connection details) and a list of form outputs (e.g., ["G98", "LOA", "SLD"]). If a Password is provided, applicable PDF files will be password protected.
Example 2: Generating LOA Documents
Call GenerateLOA with a SolarFormExternal object that includes installer and project details. The Inverters list may be empty as LOA does not require inverter data.
Example 3: Generating SLD Documents
Call GenerateSLD with a full SolarFormExternal including inverter details (and optional PVData and Battery information) to produce a schematic. The output includes a PNG image and a DrawIO XML string.
Example 4: Submitting an ENA Application
Call SubmitENAApplication with an ExpandedFormExternal JSON body. This model extends SolarFormExternal by including lists for Inverters (using InverterENADetails), Heatpumps, and EVChargers (if applicable), as well as an optional CutoutFile for file attachments.
Example 5: Generating EV/HP Documents
Call GenerateEVHPDocuments with a JSON object containing the form (of type ExpandedFormExternal), the desired form outputs, and options for file return and password protection.
This documentation provides an overview of the AutoDNOExternal API endpoints along with the models required for each operation. The endpoints support searching for ENA, EV charger, and heat pump details, generating multiple document types (PDFs, LOA, SLD, etc.), submitting ENA applications, and generating EV/HP documents. Optional fields such as AdvancedSettings.SaveName, Project.Boundary, and additional component lists in ExpandedFormExternal allow customization based on the installation requirements.
For further integration, adjust sample JSON bodies and field values as needed to match your business rules and data.
Here’s a Postman collection examples of the endpoints, you will require an API key from support before being able to submit any endpoints.
