Skip to content

Latest commit

 

History

History
86 lines (63 loc) · 2.79 KB

STYLE-GUIDE.md

File metadata and controls

86 lines (63 loc) · 2.79 KB

Istio API Style Guide

This page defines the design guidelines for Istio APIs. They apply to all proto files in the Istio project. Developers who create their own APIs using Istio should find these guidelines useful as well.

Since Istio APIs are based on proto3 and gRPC, we will use Google's API Design Guide as the baseline. Because Envoy APIs also uses the same baseline, the commonality across Envoy, Istio, proto3 and gRPC will greatly help developer experience in the long term.

In addition to Google's guide, the following conventions should be followed for Istio APIs.

Naming

Having consistent naming improves understanding of the APIs and reduce churns on the API design. Istio APIs should follow these naming conventions:

  • Package names must use lowercase without any _. Singular words are recommended to avoid mixture of plural and singular words in a package name. For example, istio.network.config.v1.

  • Message/enum/method names must use CamelCase without any embedded acronyms, see #364 for reasons. For example, HttpRequest.

  • Enum values must use UPPERCASE_WITH_UNDERSCORE. For example, INT_TYPE.

  • Field names must use lowercase_with_underscore. For example, display_name.

  • Repeated fields must use proper plural names. For example, rules.

  • Avoid using postpositive adjectives in names. For example, collected_items is recommended over items_collected.

Versioning

API Versioning

Istio APIs should use a simple versioning strategy based on major versions and releases, such as v1alpha, v2beta, or v3. Within each release, there should not be any breaking change to released features, such as changing the type of a field type, renaming a field, or changing a field number. Breaking changes are allowed between different releases, such as v1alpha1 and v1alpha2.

Deprecating a feature in an API release is allowed by following the applicable deprecation process. The reason to allow deprecation of individual features in a release is that it is significantly cheaper and simpler for everyone involved. In practice, it works out much better than deprecating an entire API version.

CRD Versioning

When defining Kubernetes Custom Resource Definition (CRD) using proto3, follow these guidelines:

  • The proto package name must match the Kubernetes apiVersion, excluding the .io DNS suffix and reversing the DNS segment ordering. The Kubernetes apiVersion has the format of group/version.

  • The proto message type must match the CRD kind name.

Example

The Kubernetes CRD:

apiVersion: authentication.istio.io/v1alpha1
kind: Policy

The proto message definition:

package istio.authentication.v1alpha1;
message Policy {...}