-
Notifications
You must be signed in to change notification settings - Fork 759
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Auto generated documentation e.g. Markdown and schema #4935
Comments
Adding @anthony-c-martin comments (from #2301 discussion) below:
|
Been using this PSDocs module in a pipeline to build documentation for both ARM templates and Bicep modules (bicep build as a pre step for simple parsing from JSON in Powershell). It's rather flexible thanks to the templating features of PSDocs. See example of ARM template doc generation here: |
Would this include a visual diagram of deployed resources similar to that of the Visualiser? It's not clear to me if that's what is being portrayed in the "Overview" section above, or if this is just a list of icons. |
There is a few more snippets of context in the original discussion #2301 I think this is more about 'Docs' style output that you would have on a wiki or docs webpage Etc. Perhaps if you think about the Public Module gallery, it might be something that you can search and directly reference when using Module from the Gallery or even knowing if you want to use a particular Module. So it's more of a what you see above (and the image below) is a visualization on 'How to' use a Module etc. I think comparing it to the PowerShell docs pages, might make a good comparison?
help get-process -online Which directly here: So I think something like that. Seems like the visualization would also be useful on that same page and there are some other requests that have been opened to be able to export out the visualizations from vscode #2704 |
I think some a Working in the problem space a lot, when an array or an object need to be passed into a module/ template it's always hard to consume. What properties can be used is hard to determine. Typically the default value doesn't work because it is often set to an empty string, array or the parameter may be required. Having a prototype of the object to build work nicely. Here is how we do it in PSDocs for Azure. https://github.com/Azure/PSDocs.Azure/#annotate-templates-files currently, but there is no specific support in Bicep to allow this prototype to be show as a tip or added. @metadata({
example: {
env: 'Prod'
service: 'SERVICE_NAME'
}
})
param tags |
I think this is a good idea, but is treating a symptom and not the cause. We need to support user-defined types (#4158) so that the editor can provide completions and validate object parameters with a specific schema. cc @rynowak as FYI |
@alex-frankel Absolutely agree. But when it hits the wire format JSON, there is no reason it can't be articulated as a well known metadata property like Example: {
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"workspaceId": {
"type": "string",
"metadata": {
"description": "The resource identifier for a Log Analytics workspace.",
"strongType": "Microsoft.OperationalInsights/workspaces"
}
}
}
} |
Agreed. That metadata needs to manifest itself in the JSON layer as well. I think #4158 will address what you are looking for. |
Originally posted by @Antse in #2301 (comment)
by auto generated documentation i mean something like : (must confess i take some example from the official documentation)
Code :
Doc :
Deploy a Storage Account
Overview (global deployed resources schema)
Parameters
stoName
string
None
This is the storage account Name
secureParam
secure string
None
This is my Secure Param
Examples
Deploy Bicep file to a resource group
Az CLI:
Azure PowerShell:
Deploy with parameters
Our Bicep file exposed two parameters that we can be optionally overridden (
secureParam
andstoName
) by passing new values at deployment time.Pass parameters on the command line
Az CLI:
Azure PowerShell:
The text was updated successfully, but these errors were encountered: