A robust and performant Swift 5 implementation of RFC6570 URI Template. Full Level 4 support is provided.
Getting Started
Swift Package Manager
Add .package(url: "https://github.com/SwiftScream/URITemplate.git", from: "3.0.0") to your Package.swift dependencies
Usage
Template Processing
import ScreamURITemplate
let template = try URITemplate(string:"https://api.github.com/repos/{owner}/{repository}/traffic/views")
let variables = ["owner":"SwiftScream", "repository":"URITemplate"]
let urlString = try template.process(variables)
// https://api.github.com/repos/SwiftScream/URITemplate/traffic/views
When Things Go Wrong
Both template initialization and processing can fail; throwing a URITemplate.Error
The error cases contain associated values specifying a string reason for the error and the index into the template string that the error occurred.
do {
_ = try URITemplate(string: "https://api.github.com/repos/{}/{repository}")
} catch URITemplate.Error.malformedTemplate(let position, let reason) {
// reason = "Empty Variable Name"
// position = 29th character
}
Get variable names used in a template
let template = try URITemplate(string:"https://api.github.com/repos/{owner}/{repository}/traffic/views")
let variableNames = template.variableNames
// ["owner", "repository"]
Codable Support
URITemplate implements the Codable protocol, enabling easy serialization to or from JSON objects.
struct HALObject : Codable {
let _links : [String:URITemplate]
}
Tests
The library is tested against the standard test suite, as well as some additional tests for behavior specific to this implementation. It is intended to keep test coverage as high as possible.
ScreamURITemplate
A robust and performant Swift 5 implementation of RFC6570 URI Template. Full Level 4 support is provided.
Getting Started
Swift Package Manager
Add
.package(url: "https://github.com/SwiftScream/URITemplate.git", from: "3.0.0")
to your Package.swift dependenciesUsage
Template Processing
When Things Go Wrong
Both template initialization and processing can fail; throwing a
URITemplate.Error
The error cases contain associated values specifying a string reason for the error and the index into the template string that the error occurred.Get variable names used in a template
Codable Support
URITemplate
implements theCodable
protocol, enabling easy serialization to or from JSON objects.Tests
The library is tested against the standard test suite, as well as some additional tests for behavior specific to this implementation. It is intended to keep test coverage as high as possible.