GraphQL

Fra Wikipedia, den frie encyklopedi
Hopp til navigering Hopp til søk

GraphQL er et språk tilgjengelig som åpen kildekode som er brukt til spørring og manipulering av programmeringsgrensesnitt, samt en kjøreomgivelse for å utføre spørringer mot eksisterende data.[1]

Historie[rediger | rediger kilde]

I 2012 ble GraphQL utviklet internt av Facebook, og i 2015 ble det gitt ut offentlig.[2] I 2018 ble GraphQL-prosjektet overført fra Facebook til den nyetablerte GraphQL Foundation i regi av den ideelle organisasjonen Linux Foundation.[3][4]

Siden 2012 har bruken av GraphQL økt tilnærmet likt adopsjonstidslinjen som ble angitt av Lee Byron, en av skaperne bak GraphQL.[5] Byrons mål var å gjøre GraphQL allestedsnærværende på tvers av webplattformer.

Den 9. februar 2018 ble GraphQL Schema Definition Language (SDL) en del av spesifikasjonen.[6]

Spesifikasjon av datastrukturer[rediger | rediger kilde]

GraphQL angir en tilnærming til å utvikle web-API-er, og har blitt sammenlignet med og opp mot REST og andre webtjeneste-arkitekturer. Den tillater klienter å definere strukturen til dataene som kreves, og den samme datastrukturen returneres fra serveren, hvilket forhindrer at store datamengder returneres. Dette har betydning for hvor effektivt man kan få resultater fra spørringer mot webhurtiglagre.

Eksempel[rediger | rediger kilde]

POST-forespørsel:

{
    orders {
        id
        productsList {
            product {
                name
                price
            }
            quantity
        }
        totalAmount
    }
}

Svar:

{
    "data": {
        "orders": [
            {
                "id": 1,
                "productsList": [
                    {
                        "product": {
                            "name": "orange",
                            "price": 1.5
                        },
                        "quantity": 100
                    }
                ],
                "totalAmount": 150
            }
        ]
    }
}

Oppbygning[rediger | rediger kilde]

GraphQL består av et typesystem, spørrespråk og utførelsessemantikk, statisk validering og typeintrospeksjon. Den støtter lesing, skriving (mutering) og abonnering på endringer i data (sanntidsoppdateringer), oftest implementert ved hjelp av WebSockets.[7] GraphQL-tjenere er tilgjengelige for flere språk inkludert Haskell, JavaScript,[8] Perl,[9] Python,[10] Ruby, Java, C++,[11] C#, Scala, Go, Rust, Elixir,[12] Erlang, PHP, R, D[13] og Clojure.

Alternativer[rediger | rediger kilde]

Fleksibiliteten og rikdommen i spørringsspråket legger også opp til en kompleksitet som kanskje ikke er verdt å ha for enkle API-er.[14][15][16] Til tross for navnet har ikke GraphQL mulighet for samme mengde av grafoperasjoner som en fullverdig grafdatabase, som for eksempel Neo4j eller enkelte dialekter av SQL som støtter transitiv lukking. Eksempelvis vil man med et GraphQL-grensesnitt som rapporterer foreldrene til et individ ikke kunne returnere mengden med alle disse sine forfedre i en enkelt spørring.

Se også[rediger | rediger kilde]

Referanser[rediger | rediger kilde]

  1. ^ «GraphQL: A query language for APIs.». 
  2. ^ «GraphQL: A data query language». 
  3. ^ «Facebook's GraphQL gets its own open-source foundation». TechCrunch (engelsk). Besøkt 7. november 2018. 
  4. ^ «The Linux Foundation Announces Intent to Form New Foundation to Support GraphQL - The Linux Foundation». The Linux Foundation (engelsk). 6. november 2018. Besøkt 7. november 2018. 
  5. ^ Anthony, Art. «Is GraphQL Moving Toward Ubiquity?». 
  6. ^ «GraphQL SDL included in Github repository». 
  7. ^ «GraphQL». Facebook. Arkivert fra originalen 18. juli 2018. Besøkt 4. juli 2018. 
  8. ^ «GraphQL js». 
  9. ^ «GraphQL - Perl implementation of GraphQL». 
  10. ^ «Graphene». Besøkt 18. juni 2017. 
  11. ^ graphql/libgraphqlparser, GraphQL, https://github.com/graphql/libgraphqlparser, besøkt 2020-05-30 
  12. ^ «Absinthe: The GraphQL toolkit for Elixir». Besøkt 19. juli 2018. 
  13. ^ «Package graphqld on DUB». 
  14. ^ «GraphQL vs REST: Overview». Phil Sturgeon (engelsk). Besøkt 25. november 2018. 
  15. ^ «Why use GraphQL, good and bad reasons». Honest Engineering (engelsk). 4. august 2018. Besøkt 26. november 2018. 
  16. ^ «GraphQL Fundamentals». Besøkt 4. juli 2018.