The package information for all languages is currently stored in a csv file located here. We have one csv file for each language and an automation pipeline that runs daily to check for new releases and updates the versioning information and doc links in the csv for each package. The version information will be updated from the specific package managers for the given package ecosystem as well as by reading release tags from our mono repos. We can update more information like repo and doc information for things coming from our mono repos.
Package
- This is the full name for the package as it appears on the package manager.GroupId
- This is only for Java and it contains the GroupId of the package. The Package field in Java's case only contains the ArtifactId.VersionGA
- This contains the latest stable version for the given package. If one does not exist, the field is empty.VersionPreview
- This contains the latest preview/beta/prerelease version for the given package. The field will be empty if there isn't a preview, or the preview is older than the latest stable.DisplayName
- This is a friendly name for the package that is used in the package index and other contexts to display a nicer name for the package.ServiceName
- This is the name of the service that this package is related to and is used in documentation contexts to group a set of packages for a given service together.RepoPath
- This contains information to create a link to the github repo for the given package. For our standard services that ship from our mono repos this should just be name of the service directory (e.g./sdk/<service directory>/<package>
). It can be a full link if this package is coming from somewhere else. A value ofNA
should be present if their is no go source link.MSDocs
- This contains information to create a link to the Microsoft Docs site for the given package. For our standard services that ship from our mono repos this should just be empty if the docs are published as the links will be computed from the other data in the CSV file. If the docs are in a non-standard location, then it can contain a full link in this field. A value ofNA
should be present if the docs link is unknown or doesn't exist.GHDocs
- This contains information to create a link to our Github IO ref docs. For our standard services that ship from our mono repos this should just be empty if the docs are published as the links will be computed from the other data in the CSV file. If the docs are in a non-standard location, then it can contain a full link in this field. A value ofNA
should be present if the docs link is unknown or doesn't exist.Type
- This field contains a classification type for the given package. If a classification is unknown, the field is empty. The current classifications are:client
- This is used to represent a data plane library.compat
- This is used to represent a compatibility/bridge library.mgmt
- This is used to represent a management plane library.spring
- This is a special classification only for Java that represents the spring libraries.
New
- This field is set to true for any of our newer libraries that now following the guidelines outlined in this repo.PlannedVersions
- This field will list a set of versions combined with estimated dates in the format of[version1],[date1]|[version2],[date2]|[version3],[date3]
with version in the format ofX.Y.Z[bN|-beta.N]
and date in the format ofMM/dd/yyyy
. These dates are intended to be displayed on a roadmap page.LatestGADate
- Thi field is used to identify the date of when the latest GA package released.FirstGADate
- This field is used to identify the date of when a new package shipped its first stable release.FirstPreviewDate
- This field is used to identify the date of when a new package shipped its first preview release.Support
- This field is used to identify the level of support for the given package. See the support guidelines for more details but this field should containbeta
,active
,deprecated
orcommunity
, if the value is empty it generally implies unknown orbeta
support level.EOLDate
- If a package has a Support value ofdeprecated
this field provides the date at which the package is end of life (i.e. no longer supported). If a package is marked asdeprecated
, this field must have a valid value.Hide
- This field will determine whether we hide this package from various places like the package index, docs, as well as automated updates. The value is either true to hide or empty to not hide. This is useful to filter older packages that are still on the package managers, but we don't want to promote or display anywhere.Replace
- This field is used the store the package name for the related older (replaces) or newer (replaced by) package. The value should be the exact name of the package (for java it should begroupdid\artifactid
). If there are multiple then they should be separated by a comma (,
). If a package is marked asdeprecated
, this field must have a valid value.ReplaceGuide
- This field is used to store a link to a migration guide for folks to follow if they are trying to move from the older package to the replacement package. If the field is empty then nothing no link is displayed. If a package is marked asdeprecated
, this field must have a valid value.ServiceId
- The id for that represents the service in other internal data sources.MSDocService
- This field is the value of docs.ms metadatams.service
. If it is empty, then ms.service assigns to service directory. The value is defined here.Notes
- This is an open field that can be used to add any particular notes for a given package.
SpecPath
- Either the path to theREADME.md
file that defines the spec files or the folder that contains all the spec files.SpecReadmeTag
- If configured via aREADME.md
the tag (usually default tag) used to find spec file set. Empty if not based on aREADME.md
.SpecValidationErrors
- Can contain a list of potential errors detected while indexing the specs. The possible errors can be:SpecFileDoesNotExist
- The references spec file cannot be found to read.SpecFileIsNotUnderServiceFolder
- The referenced spec file is outside of the service folder referencing it or the path does not match the standard format.SpecTypeMismatchBetweenSpecFiles
- There is a conflict between the type of referenced spec files. Some aredata
and some aremgmt
.VersionTypeMismatchBetweenSpecFiles
- There is conflict between the version type of the referenced spec files. Some arepreview
and some arestable
.SpecPathMismatchBetweenSpecFiles
- There are specs coming from different folder paths, which often means they are from different versions.VersionMismatchBetweenSpecFiles
- There are specs files that have conflicting versions. SeeVersion
field to see a list of versions.VersionMismatchBetweenPathAndSpec
- The version in the spec doesn't match the version in the file path where the spec lives.
ServiceFamily
- The folder directly under the specification folder computed by path containing the specs. If there are conflicts the first one is used.ResourcePath
- The folder betweenServiceFamily
and version computed by the path containing the specs. If there are conflicts the first one is used.Version
- Version number based on the path containing the specs. If there are conflicting versions it will containVaries: <list of versions>
.VersionType
-preview
orstable
based on the path containing the specs.Type
-data
ormgmt
based on the path containing the specs.IsTypeSpec
- At least one of the json files contains thex-typespec-generated
tag.ServiceLifeCycle
-Greenfield
if the resource provider hasn't shipped a previous stable verison. OtherwiseBrownfield
.DateCreated
- Currently this field is unused as we don't have a great way to calculate it. If we figure out a good way we will populate it again.JsonFiles
- Path to all json spec files relative to theSpecPath
field.
In order to produce standard links without storing them all in the csv file we use link templates for each language in variable md files used by our jekyll site. We also parse those templates in our automation so that when updating we ensure the links are valid. As an example here are the link templates we currently use:
{% assign package_label = "maven" %}
{% assign package_trim = "azure-" %}
{% assign pre_suffix = "" %}
{% assign package_url_template = "https://search.maven.org/artifact/item.GroupId/item.Package/item.Version/jar/" %}
{% assign msdocs_url_template = "https://docs.microsoft.com/java/api/overview/azure/item.TrimmedPackage-readme" %}
{% assign ghdocs_url_template = "https://azuresdkdocs.blob.core.windows.net/$web/java/item.Package/item.Version/index.html" %}
{% assign source_url_template = "https://github.com/Azure/azure-sdk-for-java/tree/item.Package_item.Version/sdk/item.RepoPath/item.Package/" %}
The values in these templates of the format item.<property>
are replaced from the field values in the CSV files.
If you need to edit the CSV files please do not use Excel as it will remove all the quoting which is required by the consumers of the CSV (i.e. Jekyll and automation). Instead if it is a small edit please just use a normal text editor. If it is a larger edit the recommendation is to use the Edit csv extension for VS Code. When using that extension please set the following configuration options to ensure consistency.
"csv-edit.quoteAllFields": true,
"csv-edit.quoteEmptyOrNullFields": "true",
"csv-edit.readOption_hasHeader": "true",
"csv-edit.writeOption_hasHeader": "true"