Class DefaultSerializer
The default serializer for the Couchbase.NET SDK. Uses Newtonsoft.JSON as the the serializer.
Implements
Inherited Members
Namespace: Couchbase.Core.IO.Serializers
Assembly: Couchbase.NetClient.dll
Syntax
public class DefaultSerializer : IExtendedTypeSerializer, IStreamingTypeDeserializer, IProjectableTypeDeserializer, IBufferedTypeSerializer, ITypeSerializerConstructors
| Edit this page View SourceDefaultSerializer()
Declaration
public DefaultSerializer()DefaultSerializer(JsonSerializerSettings, JsonSerializerSettings)
Declaration
public DefaultSerializer(JsonSerializerSettings deserializationSettings, JsonSerializerSettings serializerSettings)Parameters
| Type | Name | Description | 
|---|---|---|
| JsonSerializerSettings | deserializationSettings | |
| JsonSerializerSettings | serializerSettings | 
Fields
| Edit this page View SourceRequiresDynamicCodeMessage
Declaration
public const string RequiresDynamicCodeMessage = "The DefaultSerializer uses Newtonsoft.Json which requires dynamic code and is incompatible with AOT."Field Value
| Type | Description | 
|---|---|
| string | 
UnreferencedCodeMessage
Declaration
public const string UnreferencedCodeMessage = "The DefaultSerializer uses Newtonsoft.Json which requires unreferenced code and is incompatible with trimming."Field Value
| Type | Description | 
|---|---|
| string | 
Properties
| Edit this page View SourceDeserializationOptions
Provides custom deserialization options. Options not listed in SupportedDeserializationOptions will be ignored. If null, then defaults will be used.
Declaration
public DeserializationOptions? DeserializationOptions { get; set; }Property Value
| Type | Description | 
|---|---|
| DeserializationOptions | 
DeserializationSettings
Gets the incoming de-serializer settings; controls the format of the incoming JSON for de-serialization into POCOs.
Declaration
public JsonSerializerSettings DeserializationSettings { get; }Property Value
| Type | Description | 
|---|---|
| JsonSerializerSettings | The incoming serializer settings. | 
SerializerSettings
Gets the outgoing serializer settings; controls the format of the JSON you are storing in Couchbase.
Declaration
public JsonSerializerSettings SerializerSettings { get; }Property Value
| Type | Description | 
|---|---|
| JsonSerializerSettings | The outgoing serializer settings; controls the format of the JSON you are storing in Couchbase. | 
SupportedDeserializationOptions
Informs consumers what deserialization options this IExtendedTypeSerializer supports.
Declaration
public SupportedDeserializationOptions SupportedDeserializationOptions { get; }Property Value
| Type | Description | 
|---|---|
| SupportedDeserializationOptions | 
Methods
| Edit this page View SourceCanSerialize(Type)
Determines if the serializer can serialize and deserialize the specified type.
Declaration
public bool CanSerialize(Type type)Parameters
| Type | Name | Description | 
|---|---|---|
| Type | type | Type of object to serialize or deserialize. | 
Returns
| Type | Description | 
|---|---|
| bool | 
 | 
