🐛 Bug fixes
This commit is contained in:
parent
5ce6543275
commit
08d0a99b10
@ -4,6 +4,7 @@ import 'package:flutter/material.dart';
|
|||||||
import 'package:flutter_local_notifications/flutter_local_notifications.dart';
|
import 'package:flutter_local_notifications/flutter_local_notifications.dart';
|
||||||
import 'package:livekit_client/livekit_client.dart';
|
import 'package:livekit_client/livekit_client.dart';
|
||||||
import 'package:permission_handler/permission_handler.dart';
|
import 'package:permission_handler/permission_handler.dart';
|
||||||
|
import 'package:solian/models/packet.dart';
|
||||||
import 'package:solian/models/pagination.dart';
|
import 'package:solian/models/pagination.dart';
|
||||||
import 'package:solian/providers/auth.dart';
|
import 'package:solian/providers/auth.dart';
|
||||||
import 'package:solian/utils/services_url.dart';
|
import 'package:solian/utils/services_url.dart';
|
||||||
@ -17,8 +18,7 @@ class NotifyProvider extends ChangeNotifier {
|
|||||||
|
|
||||||
List<model.Notification> notifications = List.empty(growable: true);
|
List<model.Notification> notifications = List.empty(growable: true);
|
||||||
|
|
||||||
final FlutterLocalNotificationsPlugin localNotify =
|
final FlutterLocalNotificationsPlugin localNotify = FlutterLocalNotificationsPlugin();
|
||||||
FlutterLocalNotificationsPlugin();
|
|
||||||
|
|
||||||
NotifyProvider() {
|
NotifyProvider() {
|
||||||
initNotify();
|
initNotify();
|
||||||
@ -32,10 +32,8 @@ class NotifyProvider extends ChangeNotifier {
|
|||||||
DarwinNotificationCategory('general'),
|
DarwinNotificationCategory('general'),
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
const linuxSettings =
|
const linuxSettings = LinuxInitializationSettings(defaultActionName: 'Open notification');
|
||||||
LinuxInitializationSettings(defaultActionName: 'Open notification');
|
const InitializationSettings initializationSettings = InitializationSettings(
|
||||||
const InitializationSettings initializationSettings =
|
|
||||||
InitializationSettings(
|
|
||||||
android: androidSettings,
|
android: androidSettings,
|
||||||
iOS: darwinSettings,
|
iOS: darwinSettings,
|
||||||
macOS: darwinSettings,
|
macOS: darwinSettings,
|
||||||
@ -58,19 +56,16 @@ class NotifyProvider extends ChangeNotifier {
|
|||||||
var uri = getRequestUri('passport', '/api/notifications?skip=0&take=25');
|
var uri = getRequestUri('passport', '/api/notifications?skip=0&take=25');
|
||||||
var res = await auth.client!.get(uri);
|
var res = await auth.client!.get(uri);
|
||||||
if (res.statusCode == 200) {
|
if (res.statusCode == 200) {
|
||||||
final result =
|
final result = PaginationResult.fromJson(jsonDecode(utf8.decode(res.bodyBytes)));
|
||||||
PaginationResult.fromJson(jsonDecode(utf8.decode(res.bodyBytes)));
|
notifications = result.data?.map((x) => model.Notification.fromJson(x)).toList() ?? List.empty(growable: true);
|
||||||
notifications =
|
|
||||||
result.data?.map((x) => model.Notification.fromJson(x)).toList() ??
|
|
||||||
List.empty(growable: true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
notifyListeners();
|
notifyListeners();
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<WebSocketChannel?> connect(AuthProvider auth) async {
|
Future<void> connect(AuthProvider auth) async {
|
||||||
if (auth.client == null) await auth.loadClient();
|
if (auth.client == null) await auth.loadClient();
|
||||||
if (!await auth.isAuthorized()) return null;
|
if (!await auth.isAuthorized()) return;
|
||||||
|
|
||||||
await auth.client!.refreshToken(auth.client!.currentRefreshToken!);
|
await auth.client!.refreshToken(auth.client!.currentRefreshToken!);
|
||||||
|
|
||||||
@ -80,15 +75,25 @@ class NotifyProvider extends ChangeNotifier {
|
|||||||
host: ori.host,
|
host: ori.host,
|
||||||
port: ori.port,
|
port: ori.port,
|
||||||
path: ori.path,
|
path: ori.path,
|
||||||
queryParameters: {
|
queryParameters: {'tk': Uri.encodeComponent(auth.client!.currentToken!)},
|
||||||
'tk': Uri.encodeComponent(auth.client!.currentToken!)
|
|
||||||
},
|
|
||||||
);
|
);
|
||||||
|
|
||||||
final channel = WebSocketChannel.connect(uri);
|
final channel = WebSocketChannel.connect(uri);
|
||||||
await channel.ready;
|
await channel.ready;
|
||||||
|
|
||||||
return channel;
|
channel.stream.listen(
|
||||||
|
(event) {
|
||||||
|
final result = NetworkPackage.fromJson(jsonDecode(event));
|
||||||
|
switch (result.method) {
|
||||||
|
case 'notifications.new':
|
||||||
|
final result = model.Notification.fromJson(jsonDecode(event));
|
||||||
|
onRemoteMessage(result);
|
||||||
|
notifyMessage(result.subject, result.content);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onError: (_, __) => connect(auth),
|
||||||
|
onDone: () => connect(auth),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
void onRemoteMessage(model.Notification item) {
|
void onRemoteMessage(model.Notification item) {
|
||||||
|
@ -32,22 +32,12 @@ class _NotificationNotifierState extends State<NotificationNotifier> {
|
|||||||
final nty = context.read<NotifyProvider>();
|
final nty = context.read<NotifyProvider>();
|
||||||
|
|
||||||
if (await auth.isAuthorized()) {
|
if (await auth.isAuthorized()) {
|
||||||
nty.fetch(auth);
|
if (auth.client == null) {
|
||||||
nty.connect(auth).then((snapshot) {
|
await auth.loadClient();
|
||||||
snapshot!.stream.listen(
|
|
||||||
(event) {
|
|
||||||
final result = NetworkPackage.fromJson(jsonDecode(event));
|
|
||||||
switch (result.method) {
|
|
||||||
case 'notifications.new':
|
|
||||||
final result = model.Notification.fromJson(jsonDecode(event));
|
|
||||||
nty.onRemoteMessage(result);
|
|
||||||
nty.notifyMessage(result.subject, result.content);
|
|
||||||
}
|
}
|
||||||
},
|
|
||||||
onError: (_, __) => connect(),
|
nty.fetch(auth);
|
||||||
onDone: () => connect(),
|
nty.connect(auth);
|
||||||
);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
notify.close();
|
notify.close();
|
||||||
|
Loading…
Reference in New Issue
Block a user