Std.UriTemplate
0.0.14
See the version list below for details.
dotnet add package Std.UriTemplate --version 0.0.14
NuGet\Install-Package Std.UriTemplate -Version 0.0.14
<PackageReference Include="Std.UriTemplate" Version="0.0.14" />
paket add Std.UriTemplate --version 0.0.14
#r "nuget: Std.UriTemplate, 0.0.14"
// Install Std.UriTemplate as a Cake Addin #addin nuget:?package=Std.UriTemplate&version=0.0.14 // Install Std.UriTemplate as a Cake Tool #tool nuget:?package=Std.UriTemplate&version=0.0.14
std-uritemplate
This is intended to become a complete and maintained cross-language implementation of the Uri Template specification RFC 6570 Level 4.
Available implementations
Language | Complete | Reviewed | Published |
---|---|---|---|
Java | ✅ | ✅ | ✅ |
Python | ✅ | ✅ | ✅ |
Typescript | ✅ | ✅ | ✅ |
Go | ✅ | ✅ | ✅ |
C# | ✅ | ✅ | ✅ |
Usage
Java
You can use the library as a Maven dependency:
<dependency>
<groupId>io.github.std-uritemplate</groupId>
<artifactId>std-uritemplate</artifactId>
<version>REPLACE-ME</version>
</dependency>
in Gradle:
implementation 'io.github.std-uritemplate:std-uritemplate:REPLACE-ME'
and use it in your project:
import io.github.stduritemplate.StdUriTemplate;
...
StdUriTemplate.expand(template, substitutions);
Python
Install the package with pip
(or any alternative):
pip install std-uritemplate
Use the library in your project:
from stduritemplate import StdUriTemplate
...
StdUriTemplate.expand(template, substitutions)
Typescript/Javascript
Install the package using npm
:
npm i @std-uritemplate/std-uritemplate
Use the package:
const { StdUriTemplate } = require('@std-uritemplate/std-uritemplate');
...
StdUriTemplate.expand(template, substitutions);
Go
Install the package:
go get github.com/std-uritemplate/std-uritemplate/go
and use it:
import stduritemplate "github.com/std-uritemplate/std-uritemplate/go"
...
stduritemplate.Expand(template, substitutions)
C#
Install the package:
dotnet add package Std.UriTemplate
and use it:
using stduritemplate;
...
StdUriTemplate.Expand(template, substitutions);
Design decisions
We have a set of design decisions to guide:
- zero dependencies
- no usage of regexp
- no options/configurations
- only single expansion will be supported
- single method public API
- no language idiomatic API, only 1 low level primitive - we do encourage language-specific wrapper/alternative libraries
- portable implementation across languages based on widely available patterns
- target Level support is 4 (should pass all the canonical tests)
- favor maintenance and readability
- performance until they compromise readability
- one implementation per ecosystem/runtime (e.g. 1 implementation in Java and no Kotlin/Scala/Closure, 1 in TS that will serve JS as well etc.)
API
The public API is composed by a single method(in Java for simplicity):
String expand(String template, Map<String, Object> substitutions)
all the rest, should not be directly accessible.
Motivation
<img alt="alt_text" src="https://imgs.xkcd.com/comics/dependency.png" />
In the Kiota project they are using Uri Templates to build URLs, and we have already spent enough life-time dealing with:
- unmaintained projects
- scarce feedback from maintainers
- long release cycles
- different nuances in different implementations
- quirks and integration issues
- frameworks and additional dependencies
- diamond transitive dependencies
We aim to do it differently, by reducing maintenance to a minimum by automating it, and sharing responsibilities to reduce the bus/truck factor:
- single repository
- multiple implementations
- fully automated testing standardized
- fully automated releases on tag
- same tradeoffs across languages
- familiar implementation across languages
- multiple maintainers in an independent organization
Uri Template is(likely) going to be included in the next OpenAPI specification and we need to rely on a (more) solid foundation to prevent our selves to spend long, tedious hours and days chasing hidden bugs, verifying compatibilities and waiting for unresponsive maintainers.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
-
net7.0
- No dependencies.
NuGet packages (2)
Showing the top 2 NuGet packages that depend on Std.UriTemplate:
Package | Downloads |
---|---|
Microsoft.Kiota.Abstractions
Abstractions library for the Kiota generated SDKs in dotnet. |
|
WATGx.Common.Data
WATGx library |
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on Std.UriTemplate:
Repository | Stars |
---|---|
Kyrodan/KeeAnywhere
A cloud storage provider plugin for KeePass Password Safe
|
Version | Downloads | Last updated |
---|---|---|
1.0.6 | 23,068 | 8/30/2024 |
1.0.5 | 146,882 | 7/24/2024 |
1.0.3 | 109,974 | 7/3/2024 |
1.0.2 | 1,864 | 6/26/2024 |
1.0.1 | 91,208 | 6/11/2024 |
1.0.0 | 175 | 6/11/2024 |
0.0.59 | 1,136 | 6/7/2024 |
0.0.58 | 150 | 6/7/2024 |
0.0.57 | 3,364,081 | 4/18/2024 |
0.0.56 | 27,804 | 4/11/2024 |
0.0.55 | 1,003,079 | 3/18/2024 |
0.0.54 | 460,647 | 2/27/2024 |
0.0.53 | 96,605 | 2/15/2024 |
0.0.52 | 1,894 | 2/9/2024 |
0.0.50 | 3,207,763 | 1/8/2024 |
0.0.49 | 5,379 | 12/12/2023 |
0.0.48 | 86,776 | 11/29/2023 |
0.0.47 | 3,463 | 11/20/2023 |
0.0.46 | 2,510,914 | 10/19/2023 |
0.0.45 | 240 | 10/19/2023 |
0.0.44 | 991 | 10/17/2023 |
0.0.43 | 2,115 | 10/12/2023 |
0.0.42 | 81,113 | 9/20/2023 |
0.0.41 | 233 | 9/19/2023 |
0.0.40 | 254 | 9/7/2023 |
0.0.39 | 273 | 9/6/2023 |
0.0.38 | 243 | 9/4/2023 |
0.0.36 | 272 | 9/4/2023 |
0.0.35 | 242 | 9/4/2023 |
0.0.34 | 237 | 9/4/2023 |
0.0.32 | 253 | 9/4/2023 |
0.0.31 | 263 | 8/31/2023 |
0.0.30 | 267 | 8/31/2023 |
0.0.15 | 285 | 8/30/2023 |
0.0.14 | 274 | 8/29/2023 |
0.0.13 | 316 | 8/29/2023 |