platform/packages/mongo
Patrick Stewart e4775d1ea9
Some checks are pending
Angel3 CI / Validate framework package (push) Waiting to run
Angel3 CI / Validate ORM packages (push) Waiting to run
Remove: deleting melos jetbrains artifacts
2024-10-01 20:11:25 -07:00
..
example Added authentication 2024-07-05 00:04:58 +08:00
lib Updated mongoDB 2024-06-23 11:15:41 +08:00
test Added authentication 2024-07-05 00:04:58 +08:00
.gitignore Cleanup unused 2022-04-23 16:51:55 +08:00
.pubignore Cleanup unused 2022-04-23 16:51:55 +08:00
analysis_options.yaml Updated linter to package:lints 2021-09-25 14:32:32 +08:00
CHANGELOG.md Updated mongodb 2024-07-06 18:18:14 +08:00
LICENSE Updated linter to package:lints 2021-09-25 14:32:32 +08:00
pubspec.yaml Updated mongodb 2024-07-06 18:18:14 +08:00
README.md Replaced Gitter with Discord chat 2024-07-07 23:02:49 +08:00

Angel3 Mongo

Pub Version (including pre-releases) Null Safety Discord License

MongoDB-enabled services for the Angel3 framework.

Installation

Add the following to your pubspec.yaml:

dependencies:
  angel3_mongo: ^8.0.0

Usage

This library exposes one main class: MongoService.

Model

Model is class with no real functionality; however, it represents a basic document, and your services should host inherited classes. Other Angel service providers host Model as well, so you will easily be able to modify your application if you ever switch databases.

class User extends Model {
  String username;
  String password;
}

void main() async {
    var db = Db('mongodb://localhost:27017/local');
    await db.open();
    
    var service = app.use('/api/users', MongoService(db.collection("users")));
    
    service.afterCreated.listen((event) {
        print("New user: ${event.result}");
    });
}

MongoService

This class interacts with DbCollection (from mongo_dart) and serializing data to and from Maps.

Querying

You can query these services as follows:

    /path/to/service?foo=bar

The above will query the database to find records where 'foo' equals 'bar'. The former will sort result in ascending order of creation, and so will the latter.

    List queried = await MyService.index({r"$query": where.id(ObjectId.fromHexString("some hex string"})));

And, you can use mongo_dart queries. Just pass it as query within params.

See the tests for more usage examples.

Important Notes

When connecting to a locally installed instance of MongoDB or docker based MongoDB with authentication enabled, the following connection string is not supported yet.

  var db = Db('mongodb://<username>:<password>@localhost:27017/testDB');
  await db.open();

Use the following instead. By default the user access information is stored in admin database.

  var db = Db('mongodb://localhost:27017/testDB');
  await db.open();
  await db.authenticate("<username>", "<password>", authDb: "admin");

Where

  • <username> is MongoDB username
  • <password> is MongoDB password