CreateJsonStreamReader(Stream)
Create an IJsonStreamReader for parsing a Stream.
Declaration
public IJsonStreamReader CreateJsonStreamReader(Stream stream)Parameters
| Type | Name | Description | 
|---|---|---|
| Stream | stream | Stream to parse. | 
Returns
| Type | Description | 
|---|---|
| IJsonStreamReader | The new IJsonStreamReader. | 
CreateProjectionBuilder(ILogger)
Create a new IProjectionBuilder based on this serializer.
Declaration
public IProjectionBuilder CreateProjectionBuilder(ILogger logger)Parameters
| Type | Name | Description | 
|---|---|---|
| ILogger | logger | Logger for logging warnings or errors. | 
Returns
| Type | Description | 
|---|---|
| IProjectionBuilder | A new IProjectionBuilder. | 
DeserializeAsync<T>(Stream, CancellationToken)
Deserializes the specified stream into the Type T specified as a generic parameter.
Declaration
public ValueTask<T?> DeserializeAsync<T>(Stream stream, CancellationToken cancellationToken = default)Parameters
| Type | Name | Description | 
|---|---|---|
| Stream | stream | The stream. | 
| CancellationToken | cancellationToken | Cancellation token. | 
Returns
| Type | Description | 
|---|---|
| ValueTask<T> | The Type instance representing the value of the key. | 
Type Parameters
| Name | Description | 
|---|---|
| T | The Type specified as the type of the value. | 
Deserialize<T>(ReadOnlySequence<byte>)
Deserializes the specified buffer into the type specified by T.
Declaration
public T? Deserialize<T>(ReadOnlySequence<byte> buffer)Parameters
| Type | Name | Description | 
|---|---|---|
| ReadOnlySequence<byte> | buffer | The buffer to deserialize from. | 
Returns
| Type | Description | 
|---|---|
| T | The deserialized value. | 
Type Parameters
| Name | Description | 
|---|---|
| T | The type of the value. | 
Deserialize<T>(Stream)
Deserializes the specified stream into the Type T specified as a generic parameter.
Declaration
public T? Deserialize<T>(Stream stream)Parameters
| Type | Name | Description | 
|---|---|---|
| Stream | stream | The stream. | 
Returns
| Type | Description | 
|---|---|
| T | The Type instance representing the value of the key. | 
Type Parameters
| Name | Description | 
|---|---|
| T | The Type specified as the type of the value. | 
Deserialize<T>(ReadOnlyMemory<byte>)
Deserializes the specified buffer into the Type T specified as a generic parameter.
Declaration
public T? Deserialize<T>(ReadOnlyMemory<byte> buffer)Parameters
| Type | Name | Description | 
|---|---|---|
| ReadOnlyMemory<byte> | buffer | The buffer to deserialize from. | 
Returns
| Type | Description | 
|---|---|
| T | The Type instance representing the value of the key. | 
Type Parameters
| Name | Description | 
|---|---|
| T | The Type specified as the type of the value. | 
GetDeserializationSettings(JsonSerializerSettings, DeserializationOptions?)
Declaration
protected virtual JsonSerializerSettings GetDeserializationSettings(JsonSerializerSettings baseSettings, DeserializationOptions? options)Parameters
| Type | Name | Description | 
|---|---|---|
| JsonSerializerSettings | baseSettings | |
| DeserializationOptions | options | 
Returns
| Type | Description | 
|---|---|
| JsonSerializerSettings | 
GetMemberName(MemberInfo)
Get the name which will be used for a given member during serialization/deserialization.
Declaration
public string? GetMemberName(MemberInfo member)Parameters
| Type | Name | Description | 
|---|---|---|
| MemberInfo | member | Returns the name of this member. | 
Returns
| Type | Description | 
|---|---|
| string | The name which will be used for a given member during serialization/deserialization, or null if if will not be serialized. | 
Remarks
DefaultSerializer uses Newtonsoft.Json.JsonSerializerSettings.ContractResolver from SerializerSettings to determine the member name.
Serialize(Stream, object?)
Serializes the specified object onto a stream.
Declaration
public void Serialize(Stream stream, object? obj)Parameters
| Type | Name | Description | 
|---|---|---|
| Stream | stream | The stream to receive the serialized object. | 
| object | obj | The object to serialize. | 
SerializeAsync(Stream, object?, CancellationToken)
Serializes the specified object onto a stream.
Declaration
public ValueTask SerializeAsync(Stream stream, object? obj, CancellationToken cancellationToken = default)Parameters
| Type | Name | Description | 
|---|---|---|
| Stream | stream | The stream to receive the serialized object. | 
| object | obj | The object to serialize. | 
| CancellationToken | cancellationToken | Cancellation token. | 
Returns
| Type | Description | 
|---|---|
| ValueTask | 
Serialize<T>(IBufferWriter<byte>, T)
Serializes the specified object onto an IBufferWriter<T>.
Declaration
public void Serialize<T>(IBufferWriter<byte> writer, T obj)Parameters
| Type | Name | Description | 
|---|---|---|
| IBufferWriter<byte> | writer | The writer to receive the serialized object. | 
| T | obj | The object to serialize. | 
Type Parameters
| Name | Description | 
|---|---|
| T | Type of object to serialize. |