- actions/checkout@v3 update
- package update
- fix pipeline quoting issues
- fix pipeline path, again
- fix pipeline path
- update workflows to use official community actions
- package update
- common fragments overlap fix
- package update
- package update
- operation name constant
- generate_queries flag to signify if query documents and operation names should be generated
- operation name constant
- package updates
- there is no need to use
fragments_glob
any more just specify the glob which will include all your graphql docs
- allow using file fragments and common fragments at the same time
- fix comigor#373
- performance improvements-2
- performance improvements
- package update
- Fix README
- Format some files to improve
pana
score
- package update
- Update examples and make sure they all work
- Add throwable errors for missing root object and used query fragments
- Update package to use official Dart lint following this guide
- package update
- support of
fragments_glob
at schema level
- fix for comigor#341
- duplicated $$typename fix
BREAKING CHANGE
- changed the naming of scalar mappers
- example indentaion fix
- lazy canonical visitors
- Update build_runner version in examples
- Update Pokemon API in pokemon example
- Update WebSocketLink in hasura example
- Support gql context in client's execute and stream methods
- fix for comigor#177
- package update
- document generation fix for comigor#307
- union generation fix for comigor#284
- nullable scalar_mapping types
- packages update
- config file error handling
- packages update
- github example fix
- pokemon example fix
- hasura example fix
- graphbrainz example fix
- packages update
- null-safe tests
- document generated in separate variable for easier usage
- package nnbd migraion
MAJOR BREAKING CHANGE
- Code generated by Artemis is now nnbd-compliant
- Add codespaces folder
- Allow for auto generated response and inputs to extend JsonSerializable
- bugfix of append typename - common fragments
- bugfix of append typename
- Append typename flag
- Merging beta into master
- add unknownEnumValue on list enums comigor#246
- Add test case, warning to README, fix CI pipeline
- Update dependencies versions
- package updates and one test fix
- simple naming schema fix comigor#226
- Override annotation fix
- Package updates
- input underscore bugfix comigor#223
- Subscription test added
- Readme fix
- Fixed
ignore_for_file
documentation.
- Added
ignore_for_file
option to ignore linter rules on generated files.
- improved canonical types handling
- Package updates
- Fixed
toJson() doesn't remove "kw$" prefix
- test fix
- fix for multiple schema_mapping
- analyzer and linter warnings fix
- uppercase keyword fix
- pubspec fix
- test fix
- nnbd preparation
- allow multiple operations per file
- performance improvements - scan schema for canonical types only once
- enum name pascal casing.
- Add deprecated annotations in fields.
- Build type name recursively, considering casing changes.
- Mass package update
- Centralize naming transformations; make types PascalCase and fields camelCase.
- Recursively consider input lists.
- Do not throw on unused scalars.
MAJOR BREAKING CHANGE
- all starting underscores are replaced with $
__typename
field replaced with$$typename
- enums are named according to Dart spec
- fields similar to Dart keywords are prefixed with
kw$
- Check for more error causes and throw, explaining the error.
MAJOR BREAKING CHANGE
We've found a regression on 6.1.0-beta.1
, which sends Enums as camelCase to
the server, when they should be sent as SCREAMING_SNAKE_CASE.
- Reverts
6.1.0-beta.1
.
- Improve actions and check pipeline output.
- Short-circuit input object generation on recursive detection
MAJOR BREAKING CHANGE
- Convert enum casing to camel case.
- Convert
ClassProperty
annotation item toList<String>
.
- Duplication bug fix
- Added the exception for the case when
fragment_glob
leads to query files fragments ignore.
- Adapt Artemis to subscriptions and create an example
- Fix for the interfaces which uses fragments from fragments_glob
- Hide build logs under
--verbose
flag
- Include coercers annotations on custom scalars on input objects.
- Properly consider "sub-fragments" on class generation.
- Fix generation of custom scalars and its functions.
- Fix invalid reference to class on Query generations.
- End forwarder file with a newline.
MAJOR BREAKING CHANGE
- Generate canonical objects (enums and input objects) with their original
names on GraphQL. Fragments are also generated with their own names (plus the
Mixin
prefix, for now). - Make it possible to select a naming scheme to be used for generate the class
names.
pathedWithTypes
is the default for retrocompatibility, where the names of previous types are used as prefix of the next class. This can generate duplication on certain schemas. WithpathedWithFields
, the names of previous fields are used as prefix of the next class and withsimple
, only the actual GraphQL class nameis considered. See discussion on #90 and #96 for more information.
- Add
.graphql.
to outputted files path, in a non-breaking change way: a "forwarder" file will be generated to make it retro-compatible when a configurated output doesn't end with.graphql.dart
.
- Update CI to include beta branch.
- Update examples to match latest changes.
- Use default names for query/mutation root when SDL does not declare
schema
.
- Fix generation of recursive input objects introduced by 5.0.0.
MAJOR BREAKING CHANGE
In this version we moved from json
to graphql
(SDL) schema parsing.
This allowed us to get rid off ±1200 lines of code which makes the
project support much easier. The test files with schema definitions
became more clear and human readable.
If you already have your schema in SDL format, just point to it in build.yaml
.
If not, use this snippet
(from this Apollo article) or online helpers like
this one to convert from one to another.
- Only add unknownEnumValue on non-list enums
- Consider all classes to include reference to meta package
- Look at mutation root when generating a mutation
MAJOR BREAKING CHANGE
This version completely refactors how Artemis generate code (by finally
using the implementation of visitor pattern provided by gql
). On top of that,
I've decided to do other major breaking changes to make code cleaner and more
maintainable. Listed:
add_query_prefix
doesn't exist anymore (it's now the default to generate classes with its "path" from the query), e.g., this query'scity
field will be typed asCityName$QueryRoot$User$Address$City
:This change was also done to tip users to NOT use those generated queries directly on their code, to avoid coupling them to your business logic.query city_name { user { address { city { name } } } }
custom_parser_import
was moved to inside a ScalarMap, anduse_custom_parser
was removed.resolve_type_field
option was renamed totype_name_field
, as__typename
is the correct field name (by GraphQL spec).- Classes generated for mutation will have a
Mutation
suffix, as queries already haveQuery
suffix. - Change pre-generation data classes constructors to named parameters, so if
you're using
GraphQLQueryBuilder.onBuild
, it will break.
And also:
- Add more logs and errors while generating code, to help debugging.
- Add more/refactor tests.
- Add a GitHub example.
TODO:
- re-add more logs
- clean options (?)
- prefix every class with
$
(?) - refactor class naming variables
- review readme and changelog
- Fix unknown enum: add prefix
- Make enums loose. When unknown values are provided into an enum, it will fall back to a custom
ARTEMIS_UNKNOWN
value avoiding breaking/crashing the client.
- Allow to dispose
ArtemisClient
underlining http client when possible
- BREAKING: Marks non nullable input field as
@required
#68
- Make lists as input objects work again
- Display error on types not found on schema
- Add "Articles and videos" category on README
- Share fragments between queries and schemas (see
fragments_glob
) #65
- Add missing prefix to generated enums
- Bump equatable/gql suite, refine GitHub actions
- Bump json_serializable/json_annotation
- Properly consider Union types on generation
- Fix GitHub actions deploy pipeline
- Make sure artemis depends on json_annotation
- Generate fragments as mixins
- README updates
- Add missing prefix to interfaces
- Perserve the query name casing
- Bump
gql
package
- Bump
gql
package
- Generate every field of input objects
- Support
__schema
key under the data field or on root ofschema.json
.
- Loosen up dependencies to make it work again with Flutter
beta
channel
- BREAKING: move
GraphQLError
topackage:gql
. If you don't use it, or just reference it indirectly, it will not be breaking, but a major will be bumped anyway, just for sure. - Upgrade
package:gql
to version0.7.4
- Build GQL AST into generated Dart code instead of the raw string
- Use
Link
frompackage:gql/link
as the execution interface ofArtemisClient
- Use
package:gql_dedupe_link
andpackage:gql_http_link
as the default links
- Add a test to guarantee query inputs can be lists
- Disable implicit casts
- Avoid double-parsing the source string
- Differentiate lists from named types when looping through variables
- Consider nullable operation name when defining query name
- Upgrade
gql
to version0.2.0
to get rid of direct dependency onsource_span
and for better parsing errors. - Filter for
SchemaMap
withoutput
when generating code
- Breaking: Add required
output
option toSchemaMap
- Make Artemis a
$lib$
synthetic generator - Add
add_query_prefix
option toSchemaMap
- Make generated classes a mixin of
Equatable
, meaning they can be easily comparable with==
- Include pubspec.lock files of examples
- Replace
graphql_parser
withgql
package
- Add most documentation
- Increase pana grade (health and maintenance)
- Fix some stuff related to importing http on client
- Start using
code_builder
to better generate Dart code
- Allow scalar mappings to include imports for types
- Decode HTTP response as UTF-8 on execute helper.
- Export common used files on default package route (
package:artemis/artemis.dart
) - Use single schemaMap globbing stream to make sure only one schema will be found
- Add missing changelog
- Test new github actions
- Add new generators to GraphQLQuery and QueryArguments
- Fix toJson() on JsonSerializable classes (for nested entities)
- [BREAKING] Remove the
execute*
functions generations, to use instead the genericArtemisClient
class that should receive a GraphQLQuery generated subclass.
Set HTTP headers only when using default HTTP client.
Completely overhaul how this works.
Artemis won't generate a full schema typing anymore. Instead, it will use the schema to generate typings from a specific query or mutation. It will also create helper functions to execute those queries. See README for more info.
This is totally a breaking change but as this library is still on alpha, I should keep it under 1.0.
- Make objects that implement interfaces override resolveType
- Improve package score
- Enable tests on pipeline
- "Fix" json_serializable dependency
- Add tests
- Generate union types as inheritance
- Generate interface types as implementation
- Make generated code choose inheritance
- First release
- No tests
- No documentation
- Parse complex GraphQL schemas (incorrectly, now I know)
- Parse all GraphQL types types (union, interface, enum, input object, object, scalar, list, non null)
- Consider custom scalars
- Not even compile from scratch
- Lot of bugs