2021-06-26 12:06:30 +00:00
# File Service for Angel3
2022-01-04 12:03:52 +00:00
data:image/s3,"s3://crabby-images/0dca7/0dca7d9ae04e9e16d20ba4caf6991fb4fb7eab27" alt="Pub Version (including pre-releases) "
2021-06-10 08:47:05 +00:00
[data:image/s3,"s3://crabby-images/fb323/fb32333d9edbb854cf31aef175a56bba8764eefc" alt="Null Safety "](https://dart.dev/null-safety)
[data:image/s3,"s3://crabby-images/ed53c/ed53ccc0d55f52cbdfd4b60248c5c6206a84c479" alt="Gitter "](https://gitter.im/angel_dart/discussion)
2022-01-04 12:03:52 +00:00
[data:image/s3,"s3://crabby-images/60424/60424a6f1f9e21cae5d8b2ca9203d16f2c867ac5" alt="License "](https://github.com/dukefirehawk/angel/tree/master/packages/file_service/LICENSE)
2021-06-10 08:47:05 +00:00
2022-01-04 12:03:52 +00:00
Angel service that persists data to a file on disk, stored as a JSON list. It uses a simple mutex to prevent race conditions, and caches contents in memory until changes are made.
2017-06-13 16:55:07 +00:00
The file will be created on read/write, if it does not already exist.
2022-01-04 12:03:52 +00:00
This package is useful in development, as it prevents you from having to install an external database to run your server.
2017-06-13 16:55:07 +00:00
2022-01-04 12:03:52 +00:00
When running a multi-threaded server, there is no guarantee that file operations will be mutually excluded. Thus, try to only use this one a single-threaded server if possible, or one with very low load.
2017-06-13 16:55:07 +00:00
While not necessarily *slow* , this package makes no promises about performance.
2021-06-26 12:06:30 +00:00
## Usage
2017-06-13 16:55:07 +00:00
```dart
configureServer(Angel app) async {
// Just like a normal service
2017-12-21 06:37:03 +00:00
app.use(
'/api/todos',
2022-01-04 12:03:52 +00:00
JsonFileService(
2017-12-21 06:37:03 +00:00
const LocalFileSystem().file('todos_db.json')
),
);
2017-06-13 16:55:07 +00:00
}
2021-06-26 12:06:30 +00:00
```