Documentation / @ember-data/json-api / index / default
Defined in: -private/cache.ts:146
A JSON:API Cache implementation.
What cache the store uses is configurable. Using a different implementation can be achieved by implementing the store's createCache hook.
This is the cache implementation used by ember-data
.
import Cache from '@ember-data/json-api';
import Store from '@ember-data/store';
export default class extends Store {
createCache(wrapper) {
return new Cache(wrapper);
}
}
Cache
Implements
Constructors
Constructor
new default(capabilities): JSONAPICache;
Defined in: -private/cache.ts:167
Parameters
capabilities
Returns
JSONAPICache
Properties
version
version: "2";
Defined in: -private/cache.ts:154
The Cache Version that this implementation implements.
Implementation of
Methods
changedAttrs()
changedAttrs(identifier): ChangedAttributesHash;
Defined in: -private/cache.ts:1416
Query the cache for the changed attributes of a resource.
Parameters
identifier
Returns
ChangedAttributesHash
{ <field>: [<old>, <new>] }
Implementation of
changedRelationships()
changedRelationships(identifier): Map<string, RelationshipDiff>;
Defined in: -private/cache.ts:1529
Query the cache for the changes to relationships of a resource.
Returns a map of relationship names to RelationshipDiff objects.
type RelationshipDiff =
| {
kind: 'collection';
remoteState: StableRecordIdentifier[];
additions: Set<StableRecordIdentifier>;
removals: Set<StableRecordIdentifier>;
localState: StableRecordIdentifier[];
reordered: boolean;
}
| {
kind: 'resource';
remoteState: StableRecordIdentifier | null;
localState: StableRecordIdentifier | null;
};
Parameters
identifier
Returns
Map
<string
, RelationshipDiff
>
Implementation of
clientDidCreate()
clientDidCreate(identifier, options?): Record<string, unknown>;
Defined in: -private/cache.ts:768
[LIFECYCLE] Signal to the cache that a new record has been instantiated on the client
It returns properties from options that should be set on the record during the create process. This return value behavior is deprecated.
Parameters
identifier
options?
Record
<string
, Value
>
Returns
Record
<string
, unknown
>
Implementation of
commitWasRejected()
commitWasRejected(identifier, errors?): void;
Defined in: -private/cache.ts:1053
[LIFECYCLE] Signals to the cache that a resource was update via a save transaction failed.
Parameters
identifier
errors?
ApiError
[]
Returns
void
Implementation of
didCommit()
didCommit(committedIdentifier, result): SingleResourceDataDocument;
Defined in: -private/cache.ts:909
[LIFECYCLE] Signals to the cache that a resource was successfully updated as part of a save transaction.
Parameters
committedIdentifier
result
StructuredDataDocument
<SingleResourceDocument
>
Returns
Implementation of
diff()
diff(): Promise<Change[]>;
Defined in: -private/cache.ts:716
Generate the list of changes applied to all record in the store.
Each individual resource or document that has been mutated should be described as an individual Change
entry in the returned array.
A Change
is described by an object containing up to three properties: (1) the identifier
of the entity that changed; (2) the op
code of that change being one of upsert
or remove
, and if the op is upsert
a patch
containing the data to merge into the cache for the given entity.
This patch
is opaque to the Store but should be understood by the Cache and may expect to be utilized by an Adapter when generating data during a save
operation.
It is generally recommended that the patch
contain only the updated state, ignoring fields that are unchanged
interface Change {
identifier: StableRecordIdentifier | StableDocumentIdentifier;
op: 'upsert' | 'remove';
patch?: unknown;
}
Returns
Promise
<Change
[]>
Implementation of
dump()
dump(): Promise<ReadableStream<unknown>>;
Defined in: -private/cache.ts:731
Serialize the entire contents of the Cache into a Stream which may be fed back into a new instance of the same Cache via cache.hydrate
.
Returns
Promise
<ReadableStream
<unknown
>>
Implementation of
getAttr()
getAttr(identifier, attr):
| undefined
| Value;
Defined in: -private/cache.ts:1165
Retrieve the data for an attribute from the cache
Parameters
identifier
attr
string
| string
[]
Returns
| undefined
| Value
Implementation of
getErrors()
getErrors(identifier): ApiError[];
Defined in: -private/cache.ts:1610
Query the cache for any validation errors applicable to the given resource.
Parameters
identifier
Returns
ApiError
[]
Implementation of
getRelationship()
getRelationship(identifier, field):
| ResourceRelationship<StableRecordIdentifier>
| CollectionRelationship<StableRecordIdentifier>;
Defined in: -private/cache.ts:1572
Query the cache for the current state of a relationship property
Parameters
identifier
field
string
Returns
| ResourceRelationship
<StableRecordIdentifier
> | CollectionRelationship
<StableRecordIdentifier
>
resource relationship object
Implementation of
getRemoteAttr()
getRemoteAttr(identifier, attr):
| undefined
| Value;
Defined in: -private/cache.ts:1230
Retrieve remote state without any local changes for a specific attribute
Parameters
identifier
attr
string
| string
[]
Returns
| undefined
| Value
Implementation of
getRemoteRelationship()
getRemoteRelationship(identifier, field):
| ResourceRelationship<StableRecordIdentifier>
| CollectionRelationship<StableRecordIdentifier>;
Defined in: -private/cache.ts:1576
Query the cache for the server state of a relationship property without any local changes
Parameters
identifier
field
string
Returns
| ResourceRelationship
<StableRecordIdentifier
> | CollectionRelationship
<StableRecordIdentifier
>
resource relationship object
Implementation of
hasChangedAttrs()
hasChangedAttrs(identifier): boolean;
Defined in: -private/cache.ts:1440
Query the cache for whether any mutated attributes exist
Parameters
identifier
Returns
boolean
Implementation of
hasChangedRelationships()
hasChangedRelationships(identifier): boolean;
Defined in: -private/cache.ts:1540
Query the cache for whether any mutated relationships exist
Parameters
identifier
Returns
boolean
Implementation of
hydrate()
hydrate(stream): Promise<void>;
Defined in: -private/cache.ts:751
hydrate a Cache from a Stream with content previously serialized from another instance of the same Cache, resolving when hydration is complete.
This method should expect to be called both in the context of restoring the Cache during application rehydration after SSR AND at unknown times during the lifetime of an already booted application when it is desired to bulk-load additional information into the cache. This latter behavior supports optimizing pre/fetching of data for route transitions via data-only SSR modes.
Parameters
stream
ReadableStream
<unknown
>
Returns
Promise
<void
>
Implementation of
isDeleted()
isDeleted(identifier): boolean;
Defined in: -private/cache.ts:1647
Query the cache for whether a given resource is marked as deleted (but not necessarily persisted yet).
Parameters
identifier
Returns
boolean
Implementation of
isDeletionCommitted()
isDeletionCommitted(identifier): boolean;
Defined in: -private/cache.ts:1660
Query the cache for whether a given resource has been deleted and that deletion has also been persisted.
Parameters
identifier
Returns
boolean
Implementation of
isEmpty()
isEmpty(identifier): boolean;
Defined in: -private/cache.ts:1621
Query the cache for whether a given resource has any available data
Parameters
identifier
Returns
boolean
Implementation of
isNew()
isNew(identifier): boolean;
Defined in: -private/cache.ts:1634
Query the cache for whether a given resource was created locally and not yet persisted.
Parameters
identifier
Returns
boolean
Implementation of
merge()
merge(cache): Promise<void>;
Defined in: -private/cache.ts:680
Merge a fork back into a parent Cache.
Applications should typically not call this method themselves, preferring instead to merge at the Store level, which will utilize this method to merge the caches.
Parameters
cache
Returns
Promise
<void
>
Implementation of
mutate()
mutate(mutation): void;
Defined in: -private/cache.ts:440
Update the "local" or "current" (unpersisted) state of the Cache
Parameters
mutation
Returns
void
Implementation of
patch()
patch(op): void;
Defined in: -private/cache.ts:411
Update the "remote" or "canonical" (persisted) state of the Cache by merging new information into the existing state.
Parameters
op
the operation or list of operations to perform
Returns
void
Implementation of
peek()
Call Signature
peek(identifier):
| null
| ResourceObject;
Defined in: -private/cache.ts:491
Peek resource data from the Cache.
In development, if the return value is JSON the return value will be deep-cloned and deep-frozen to prevent mutation thereby enforcing cache Immutability.
This form of peek is useful for implementations that want to feed raw-data from cache to the UI or which want to interact with a blob of data directly from the presentation cache.
An implementation might want to do this because de-referencing records which read from their own blob is generally safer because the record does not require retainining connections to the Store and Cache to present data on a per-field basis.
This generally takes the place of getAttr
as an API and may even take the place of getRelationship
depending on implementation specifics, though this latter usage is less recommended due to the advantages of the Graph handling necessary entanglements and notifications for relational data.
Parameters
identifier
Returns
| null
| ResourceObject
the known resource data
Implementation of
Call Signature
peek(identifier):
| null
| ResourceDocument;
Defined in: -private/cache.ts:492
Peek resource data from the Cache.
In development, if the return value is JSON the return value will be deep-cloned and deep-frozen to prevent mutation thereby enforcing cache Immutability.
This form of peek is useful for implementations that want to feed raw-data from cache to the UI or which want to interact with a blob of data directly from the presentation cache.
An implementation might want to do this because de-referencing records which read from their own blob is generally safer because the record does not require retainining connections to the Store and Cache to present data on a per-field basis.
This generally takes the place of getAttr
as an API and may even take the place of getRelationship
depending on implementation specifics, though this latter usage is less recommended due to the advantages of the Graph handling necessary entanglements and notifications for relational data.
Parameters
identifier
Returns
| null
| ResourceDocument
the known resource data
Implementation of
peekRemoteState()
Call Signature
peekRemoteState(identifier):
| null
| ResourceObject;
Defined in: -private/cache.ts:551
Peek remote resource data from the Cache.
This will give the data provided from the server without any local changes.
In development, if the return value is JSON the return value will be deep-cloned and deep-frozen to prevent mutation thereby enforcing cache Immutability.
This form of peek is useful for implementations that want to feed raw-data from cache to the UI or which want to interact with a blob of data directly from the presentation cache.
An implementation might want to do this because de-referencing records which read from their own blob is generally safer because the record does not require retainining connections to the Store and Cache to present data on a per-field basis.
This generally takes the place of getAttr
as an API and may even take the place of getRelationship
depending on implementation specifics, though this latter usage is less recommended due to the advantages of the Graph handling necessary entanglements and notifications for relational data.
Parameters
identifier
Returns
| null
| ResourceObject
the known resource data
Implementation of
Call Signature
peekRemoteState(identifier):
| null
| ResourceDocument;
Defined in: -private/cache.ts:552
Parameters
identifier
Returns
| null
| ResourceDocument
Implementation of
peekRequest()
peekRequest(identifier):
| null
| StructuredDocument<ResourceDocument>;
Defined in: -private/cache.ts:621
Peek the Cache for the existing request data associated with a cacheable request.
This is effectively the reverse of put
for a request in that it will return the the request, response, and content whereas peek
will return just the content
.
Parameters
identifier
Returns
| null
| StructuredDocument
<ResourceDocument
>
Implementation of
put()
Call Signature
put<T>(doc): SingleResourceDataDocument;
Defined in: -private/cache.ts:217
Cache the response to a request
Implements Cache.put
.
Expects a StructuredDocument whose content
member is a JsonApiDocument.
cache.put({
request: { url: 'https://api.example.com/v1/user/1' },
content: {
data: {
type: 'user',
id: '1',
attributes: {
name: 'Chris'
}
}
}
})
Note The nested
content
anddata
members are not a mistake. This is because there are two separate concepts involved here, theStructuredDocument
which contains the context of a given Request that has been issued with the returned contents as itscontent
property, and aJSON:API Document
which is the json contents returned by this endpoint and which uses itsdata
property to signify which resources are the primary resources associated with the request.
StructuredDocument's with urls will be cached as full documents with associated resource membership order and contents preserved but linked into the cache.
Type Parameters
T
T
extends SingleResourceDocument
Parameters
doc
Returns
Implementation of
Call Signature
put<T>(doc): CollectionResourceDataDocument;
Defined in: -private/cache.ts:218
Cache the response to a request
Implements Cache.put
.
Expects a StructuredDocument whose content
member is a JsonApiDocument.
cache.put({
request: { url: 'https://api.example.com/v1/user/1' },
content: {
data: {
type: 'user',
id: '1',
attributes: {
name: 'Chris'
}
}
}
})
Note The nested
content
anddata
members are not a mistake. This is because there are two separate concepts involved here, theStructuredDocument
which contains the context of a given Request that has been issued with the returned contents as itscontent
property, and aJSON:API Document
which is the json contents returned by this endpoint and which uses itsdata
property to signify which resources are the primary resources associated with the request.
StructuredDocument's with urls will be cached as full documents with associated resource membership order and contents preserved but linked into the cache.
Type Parameters
T
T
extends CollectionResourceDocument
Parameters
doc
Returns
CollectionResourceDataDocument
Implementation of
Cache.put
Call Signature
put<T>(doc): ResourceErrorDocument;
Defined in: -private/cache.ts:219
Cache the response to a request
Implements Cache.put
.
Expects a StructuredDocument whose content
member is a JsonApiDocument.
cache.put({
request: { url: 'https://api.example.com/v1/user/1' },
content: {
data: {
type: 'user',
id: '1',
attributes: {
name: 'Chris'
}
}
}
})
Note The nested
content
anddata
members are not a mistake. This is because there are two separate concepts involved here, theStructuredDocument
which contains the context of a given Request that has been issued with the returned contents as itscontent
property, and aJSON:API Document
which is the json contents returned by this endpoint and which uses itsdata
property to signify which resources are the primary resources associated with the request.
StructuredDocument's with urls will be cached as full documents with associated resource membership order and contents preserved but linked into the cache.
Type Parameters
T
T
extends ResourceErrorDocument
Parameters
doc
Returns
Implementation of
Cache.put
Call Signature
put<T>(doc): ResourceMetaDocument;
Defined in: -private/cache.ts:220
Cache the response to a request
Implements Cache.put
.
Expects a StructuredDocument whose content
member is a JsonApiDocument.
cache.put({
request: { url: 'https://api.example.com/v1/user/1' },
content: {
data: {
type: 'user',
id: '1',
attributes: {
name: 'Chris'
}
}
}
})
Note The nested
content
anddata
members are not a mistake. This is because there are two separate concepts involved here, theStructuredDocument
which contains the context of a given Request that has been issued with the returned contents as itscontent
property, and aJSON:API Document
which is the json contents returned by this endpoint and which uses itsdata
property to signify which resources are the primary resources associated with the request.
StructuredDocument's with urls will be cached as full documents with associated resource membership order and contents preserved but linked into the cache.
Type Parameters
T
T
extends ResourceMetaDocument
Parameters
doc
Returns
Implementation of
Cache.put
rollbackAttrs()
rollbackAttrs(identifier): string[];
Defined in: -private/cache.ts:1468
Tell the cache to discard any uncommitted mutations to attributes
This method is a candidate to become a mutation
Parameters
identifier
Returns
string
[]
the names of fields that were restored
Implementation of
rollbackRelationships()
rollbackRelationships(identifier): string[];
Defined in: -private/cache.ts:1555
Tell the cache to discard any uncommitted mutations to relationships.
This will also discard the change on any appropriate inverses.
This method is a candidate to become a mutation
Parameters
identifier
Returns
string
[]
the names of relationships that were restored
Implementation of
setAttr()
setAttr(
identifier,
attr,
value): void;
Defined in: -private/cache.ts:1299
Mutate the data for an attribute in the cache
This method is a candidate to become a mutation
Parameters
identifier
attr
string
| string
[]
value
Returns
void
Implementation of
setIsDeleted()
setIsDeleted(identifier, isDeleted): void;
Defined in: -private/cache.ts:1596
Update the cache state for the given resource to be marked as locally deleted, or remove such a mark.
This method is a candidate to become a mutation
Parameters
identifier
isDeleted
boolean
Returns
void
Implementation of
unloadRecord()
unloadRecord(identifier): void;
Defined in: -private/cache.ts:1083
[LIFECYCLE] Signals to the cache that all data for a resource should be cleared.
This method is a candidate to become a mutation
Parameters
identifier
Returns
void
Implementation of
upsert()
upsert(
identifier,
data,
calculateChanges?): void | string[];
Defined in: -private/cache.ts:634
Push resource data from a remote source into the cache for this identifier
Parameters
identifier
data
ExistingResourceObject
calculateChanges?
boolean
Returns
void
| string
[]
if hasRecord
is true then calculated key changes should be returned
Implementation of
willCommit()
willCommit(identifier): void;
Defined in: -private/cache.ts:847
[LIFECYCLE] Signals to the cache that a resource will be part of a save transaction.
Parameters
identifier
Returns
void