A mechanized formalization of GraphQL

Abstract

GraphQL is a novel language for specifying and querying web APIs, allowing clients to flexibly and efficiently retrieve data of interest. The GraphQL language specification is unfortunately only available in prose, making it hard to develop robust formal results for this language. Recently, Hartig and Perez proposed a formal semantics for GraphQL in order to study the complexity of GraphQL queries. The semantics is however not mechanized and leaves certain key aspects unverified. We present GraphCoQL, the first mechanized formalization of GraphQL, developed in the Coq proof assistant. GraphCoQL covers the schema definition DSL, query definitions, validation of both schema and queries, as well as the semantics of queries over a graph data model. We illustrate the application of GraphCoQL by formalizing the key query transformation and interpretation techniques of Hartig and Perez, and proving them correct, after addressing some imprecisions and minor issues.We hope that GraphCoQL can serve as a solid formal baseline for both language design and verification efforts for GraphQL.

Más información

Título según SCOPUS: A mechanized formalization of GraphQL
Título de la Revista: CPP 2020 - Proceedings of the 9th ACM SIGPLAN International Conference on Certified Programs and Proofs, co-located with POPL 2020
Editorial: Association for Computing Machinery, Inc
Fecha de publicación: 2020
Página de inicio: 201
Página final: 214
Idioma: English
DOI:

10.1145/3372885.3373822

Notas: SCOPUS