Skip to content

Commit

Permalink
docs(NODE-6302): add SerializableTypes to migration guide (#716)
Browse files Browse the repository at this point in the history
Co-authored-by: Daria Pardue <[email protected]>
  • Loading branch information
nbbeeken and dariakp authored Sep 11, 2024
1 parent 5a8900e commit e584fbb
Showing 1 changed file with 13 additions and 0 deletions.
13 changes: 13 additions & 0 deletions docs/upgrade-to-v5.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
- [Other Changes](#other-changes)
- [`serializeFunctions` bug fix](#serializefunctions-bug-fix)
- [TS "target" set to es2020](#ts-target-set-to-es2020)
- [Removed SerializableTypes](#removed-serializabletypes)

## About

Expand Down Expand Up @@ -313,3 +314,15 @@ import { serialize } from 'bson5';
serialize({ _id: new ObjectId() });
// Uncaught BSONVersionError: Unsupported BSON version, bson types must be from bson 5.0 or later
```

### Removed SerializableTypes

```ts
export type JSONPrimitive = string | number | boolean | null;
export type SerializableTypes = Document | Array<JSONPrimitive | Document> | JSONPrimitive;
```

`SerializableTypes` is removed in v5 due to its inaccuracy and inconvenience when working with return type of `EJSON.parse()`.
This type does not contain all possible outputs from this function and it cannot be conveniently related to a custom declared type.
`EJSON.parse` and `EJSON.stringify` now accept `any` in alignment with `JSON`'s corresponding APIs.
For users that desire type strictness it is recommended to wrap these APIs with type annotations that take/return `unknown` since that generally forces better narrowing logic than `SerializableTypes` would have prompted.

0 comments on commit e584fbb

Please sign in to comment.