mirror of
https://github.com/immich-app/immich.git
synced 2025-01-04 02:46:47 +01:00
9bce3417e9
* feat(server): add `react-mail` as mail template engine and `nodemailer` * feat(server): add `smtp` related configs to `SystemConfig` * feat(web): add page for SMTP settings * feat(server): add `react-email.adapter` This adapter render the React-Email into HTML and plain/text email. The output is set as the body of the email. * feat(server): add `MailRepository` and `MailService` Allow to use the NestJS-modules-mailer module to send SMTP emails. This is the base transport for the `NotificationRepository` * feat(server): register the job dispatcher and Job for async email This allows to queue email sending jobs for the `EmailService`. * feat(server): add `NotificationRepository` and `NotificationService` This act as a middleware to properly route the notification to the right transport. As POC I've only implemented a simple SMTP transport. * feat(server): add `welcome` email template * feat(server): add the first notification on `createUser` in `UserService` This trigger an event for the `NotificationRepository` that once processes by using the global config and per-user config will carry the payload to the right notification transport. * chore: clean up * chore: clean up web * fix: type errors" * fix package lock * fix mail sending, option to ignore certs * chore: open api * chore: clean up * remove unused import * feat: email feature flag * chore: remove unused interface * small styling --------- Co-authored-by: Jason Rasmussen <jrasm91@gmail.com> Co-authored-by: Daniel Dietzler <mail@ddietzler.dev> Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
82 lines
1.7 KiB
Dart
Generated
82 lines
1.7 KiB
Dart
Generated
//
|
|
// AUTO-GENERATED FILE, DO NOT MODIFY!
|
|
//
|
|
// @dart=2.12
|
|
|
|
// ignore_for_file: unused_element, unused_import
|
|
// ignore_for_file: always_put_required_named_parameters_first
|
|
// ignore_for_file: constant_identifier_names
|
|
// ignore_for_file: lines_longer_than_80_chars
|
|
|
|
import 'package:openapi/api.dart';
|
|
import 'package:test/test.dart';
|
|
|
|
// tests for ServerFeaturesDto
|
|
void main() {
|
|
// final instance = ServerFeaturesDto();
|
|
|
|
group('test ServerFeaturesDto', () {
|
|
// bool configFile
|
|
test('to test the property `configFile`', () async {
|
|
// TODO
|
|
});
|
|
|
|
// bool email
|
|
test('to test the property `email`', () async {
|
|
// TODO
|
|
});
|
|
|
|
// bool facialRecognition
|
|
test('to test the property `facialRecognition`', () async {
|
|
// TODO
|
|
});
|
|
|
|
// bool map
|
|
test('to test the property `map`', () async {
|
|
// TODO
|
|
});
|
|
|
|
// bool oauth
|
|
test('to test the property `oauth`', () async {
|
|
// TODO
|
|
});
|
|
|
|
// bool oauthAutoLaunch
|
|
test('to test the property `oauthAutoLaunch`', () async {
|
|
// TODO
|
|
});
|
|
|
|
// bool passwordLogin
|
|
test('to test the property `passwordLogin`', () async {
|
|
// TODO
|
|
});
|
|
|
|
// bool reverseGeocoding
|
|
test('to test the property `reverseGeocoding`', () async {
|
|
// TODO
|
|
});
|
|
|
|
// bool search
|
|
test('to test the property `search`', () async {
|
|
// TODO
|
|
});
|
|
|
|
// bool sidecar
|
|
test('to test the property `sidecar`', () async {
|
|
// TODO
|
|
});
|
|
|
|
// bool smartSearch
|
|
test('to test the property `smartSearch`', () async {
|
|
// TODO
|
|
});
|
|
|
|
// bool trash
|
|
test('to test the property `trash`', () async {
|
|
// TODO
|
|
});
|
|
|
|
|
|
});
|
|
|
|
}
|