SlideShare a Scribd company logo
CLI, SDK, Doc... What if we generate them?
Quentin Brosse
DEVOPS ENGINEER, API Gateway - Dev tools
CLI, SDK, Doc…
What if we generate them?
Olivier Cano
DEVOPS ENGINEER, API Gateway - Dev tools
Our mission
API Gateway

& Dev tools
High Availability
Routing cross-region
Monitoring
Tracing
Dev tools
API Gateway
SDK
Python
Ansible
CLI
Terraform
SDK Go
Doc
API
Gateway
Dev tools
Works well at small scale
Scaleway APIs Today
54 services
11 methods
7 fields
54 services 580 methods 4 293 fields
SDK
Python
Ansible
CLI
Terraform
SDK Go
Doc
API
Gateway
RISKS
3 v2.4
v1.0
v2.0
v1.0
v0.1
v12
v1
1
5
8
5
3
1
How to scale better?
Don’t Repeat Yourself
Define a Single Source Of
Truth (SSOT)
SSOT Generators Tools
• Sync releases
• Short time-to-market
• Ease to patch
• Cross-team standardization
BENEFITS
Step 1: choose a SSOT
Interface Description Language
Specification language used to
describe a software component's
application programming interface
(API).
INTERFACE DESCRIPTION LANGUAGE
Apache Thrift
• Easy to read
• Typed language
• Growing ecosystem for code generation
• Used by major companies (Google, Twitter, …)
• High performance API with GRPC
PROTOBUF
Serialization Framework
:method: POST
:path: /greeter.Api/SayHello
content-type: application/grpc
0x78 0x67 0x68 0x5A 0x9A . . .
Serialization Framework
:method: POST
:path: /greeter.Api/SayHello
content-type: application/grpc
0x78 0x67 0x68 0x5A 0x9A . . .
package greeter;
service Api {
rpc SayHello (HelloRequest) returns (HelloReply) {}
}
message HelloRequest {
string name = 1;
}
message HelloReply {
string message = 1;
}
PROTOBUF
greeter/v1/api.proto
protoc-gen-go
api.pb.go
Let’s generate stuff!
Doc SDK CLI
GENERATED DEVELOPER TOOLS
GRPC

Gateway
GENERATED DEVELOPER TOOLS
GRPC

Gateway
Doc SDK CLI
REST vs gRPC
gRPC Gateway
REST
greeter/v1/api.proto
protoc-gen-grpc-gateway
GENERATED DEVELOPER TOOLS
GRPC

Gateway
Doc SDK CLI
Home-made plugins
• Description
• Required / Optional field
• Versions
• Public / Private
• Errors
• …
MISSING DATA
package: greeter
services:
Api:
title: Greeter API
version: v1
short: The Scaleway Greeter API
long: Say hello to Scaleway people! 👋
methods:
Greeter:
short: say hello !
messages:
HelloRequest:
fields:
name:
short: the name
required: true
SERVICE CONFIG
GENERATED DEVELOPER TOOLS
GRPC

Gateway
Doc SDK CLI
developers.scaleway.com
greeter/v1/api.proto + greeter/v1/api.yml
protoc-gen-openapi
openapi/greeter.v1.api.yaml
GENERATED DEVELOPER TOOLS
Doc CLISDKGRPC

Gateway
github.com/scaleway/scaleway-sdk-go
greeter/v1/api.proto + greeter/v1/api.yml
protoc-gen-sdk-go
api/greeter/v1/sdk.go
GENERATED DEVELOPER TOOLS
GRPC

Gateway
CLIDoc SDK
$ scw k8s create cluster
SSOT GENERATORS PROJECTS
Protobuf
Repository
protoc
protoc-gen-go
protoc-gen-python
protoc-gen-grpc-gateway
protoc-gen-openapi
protoc-gen-sdk-go
protoc-gen-cli CLI
Developers Website
SDK Go
GRPC Client
GRPC Client
GRPC Gateway
Internal
Let’s generate (more) stuff! 🙌
245, 328
generated lines
20, 847 handwritten lines
MERCI
Suivez notre actualité, tutoriels inédits et infos cloud sur
Twitter et LinkedIn @Scaleway
Et suivez-nous sur Twitter @QuentinBrosse & @kindermoumoute
CLI, SDK, Doc... What if we generate them?

More Related Content

PPTX
Running Python Flask web apps on Azure App Service
PPTX
PDF
OpenAPI Generator The Babel Fish of The API World - apidays Live Australia
PDF
A Journey to Improve Infrastructure Compliance With InSpec
PDF
apidays LIVE Paris 2021 - Using OpenAPI to configure your API Gateway by Ole ...
PPTX
Ciprian redinciuc continuous integration with jenkins for i os
PDF
Professional iOS development
PDF
Kotlin Multiplatfom In Action
Running Python Flask web apps on Azure App Service
OpenAPI Generator The Babel Fish of The API World - apidays Live Australia
A Journey to Improve Infrastructure Compliance With InSpec
apidays LIVE Paris 2021 - Using OpenAPI to configure your API Gateway by Ole ...
Ciprian redinciuc continuous integration with jenkins for i os
Professional iOS development
Kotlin Multiplatfom In Action

