Skip to content

Latest commit

 

History

History

contributing-code-organization

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 

Understanding Radius repo code organization

This document describes the high-level organization of code for the Radius repository. The goal of this document is to capture most of the important details, not every single thing will be described here.

In general you should ask for guidance before creating a new top-level folder in the repo or creating a new folder in pkg/. There is usually a better place to put something.

Root folders

Folder Description
build/ Makefiles and scripts referenced from the root Makefile
cmd/ Entry points for executables built in the repository
typespec/ Definitions for generating Radius swagger files.
deploy/ Assets used to package, deploy, and install Radius
docs/ All project documentation
hack/ Utility code to generate Radius bicep types
pkg/ The majority of the Go code powering Radius
swagger/ OpenAPI Specification v2 files to describe the REST APIs of Radius resource providers
test/ Integration and end-to-end tests

Pkg folders

Folder Description
algorithm/ General purpose algorithms and data structures
armrpc/ Implementation containing shared functionality and utility for all Radius RP
aws/ Utility code and library integrations for working with AWS
azure/ Utility code and library integrations for working with Azure
cli/ Implementation code for the rad CLI
components/ Components and its folders hold the implementations of shared components used by the Radius control-plane services
controllers/ Kubernetes controllers for Radius
corerp/ Resource Provider implementation for Applications.Core resources
daprrp/ Resource Provider implementation for Applications.Dapr resources
datastoresrp/ Resource Provider implementation for Applications.Datastores resources
dynamicrp/ Implementation of the dynamic resource provider. The dynamicrp is responsible for managing the lifecycle of resources that are defined without their own resource provider implementation.
kubernetes/ Utility code and library integrations for working with Kubernetes
kubeutil/ Utility code and working with Kubernetes on client side
portableresources/ Shared Resource Provider implementation for portable resources
logging/ Utility code for Radius logging
messagingrp/ Resource Provider implementation for Applications.Messaging resources
middleware/ Implementation for all Radius middleware
metrics/ Code generating Radius metrics
profiler/ Code and configs for Radius profiler
recipes/ Implementation for Radius Recipes
rp/ Code shared by multiple rps
sdk/ Code for interfacing with Radius as a client
to/ Code for pointer to value conversions
trace/ Utility code for generating Radius traces
ucp/ Implementation of Universal Control Plane
validator/ OpenAPI spec loader and validator
version/ Infrastructure for how to version the Radius implementations