
- Complete NestJS TypeScript implementation with WebSocket support - Direct messaging (DM) and group chat functionality - End-to-end encryption with AES encryption and key pairs - Media file support (images, videos, audio, documents) up to 100MB - Push notifications with Firebase Cloud Messaging integration - Mention alerts and real-time typing indicators - User authentication with JWT and Passport - SQLite database with TypeORM entities and relationships - Comprehensive API documentation with Swagger/OpenAPI - File upload handling with secure access control - Online/offline status tracking and presence management - Message editing, deletion, and reply functionality - Notification management with automatic cleanup - Health check endpoint for monitoring - CORS configuration for cross-origin requests - Environment-based configuration management - Structured for Flutter SDK integration Features implemented: ✅ Real-time messaging with Socket.IO ✅ User registration and authentication ✅ Direct messages and group chats ✅ Media file uploads and management ✅ End-to-end encryption ✅ Push notifications ✅ Mention alerts ✅ Typing indicators ✅ Message read receipts ✅ Online status tracking ✅ File access control ✅ Comprehensive API documentation Ready for Flutter SDK development and production deployment.
74 lines
2.4 KiB
Markdown
74 lines
2.4 KiB
Markdown
# passport-local
|
|
|
|
[](https://travis-ci.org/jaredhanson/passport-local)
|
|
[](https://coveralls.io/r/jaredhanson/passport-local)
|
|
[](https://codeclimate.com/github/jaredhanson/passport-local)
|
|
[](https://david-dm.org/jaredhanson/passport-local)
|
|
[](https://www.gittip.com/jaredhanson/)
|
|
|
|
|
|
[Passport](http://passportjs.org/) strategy for authenticating with a username
|
|
and password.
|
|
|
|
This module lets you authenticate using a username and password in your Node.js
|
|
applications. By plugging into Passport, local authentication can be easily and
|
|
unobtrusively integrated into any application or framework that supports
|
|
[Connect](http://www.senchalabs.org/connect/)-style middleware, including
|
|
[Express](http://expressjs.com/).
|
|
|
|
## Install
|
|
|
|
$ npm install passport-local
|
|
|
|
## Usage
|
|
|
|
#### Configure Strategy
|
|
|
|
The local authentication strategy authenticates users using a username and
|
|
password. The strategy requires a `verify` callback, which accepts these
|
|
credentials and calls `done` providing a user.
|
|
|
|
passport.use(new LocalStrategy(
|
|
function(username, password, done) {
|
|
User.findOne({ username: username }, function (err, user) {
|
|
if (err) { return done(err); }
|
|
if (!user) { return done(null, false); }
|
|
if (!user.verifyPassword(password)) { return done(null, false); }
|
|
return done(null, user);
|
|
});
|
|
}
|
|
));
|
|
|
|
#### Authenticate Requests
|
|
|
|
Use `passport.authenticate()`, specifying the `'local'` strategy, to
|
|
authenticate requests.
|
|
|
|
For example, as route middleware in an [Express](http://expressjs.com/)
|
|
application:
|
|
|
|
app.post('/login',
|
|
passport.authenticate('local', { failureRedirect: '/login' }),
|
|
function(req, res) {
|
|
res.redirect('/');
|
|
});
|
|
|
|
## Examples
|
|
|
|
For complete, working examples, refer to the multiple [examples](https://github.com/jaredhanson/passport-local/tree/master/examples) included.
|
|
|
|
## Tests
|
|
|
|
$ npm install
|
|
$ npm test
|
|
|
|
## Credits
|
|
|
|
- [Jared Hanson](http://github.com/jaredhanson)
|
|
|
|
## License
|
|
|
|
[The MIT License](http://opensource.org/licenses/MIT)
|
|
|
|
Copyright (c) 2011-2014 Jared Hanson <[http://jaredhanson.net/](http://jaredhanson.net/)>
|