What's hot (20)

PDF
Comparison of Voice Assistant SDKs for Embedded Linux Devices
PPTX
Renan Dias: Using Alexa to deploy applications to Kubernetes
PPTX
Kotlin Multiplatfom In Action
PDF
Docker and DevOps - Why it matters
PDF
Having A Talk With Jenkins
PPTX
Speech Devices SDK
PPTX
Ppt on android
PPTX
Running the-next-generation-of-cloud-native-applications-using-open-applicati...
PPTX
Native Script by Sebastian Witalec
PDF
Accelerate Your Automation Testing Effort using TestProject & Docker | Docker...
PPTX
2014 austin-api-sdks-are-apis-too
PPTX
An overview of ring central sdk
PDF
Infrastructure as a Code
PDF
Kotlin for Android
PPTX
Using Docker EE in a CI/CD Workflow
PPTX
What is Kotlin Multiplaform? Why & How?
PDF
[RHFSeoul2017]6 Steps to Transform Enterprise Applications
PDF
Google Developer Day 2010 Japan: 音声入力 API for Android (アレックス グランスタイン, 小西 祐介)
PDF
Marco bizzantino Microsoft-Docker Meetup #4 Docker bday intro
PDF
The Ring programming language version 1.10 book - Part 6 of 212
Comparison of Voice Assistant SDKs for Embedded Linux Devices
Renan Dias: Using Alexa to deploy applications to Kubernetes
Kotlin Multiplatfom In Action
Docker and DevOps - Why it matters
Having A Talk With Jenkins
Speech Devices SDK
Ppt on android
Running the-next-generation-of-cloud-native-applications-using-open-applicati...
Native Script by Sebastian Witalec
Accelerate Your Automation Testing Effort using TestProject & Docker | Docker...
2014 austin-api-sdks-are-apis-too
An overview of ring central sdk
Infrastructure as a Code
Kotlin for Android
Using Docker EE in a CI/CD Workflow
What is Kotlin Multiplaform? Why & How?
[RHFSeoul2017]6 Steps to Transform Enterprise Applications
Google Developer Day 2010 Japan: 音声入力 API for Android (アレックス グランスタイン, 小西 祐介)
Marco bizzantino Microsoft-Docker Meetup #4 Docker bday intro
The Ring programming language version 1.10 book - Part 6 of 212
Ad

Similar to CLI, SDK, Doc... What if we generate them? (20)

PPTX
API Gateways are going through an identity crisis
PDF
Gateway APIs, Envoy Gateway, and API Gateways
PDF
apidays Helsinki & North 2023 - The future of API Management, Jona Apelbaum &...
PDF
API Gateway report
PDF
API Gateway Deployment Patterns
PDF
[Workshop] API-driven Integration
PDF
Deploy and Secure Your API Gateway with NGINX: From Zero to Hero – APCJ
PDF
OpenAPI and gRPC Side by-Side
PDF
LF_APIStrat17_OpenAPI and gRPC Side-by-Side
PDF
Automating the API Product Lifecycle
PDF
OpenAPI Generator The Babel Fish of The API World - apidays Live Paris
PDF
Creating API documentation for international communities
PPTX
AWS Summit Barcelona 2015 - Introducing Amazon API Gateway
PDF
2022 apidays LIVE Helsinki & North_Using OpenAPI to configure your API Gateway
PDF
apidays LIVE Paris 2021 - OpenAPI Generator - The Babel Fish of the API World...
PDF
Kong API Gateway.pdf
PDF
Microservices Architectural Maturity Matrix, Token Based Authority, API Gatew...
PDF
Build Great Networked APIs with Swift, OpenAPI, and gRPC
PPTX
Introduction to AWS API Gateway Presentation
PPTX
WEB API Gateway
API Gateways are going through an identity crisis
Gateway APIs, Envoy Gateway, and API Gateways
apidays Helsinki & North 2023 - The future of API Management, Jona Apelbaum &...
API Gateway report
API Gateway Deployment Patterns
[Workshop] API-driven Integration
Deploy and Secure Your API Gateway with NGINX: From Zero to Hero – APCJ
OpenAPI and gRPC Side by-Side
LF_APIStrat17_OpenAPI and gRPC Side-by-Side
Automating the API Product Lifecycle
OpenAPI Generator The Babel Fish of The API World - apidays Live Paris
Creating API documentation for international communities
AWS Summit Barcelona 2015 - Introducing Amazon API Gateway
2022 apidays LIVE Helsinki & North_Using OpenAPI to configure your API Gateway
apidays LIVE Paris 2021 - OpenAPI Generator - The Babel Fish of the API World...
Kong API Gateway.pdf
Microservices Architectural Maturity Matrix, Token Based Authority, API Gatew...
Build Great Networked APIs with Swift, OpenAPI, and gRPC
Introduction to AWS API Gateway Presentation
WEB API Gateway
Ad

