Skip to content

Commit

Permalink
Added documentation directory for StrawberryShake v14 (#7435)
Browse files Browse the repository at this point in the history
  • Loading branch information
glen-84 authored Sep 5, 2024
1 parent 22d0425 commit 90e2826
Show file tree
Hide file tree
Showing 18 changed files with 1,802 additions and 0 deletions.
100 changes: 100 additions & 0 deletions website/src/docs/docs.json
Original file line number Diff line number Diff line change
Expand Up @@ -1608,6 +1608,106 @@
"metaDescription": "Strawberry Shake is an incredible GraphQL client for the .NET ecosystem, that helps developers to build awesome UIs in Blazor, Maui, and more.",
"latestStableVersion": "v13",
"versions": [
{
"path": "v14",
"title": "v14",
"items": [
{
"path": "index",
"title": "Introduction"
},
{
"path": "get-started",
"title": "Get Started",
"items": [
{
"path": "index",
"title": "Blazor"
},
{
"path": "xamarin",
"title": "Xamarin"
},
{
"path": "console",
"title": "Console"
}
]
},
{
"path": "subscriptions",
"title": "Subscriptions"
},
{
"path": "tooling",
"title": "Tooling / CLI"
},
{
"path": "caching",
"title": "Caching",
"items": [
{
"path": "index",
"title": "Overview"
},
{
"path": "entities",
"title": "Entities"
},
{
"path": "invalidation",
"title": "Invalidation"
}
]
},
{
"path": "performance",
"title": "Performance",
"items": [
{
"path": "index",
"title": "Overview"
},
{
"path": "persisted-queries",
"title": "Persisted Queries"
},
{
"path": "persisted-state",
"title": "Persisted State"
}
]
},
{
"path": "networking",
"title": "Networking",
"items": [
{
"path": "index",
"title": "Protocols"
},
{
"path": "authentication",
"title": "Authentication"
}
]
},
{
"path": "scalars",
"title": "Scalars"
},
{
"path": "migrating",
"title": "Migrating",
"items": [
{
"path": "migrate-from-12-to-13",
"title": "Migrate from 12 to 13"
}
]
}
]
},
{
"path": "v13",
"title": "v13",
Expand Down
5 changes: 5 additions & 0 deletions website/src/docs/strawberryshake/v14/caching/entities.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
title: "Entities"
---

> We are still working on the documentation for Strawberry Shake so help us by finding typos, missing things or write some additional docs with us.
67 changes: 67 additions & 0 deletions website/src/docs/strawberryshake/v14/caching/index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
---
title: "Caching"
---

> We are still working on the documentation for Strawberry Shake, so help us by finding typos, missing things, or write some additional docs with us.
StrawberryShake stores the result of GraphQL requests in a normalized entity store. The entity store allows your client to execute GraphQL requests with various strategies to reduce the need for network requests. Moreover, the normalized entities are updated by every request the client does, which means that you can build fully reactive components that change as the state in the store changes.

```mermaid
sequenceDiagram
participant Generated Client
participant Operation Store
participant Entity Store
participant GraphQL Server
Generated Client->>Operation Store: Queries local store
Operation Store->>GraphQL Server: Queries GraphQL server
Note over Entity Store: Normalize response into entities
GraphQL Server->>Entity Store: Returns GraphQL response
Note over Operation Store: Builds operation result from entities
Entity Store->>Operation Store: Returns entities for operation
Operation Store->>Generated Client: Returns operation result
```

# Strategies

We support three basic strategies to interact with the store and fetch data.

## Network Only

Network only is the simplest strategy and will fetch from the network and only then update the store. This means that our initial call will always get fresh data and at the same time update other request results watching the same entities.

If we use the reactive APIs in combination with network only we will still get updates whenever other requests fetch data for the entities we are watching.

## Cache First

Cache first is essentially the opposite of network only since it will first fetch from the store, and if the store has the data needed, it will not make any network requests. If the store does not have the data needed, it will go to the network and try to get the data and update the store.

## Cache and Network

The last strategy is a combination of the first two. The client will first try to get the data from the store. This gives us fast data response time if the store already has the data. After that the store will update that data for this request with data from the network which in consequence will trigger our subscription and serve us new data.

## Configuration

The global strategy default can be set on our dependency injection setup method.

```csharp
builder.Services
.AddConferenceClient(ExecutionStrategy.CacheFirst) // <----
.ConfigureHttpClient(client => client.BaseAddress = new Uri("http://localhost:5050/graphql"))
.ConfigureWebSocketClient(client => client.Uri = new Uri("ws://localhost:5050/graphql"));
```

The global strategy default can then be overwritten by any `Watch` method for a particular request.

```csharp
storeSession =
ConferenceClient
.GetSessions
.Watch(ExecutionStrategy.CacheFirst) // <----
.Where(t => !t.Errors.Any())
.Select(t => t.Data!.Sessions!.Nodes)
.Subscribe(result =>
{
sessions = result;
StateHasChanged();
});
```
5 changes: 5 additions & 0 deletions website/src/docs/strawberryshake/v14/caching/invalidation.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
title: "Invalidation"
---

> We are still working on the documentation for Strawberry Shake so help us by finding typos, missing things or write some additional docs with us.
34 changes: 34 additions & 0 deletions website/src/docs/strawberryshake/v14/configuration.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
---
title: Configuration
---

Strawberry Shake is configured by altering the `.graphqlrc.json` at the root of your project.
All settings to into `extensions.strawberryShake` object.
Here is a full configuration with all possibilities:

```json
{
// The path of the schema file, that will be used to generate the client.
// This setting may also be used by other tooling, because it is a default field of graphql-spec
"schema": "schema.graphql",
// The selector that determines, what files will be regarded as graphql documents
// This setting may also be used by other tooling, because it is a default field of graphql-spec
"documents": "**/*.graphql",
"extensions": {
// Here do only Strawberry Shake specific settings live
"strawberryShake": {
// The name of the generated client
"name": "ChatClient",
// The namespace of all the generated files of the client
"namespace": "Demo",
// The URL of the GraphQL api you want to consume with the client
"url": "https://workshop.chillicream.com/graphql/",
// The access level modifier of the generated client
"accessModifier": "public",
// Shall your client be based on dependency injection? If yes, all needed setup code
// will be generated for you, so that you only have to add the client to your DI container.
"dependencyInjection": true
}
}
}
```
Loading

0 comments on commit 90e2826

Please sign in to comment.