Skip to content

setchy/dgs-extended-formatters

Repository files navigation

DGS Extended Formatters

Build Status Latest Release Coverage Quality Gate Status Renovate enabled OSS License

A set of Netflix DGS Schema Directives for common response formatting use-cases.

Getting started

Tip

  • dgs-extended-formatters 2.x.x for Netflix DGS 10.x
  • dgs-extended-formatters 1.x.x for Netflix DGS 9.x
<dependency>
    <groupId>io.github.setchy</groupId>
    <artifactId>dgs-extended-formatters</artifactId>
    <version>2.0.0</version>
</dependency>

Usage

String Formatters

The following schema directives support formatting String scalars

@abbreviate

Abbreviates a string using ellipses for a given width

  • SDL: directive @abbreviate(width: Int!) on FIELD_DEFINITION

@camelcase

Converts the String into camelCase

  • SDL: directive @camelcase on FIELD_DEFINITION | ARGUMENT_DEFINITION

@capitalize

Capitalize the starting letter for each word in a String

  • SDL: directive @capitalize on FIELD_DEFINITION | ARGUMENT_DEFINITION

@lowercase

Lowercase all characters in a String

  • SDL: directive @lowercase on FIELD_DEFINITION | ARGUMENT_DEFINITION

@prefix

Prepends a prefix to a String

  • SDL: directive @prefix(with: String!) on FIELD_DEFINITION

@resourceId

Transforms a string into a base64 protobuf opaque ID. This takes in domain, subdomain, and systemName arguments which will be encoded into the ID.

  • SDL: directive @resourceId(domain: String!, subdomain: String!, systemName: String!) on FIELD_DEFINITION

@reverse

Reverse the characters in a String

  • SDL: directive @reverse on FIELD_DEFINITION | ARGUMENT_DEFINITION

@suffix

Appends a suffix to a String

  • SDL: directive @suffix(with: String!) on FIELD_DEFINITION

@swapcase

Invert the case of each character in a String

  • SDL: directive @swapcase on FIELD_DEFINITION | ARGUMENT_DEFINITION

@trim

Remove any leading or trailing whitespace

  • SDL: directive @trim on FIELD_DEFINITION | ARGUMENT_DEFINITION

@uppercase

Uppercase each character in a String

  • SDL: directive @uppercase on FIELD_DEFINITION | ARGUMENT_DEFINITION

Numeric Formatters

The following schema directives support formatting Int or Float scalars

@absolute

Returns the absolute value

  • SDL: directive @absolute on FIELD_DEFINITION | ARGUMENT_DEFINITION

@ceiling

Returns the ceiling value

  • SDL: directive @ceiling on FIELD_DEFINITION | ARGUMENT_DEFINITION

@floor

Returns the floor value

  • SDL: directive @floor on FIELD_DEFINITION | ARGUMENT_DEFINITION

Release Process

Our release process involves

  1. Run the release workflow
  2. Enter the new version number to release
  3. Draft a new release, create or select the tag which matches the release version used in step 2
  4. Publish the release notes

About

A set of DGS Directives for common formatting use-cases

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages