This repository contains the source code for several tools that are useful to prepare and upload WSDL and XML schema files for use in your Azure API Management service instance:
- WSDLProcessor: Takes a WSDL file as an input and outputs another WSDL file with references through
wsdl:import
,xsd:import
, andxsd:include
resolved and merged inline. The references are resolved from the local filesystem or through a URL. - XMLSchemaProcessor: Takes a folder with XSD files, renames them based on Azure Resource Manager naming requirements, and creates a sequence to upload those schemas into Azure API Management based on a schema dependency graph
- PowerShell tools
- uploadschemas.ps1: Uploads the XSD schema files generated by the XMLSchemaProcessor to your Azure API Management service
- batchWsdlProcessor.ps1: Runs WSDLProcessor on all WSDL files with location specified in a JSON file and uploads the generated WSDL files into your Azure API Management service
- batchXmlSchemaProcessor.ps1: Runs XMLSchemaProcessor for all folders listed in a JSON file and uploads the generated XSD schemas into your Azure API Management service
This project framework provides the following features:
- Accepts two command-line parameters:
- Path to input WSDL file (required)
- Path to schemaLocation (optional)
- Detects, resolves, and inlines:
- All
wsdl:import
directives - All
xsd:import
andxsd:include
elements in XML schemas
- All
- Merges all XML schemas with the same target namespace into a single schema
- Resolves the following types of references:
- HTTP/HTTPS absolute URLs. Any non-
200
response is a failure. - Absolute local filesystem locations
- Relative local filesystem locations. For the base location, the tool uses the current file location, not root file location or the location of the tool itself.
- HTTP/HTTPS absolute URLs. Any non-
- Outputs a single WSDL file
This tool provides the following features:
-
Accepts two command-line parameters:
- A folder with all schemas
- Output folder
-
Produces a single file upload-plan.json in the output folder
-
Performs the following steps:
-
Iterates through all files in the folder with .xsd extension
-
Detects all
xsd:import
andxsd:include
elements -
Fails immediately if any import or include doesn't have
schemaLocation
or the value is not a local file location -
For each filename, generates an Azure Resource Manager-compliant resource name:
-
Drops file extension
-
Replaces all non-alphanumeric symbols with a single dash
Examples: foo.xsd -> foo, foo_1.xsd -> foo-1, foo_1_2.xsd -> foo-1-2, etc.
-
-
Replaces
schemaLocation
with a reference to a well-formed ARM schema resource: foo.xsd -> /schemas/foo, foo_1_2.xsd -> /schemas/foo-1-2 -
Builds a dependency graph between all schema files
-
Writes a single JSON document in the output file with property names corresponding to filenames and property values corresponding to ARM names in the order of dependency
Example: If foo.xsd depends on foo_1_2.xsd, upload-plan.json should contain:
{ "foo_1_2.xsd": "foo-1-2", "foo.xsd": "foo" }
-
-
Fails on the first error with a descriptive error message written to standard output
The Powershell script uploadschemas.ps1 provides the following features:
- Accepts two command-line parameters:
- Location of JSON file generated by schema processing tool (XMLSchemaProcessor)
- API Management resource URL, e.g.
https://management.azure.com/subscriptions/{subid}/resourceGroups/{rgname}/providers/Microsoft.ApiManagement/service/{servicename}
- Acquires Azure access token for current user
- Iterates through schemas in the source JSON file and uploads them to the API Management service using HTTP calls
- Fails on first error
The Powershell script batchWsdlProcessor.ps1 provides the following features:
- Accepts three command-line parameters:
- Full path of JSON configuration file with content similar to:
{"wsdlFileName.wsdl" : "DirectoryPathOfWsdlFile", ...}
- API Management resource URL, e.g.,
https://management.azure.com/subscriptions/{subid}/resourceGroups/{rgname}/providers/Microsoft.ApiManagement/service/{servicename}
- WSDLProcessor path, e.g.,
C:\myPathParent\myPathChild\[...]\Microsoft.Azure.ApiManagement.WsdlProcessor.App.exe
- Full path of JSON configuration file with content similar to:
- Acquires Azure access token for current user
- Iterates through JSON configuration file and generates new WSDL files with merged schemas
- Uploads the new WSDL files to the API Management service using HTTP calls
- Fails on first error
The Powershell script batchXmlSchemaProcessor.ps1 provides the following features:
- Accepts three command-line parameters:
- Full path of JSON configuration file with content similar to:
{"inputDirectoryWithSchemas" : "OutputDirectory", ...}
- API Management resource URL, e.g.,
https://management.azure.com/subscriptions/{subid}/resourceGroups/{rgname}/providers/Microsoft.ApiManagement/service/{servicename}
- XMLSchemaProcessor path, e.g.
C:\myPathParent\myPathChild\[...]\Microsoft.Azure.ApiManagement.XmlSchemaProcessor.App.exe
- Full path of JSON configuration file with content similar to:
- Acquires Azure access token for current user
- Iterates through JSON configuration file and generates new XML schema files and an upload-plan.json for each
- Uploads the new XML schema files to the API Management service using the upload-plan.json files and HTTP calls
- Fails on first failure
- OS: Windows, Linux, macOS
- .NET 9.0
- .NET CLI
- Azure CLI
- PowerShell
-
When you have the .NET CLI installed on your OS of choice, download the code and go to the Microsoft.Azure.ApiManagement.WsdlProcessor.App directory:
git clone https://github.com/Azure-Samples/api-management-schema-import.git cd api-management-schema-import/ApiManagementSchemaImport/Microsoft.Azure.ApiManagement.WsdlProcessor.App
-
Restore the packages that are specified in the .csproj file of the project:
dotnet restore
-
Build the project:
dotnet build
This will drop a binary in
./bin/[configuration]/[net9.0]/[Microsoft.Azure.ApiManagement.WsdlProcessor.App.exe]
-
Run the binary: 1.1. Scenario 1 (with all schemaReference at http URL) C:\folder\Microsoft.Azure.ApiManagement.WsdlProcessor.App.exe "/mywsdlfile.wsdl"
1.2. Scenario 2 (with all schemaReference point to a file) C:\folder\Microsoft.Azure.ApiManagement.WsdlProcessor.App.exe "/mywsdlfile.wsdl" ""
-
When you have the .NET CLI installed on your OS of choice, download the code and go to the Microsoft.Azure.ApiManagement.XmlSchemaProcessor.App directory:
git clone https://github.com/Azure-Samples/api-management-schema-import.git cd api-management-schema-import/Mcrosoft.Azure.ApiManagement.XmlSchemaProcessor.App
-
Restore the packages that are specified in the .csproj file of the projecgt:
dotnet restore
-
Build the project:
dotnet build
This will drop a binary in
./bin/[configuration]/[net9.0]/[Microsoft.Azure.ApiManagement.XmlSchemaProcessor.App.exe]
-
Run the binary:
c:\folder\Microsoft.Azure.ApiManagement.XmlSchemaProcessor.App.exe "c:\schemaslocation\" "c:\schemaslocation\output\"
.\uploadschemas.ps1 "upload-planLocationFile" "https://management.azure.com/subscriptions/{subid}/resourceGroups/{rgname}/providers/Microsoft.ApiManagement/service/{servicename}"
.\batchWsdlProcessor.ps1 "C:\myPathParent\myPathChild\...\wsdlFiles.json" "https://management.azure.com/subscriptions/{subid}/resourceGroups/{rgname}/providers/Microsoft.ApiManagement/service/{servicename}" "c:\folder\Microsoft.Azure.ApiManagement.WsdlProcessor.App.exe"
.\batchXmlSchemaProcessor.ps1 "C:\myPathParent\myPathChild\...\xmlSchemaFolders.json" "https://management.azure.com/subscriptions/{subid}/resourceGroups/{rgname}/providers/Microsoft.ApiManagement/service/{servicename}" "c:\folder\Microsoft.Azure.ApiManagement.XmlSchemaProcessor.App.exe"