More from Scaleway (20)

PDF
Entreprises : découvrez les briques essentielles d’une solution IoT
PDF
Understand, verify, and act on the security of your Kubernetes clusters - Sca...
PDF
Éditeurs d'applications mobiles : augmentez la résolution des photos de vos c...
PPTX
Discover the benefits of Kubernetes to host a SaaS solution
PPTX
6 winning strategies for agil SaaS editors
PDF
Webinar - Relying on Bare Metal to manage your workloads
PPTX
Webinaire du 09/04/20 - S'appuyer sur du Bare Metal pour gérer ses pics de ch...
PPTX
Scaleway Approach to VXLAN EVPN Fabric
PDF
Workshop IoT Hub : Pilotez une ampoule connectée
PDF
Why and how we proxy our IoT broker connections
PDF
From local servers up to Kubernetes in the cloud
PDF
L’évolution des serveurs dédiés vers le Bare Metal et les instances : comm...
PDF
L’IA, booster de votre activité : principes, usages & idéation
PDF
Comment automatiser le déploiement de sa plateforme sur des infrastructures ...
PDF
Serverless
PDF
Migrating the Online’s console with Docker
PDF
Routage à grande échelle des requêtes via RabbitMQ
PDF
Instances Behind the Scene: What happen when you click on «create a new insta...
PDF
Demystifying IoT : Bringing the cloud to connected devices with IoT Station
PDF
L’odyssée d’une requête HTTP chez Scaleway
Entreprises : découvrez les briques essentielles d’une solution IoT
Understand, verify, and act on the security of your Kubernetes clusters - Sca...
Éditeurs d'applications mobiles : augmentez la résolution des photos de vos c...
Discover the benefits of Kubernetes to host a SaaS solution
6 winning strategies for agil SaaS editors
Webinar - Relying on Bare Metal to manage your workloads
Webinaire du 09/04/20 - S'appuyer sur du Bare Metal pour gérer ses pics de ch...
Scaleway Approach to VXLAN EVPN Fabric
Workshop IoT Hub : Pilotez une ampoule connectée
Why and how we proxy our IoT broker connections
From local servers up to Kubernetes in the cloud
L’évolution des serveurs dédiés vers le Bare Metal et les instances : comm...
L’IA, booster de votre activité : principes, usages & idéation
Comment automatiser le déploiement de sa plateforme sur des infrastructures ...
Serverless
Migrating the Online’s console with Docker
Routage à grande échelle des requêtes via RabbitMQ
Instances Behind the Scene: What happen when you click on «create a new insta...
Demystifying IoT : Bringing the cloud to connected devices with IoT Station
L’odyssée d’une requête HTTP chez Scaleway

Recently uploaded (20)

PDF
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
PDF
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
PDF
Empathic Computing: Creating Shared Understanding
DOCX
The AUB Centre for AI in Media Proposal.docx
PPTX
Cloud computing and distributed systems.
PPTX
ACSFv1EN-58255 AWS Academy Cloud Security Foundations.pptx
PDF
Approach and Philosophy of On baking technology
PPT
Teaching material agriculture food technology
PDF
Review of recent advances in non-invasive hemoglobin estimation
PDF
NewMind AI Weekly Chronicles - August'25-Week II
PDF
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
PPTX
A Presentation on Artificial Intelligence
PDF
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
PPTX
Spectroscopy.pptx food analysis technology
PDF
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
PDF
Assigned Numbers - 2025 - Bluetooth® Document
PDF
Machine learning based COVID-19 study performance prediction
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
Agricultural_Statistics_at_a_Glance_2022_0.pdf
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
Empathic Computing: Creating Shared Understanding
The AUB Centre for AI in Media Proposal.docx
Cloud computing and distributed systems.
ACSFv1EN-58255 AWS Academy Cloud Security Foundations.pptx
Approach and Philosophy of On baking technology
Teaching material agriculture food technology
Review of recent advances in non-invasive hemoglobin estimation
NewMind AI Weekly Chronicles - August'25-Week II
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
A Presentation on Artificial Intelligence
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
Per capita expenditure prediction using model stacking based on satellite ima...
Spectroscopy.pptx food analysis technology
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
Assigned Numbers - 2025 - Bluetooth® Document
Machine learning based COVID-19 study performance prediction

CLI, SDK, Doc... What if we generate them?