serdes_json 0.4.0 copy "serdes_json: ^0.4.0" to clipboard
serdes_json: ^0.4.0 copied to clipboard

Simple and clean json serializer and deserializer.

serdes_json #

serdes_json - is a simple and clean json serializer and deserializer. To create serializable model just describe your model, add Scheme suffix to the end of class name, and annotate with @SerdesJson. That's it!

NOTE #

This package is used only as a data holder and validation unit. You can't add additional methods to a model, at least for now. If you need a more flexible library, you can use json_serializable.

Install #

To use serdes_json you need install serdes_json and serdes_json_generator:

dependencies:
  serdes_json: <version>
dev_dependencies:
  serdes_json_generator: <version>

Generate models #

flutter packages pub run build_runner build

Examples #

Model with all required fields #

import 'package:serdes_json/serdes_json.dart';

part 'schemes.g.dart';

@SerdesJson()
class NewsListScheme {
  late List<NewsItemScheme> news;
}

// You can define private schemes.
@SerdesJson()
class _UserScheme {
  late String name;
}
@SerdesJson()
class NewsItemScheme {
  late int id;
  late String title;
  late String description;
  late int commentsCount;
}

Snake case models #

To convert all names to snake case, add convertToSnakeCase: true to the annotation:

@SerdesJson(convertToSnakeCase: true)
class NewsItemScheme {
  late int id;
  late String title;
  late String description;
  late int commentsCount;
}

Rename field #

You can manually specify names for field:

@SerdesJson()
class PayloadScheme {
  late int id;
  late String title;
  late String description;
  @SerdesJsonField(name: 'comments_count')
  late int commentsCount;
}

Use custom suffix #

@SerdesJson(endsWith: 'Response')
class NewsItemResponse {
  late int id;
  late String title;
  late String description;
  late int commentsCount;
}

Optional #

By default all fields are required, and if there will not be a field, then parser will throw the SchemeConsistencyException. To describe optional fields:

@SerdesJson()
class PayloadScheme {
  late Map<String, dynamic>? result;
  late ErrorScheme? error;
}

Enums #

WIP

Unions #

WIP

Type adapters #

WIP

Custom validations #

WIP

To json #

final news = NewsItem(
  id: 1,
  title: 'Some new',
  description: 'Description',
  commentsCount: 12,
);

final json = news.toJson();
final stringJson = news.toStringJson();

From json #

final json = _client.getJsonBody(response);
final jsonString = _client.getStringJsonBody(response);

final news = NewsItem.fromJson(json);
final news = NewsItem.fromStringJson(jsonString);
2
likes
130
points
38
downloads

Publisher

verified publisherandrey.kabylin.ru

Weekly Downloads

Simple and clean json serializer and deserializer.

Repository (GitHub)
View/report issues

Documentation

API reference

License

MIT (license)

Dependencies

flutter

More

Packages that depend on serdes_json