mirror of
https://github.com/JGeek00/adguard-home-manager.git
synced 2025-04-24 07:46:06 +00:00
Extracted dns rewrites
This commit is contained in:
parent
9460da6dcb
commit
5afe912e7e
8 changed files with 80 additions and 99 deletions
|
@ -21,6 +21,7 @@ import 'package:adguard_home_manager/providers/logs_provider.dart';
|
||||||
import 'package:adguard_home_manager/providers/app_config_provider.dart';
|
import 'package:adguard_home_manager/providers/app_config_provider.dart';
|
||||||
import 'package:adguard_home_manager/providers/clients_provider.dart';
|
import 'package:adguard_home_manager/providers/clients_provider.dart';
|
||||||
import 'package:adguard_home_manager/providers/filters_provider.dart';
|
import 'package:adguard_home_manager/providers/filters_provider.dart';
|
||||||
|
import 'package:adguard_home_manager/providers/rewrute_rules_provider.dart';
|
||||||
import 'package:adguard_home_manager/providers/dhcp_provider.dart';
|
import 'package:adguard_home_manager/providers/dhcp_provider.dart';
|
||||||
import 'package:adguard_home_manager/providers/status_provider.dart';
|
import 'package:adguard_home_manager/providers/status_provider.dart';
|
||||||
import 'package:adguard_home_manager/providers/servers_provider.dart';
|
import 'package:adguard_home_manager/providers/servers_provider.dart';
|
||||||
|
@ -45,13 +46,14 @@ void main() async {
|
||||||
|
|
||||||
await dotenv.load(fileName: '.env');
|
await dotenv.load(fileName: '.env');
|
||||||
|
|
||||||
AppConfigProvider appConfigProvider = AppConfigProvider();
|
final AppConfigProvider appConfigProvider = AppConfigProvider();
|
||||||
ServersProvider serversProvider = ServersProvider();
|
final ServersProvider serversProvider = ServersProvider();
|
||||||
StatusProvider statusProvider = StatusProvider();
|
final StatusProvider statusProvider = StatusProvider();
|
||||||
ClientsProvider clientsProvider = ClientsProvider();
|
final ClientsProvider clientsProvider = ClientsProvider();
|
||||||
FilteringProvider filtersProvider = FilteringProvider();
|
final FilteringProvider filtersProvider = FilteringProvider();
|
||||||
DhcpProvider dhcpProvider = DhcpProvider();
|
final DhcpProvider dhcpProvider = DhcpProvider();
|
||||||
LogsProvider logsProvider = LogsProvider();
|
final RewriteRulesProvider rewriteRulesProvider = RewriteRulesProvider();
|
||||||
|
final LogsProvider logsProvider = LogsProvider();
|
||||||
|
|
||||||
DeviceInfoPlugin deviceInfo = DeviceInfoPlugin();
|
DeviceInfoPlugin deviceInfo = DeviceInfoPlugin();
|
||||||
if (Platform.isAndroid) {
|
if (Platform.isAndroid) {
|
||||||
|
@ -116,6 +118,9 @@ void main() async {
|
||||||
ChangeNotifierProvider(
|
ChangeNotifierProvider(
|
||||||
create: ((context) => dhcpProvider)
|
create: ((context) => dhcpProvider)
|
||||||
),
|
),
|
||||||
|
ChangeNotifierProvider(
|
||||||
|
create: ((context) => rewriteRulesProvider)
|
||||||
|
),
|
||||||
ChangeNotifierProxyProvider<StatusProvider, FilteringProvider>(
|
ChangeNotifierProxyProvider<StatusProvider, FilteringProvider>(
|
||||||
create: (context) => filtersProvider,
|
create: (context) => filtersProvider,
|
||||||
update: (context, status, filtering) => filtering!..updateStatus(status),
|
update: (context, status, filtering) => filtering!..updateStatus(status),
|
||||||
|
|
|
@ -1,29 +1,13 @@
|
||||||
import 'dart:convert';
|
|
||||||
|
|
||||||
class RewriteRules {
|
class RewriteRules {
|
||||||
int loadStatus = 0;
|
|
||||||
List<RewriteRulesData>? data;
|
|
||||||
|
|
||||||
RewriteRules({
|
|
||||||
required this.loadStatus,
|
|
||||||
this.data
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
List<RewriteRulesData> rewriteRulesDataFromJson(String str) => List<RewriteRulesData>.from(json.decode(str).map((x) => RewriteRulesData.fromJson(x)));
|
|
||||||
|
|
||||||
String rewriteRulesDataToJson(List<RewriteRulesData> data) => json.encode(List<RewriteRulesData>.from(data.map((x) => x.toJson())));
|
|
||||||
|
|
||||||
class RewriteRulesData {
|
|
||||||
final String domain;
|
final String domain;
|
||||||
final String answer;
|
final String answer;
|
||||||
|
|
||||||
RewriteRulesData({
|
RewriteRules({
|
||||||
required this.domain,
|
required this.domain,
|
||||||
required this.answer,
|
required this.answer,
|
||||||
});
|
});
|
||||||
|
|
||||||
factory RewriteRulesData.fromJson(Map<String, dynamic> json) => RewriteRulesData(
|
factory RewriteRules.fromJson(Map<String, dynamic> json) => RewriteRules(
|
||||||
domain: json["domain"],
|
domain: json["domain"],
|
||||||
answer: json["answer"],
|
answer: json["answer"],
|
||||||
);
|
);
|
||||||
|
|
29
lib/providers/rewrute_rules_provider.dart
Normal file
29
lib/providers/rewrute_rules_provider.dart
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
|
import 'package:adguard_home_manager/constants/enums.dart';
|
||||||
|
import 'package:adguard_home_manager/models/rewrite_rules.dart';
|
||||||
|
|
||||||
|
class RewriteRulesProvider with ChangeNotifier {
|
||||||
|
LoadStatus _loadStatus = LoadStatus.loading;
|
||||||
|
List<RewriteRules>? _rewriteRules;
|
||||||
|
|
||||||
|
LoadStatus get loadStatus {
|
||||||
|
return _loadStatus;
|
||||||
|
}
|
||||||
|
|
||||||
|
List<RewriteRules>? get rewriteRules {
|
||||||
|
return _rewriteRules;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setRewriteRulesData(List<RewriteRules> data) {
|
||||||
|
_rewriteRules = data;
|
||||||
|
notifyListeners();
|
||||||
|
}
|
||||||
|
|
||||||
|
void setRewriteRulesLoadStatus(LoadStatus status, bool notify) {
|
||||||
|
_loadStatus = status;
|
||||||
|
if (notify == true) {
|
||||||
|
notifyListeners();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,7 +1,6 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:sqflite/sqflite.dart';
|
import 'package:sqflite/sqflite.dart';
|
||||||
|
|
||||||
import 'package:adguard_home_manager/models/dhcp.dart';
|
|
||||||
import 'package:adguard_home_manager/models/dns_info.dart';
|
import 'package:adguard_home_manager/models/dns_info.dart';
|
||||||
import 'package:adguard_home_manager/models/rewrite_rules.dart';
|
import 'package:adguard_home_manager/models/rewrite_rules.dart';
|
||||||
import 'package:adguard_home_manager/models/server.dart';
|
import 'package:adguard_home_manager/models/server.dart';
|
||||||
|
@ -18,11 +17,6 @@ class ServersProvider with ChangeNotifier {
|
||||||
List<Server> _serversList = [];
|
List<Server> _serversList = [];
|
||||||
Server? _selectedServer;
|
Server? _selectedServer;
|
||||||
|
|
||||||
final RewriteRules _rewriteRules = RewriteRules(
|
|
||||||
loadStatus: 0, // 0 = loading, 1 = loaded, 2 = error
|
|
||||||
data: null
|
|
||||||
);
|
|
||||||
|
|
||||||
final DnsInfo _dnsInfo = DnsInfo(
|
final DnsInfo _dnsInfo = DnsInfo(
|
||||||
loadStatus: 0, // 0 = loading, 1 = loaded, 2 = error
|
loadStatus: 0, // 0 = loading, 1 = loaded, 2 = error
|
||||||
data: null
|
data: null
|
||||||
|
@ -41,10 +35,6 @@ class ServersProvider with ChangeNotifier {
|
||||||
return _selectedServer;
|
return _selectedServer;
|
||||||
}
|
}
|
||||||
|
|
||||||
RewriteRules get rewriteRules {
|
|
||||||
return _rewriteRules;
|
|
||||||
}
|
|
||||||
|
|
||||||
DnsInfo get dnsInfo {
|
DnsInfo get dnsInfo {
|
||||||
return _dnsInfo;
|
return _dnsInfo;
|
||||||
}
|
}
|
||||||
|
@ -67,18 +57,6 @@ class ServersProvider with ChangeNotifier {
|
||||||
notifyListeners();
|
notifyListeners();
|
||||||
}
|
}
|
||||||
|
|
||||||
void setRewriteRulesData(List<RewriteRulesData> data) {
|
|
||||||
_rewriteRules.data = data;
|
|
||||||
notifyListeners();
|
|
||||||
}
|
|
||||||
|
|
||||||
void setRewriteRulesLoadStatus(int status, bool notify) {
|
|
||||||
_rewriteRules.loadStatus = status;
|
|
||||||
if (notify == true) {
|
|
||||||
notifyListeners();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setDnsInfoData(DnsInfoData data) {
|
void setDnsInfoData(DnsInfoData data) {
|
||||||
_dnsInfo.data = data;
|
_dnsInfo.data = data;
|
||||||
notifyListeners();
|
notifyListeners();
|
||||||
|
|
|
@ -6,7 +6,7 @@ import 'package:flutter_gen/gen_l10n/app_localizations.dart';
|
||||||
import 'package:adguard_home_manager/models/rewrite_rules.dart';
|
import 'package:adguard_home_manager/models/rewrite_rules.dart';
|
||||||
|
|
||||||
class AddDnsRewriteModal extends StatefulWidget {
|
class AddDnsRewriteModal extends StatefulWidget {
|
||||||
final void Function(RewriteRulesData) onConfirm;
|
final void Function(RewriteRules) onConfirm;
|
||||||
final bool dialog;
|
final bool dialog;
|
||||||
|
|
||||||
const AddDnsRewriteModal({
|
const AddDnsRewriteModal({
|
||||||
|
@ -143,7 +143,7 @@ class _AddDnsRewriteModalState extends State<AddDnsRewriteModal> {
|
||||||
? () {
|
? () {
|
||||||
Navigator.pop(context);
|
Navigator.pop(context);
|
||||||
widget.onConfirm(
|
widget.onConfirm(
|
||||||
RewriteRulesData(
|
RewriteRules(
|
||||||
domain: domainController.text,
|
domain: domainController.text,
|
||||||
answer: answerController.text
|
answer: answerController.text
|
||||||
)
|
)
|
||||||
|
|
|
@ -12,52 +12,36 @@ import 'package:adguard_home_manager/screens/settings/dns_rewrites/delete_dns_re
|
||||||
import 'package:adguard_home_manager/services/http_requests.dart';
|
import 'package:adguard_home_manager/services/http_requests.dart';
|
||||||
import 'package:adguard_home_manager/providers/app_config_provider.dart';
|
import 'package:adguard_home_manager/providers/app_config_provider.dart';
|
||||||
import 'package:adguard_home_manager/functions/snackbar.dart';
|
import 'package:adguard_home_manager/functions/snackbar.dart';
|
||||||
|
import 'package:adguard_home_manager/constants/enums.dart';
|
||||||
|
import 'package:adguard_home_manager/providers/rewrute_rules_provider.dart';
|
||||||
import 'package:adguard_home_manager/models/rewrite_rules.dart';
|
import 'package:adguard_home_manager/models/rewrite_rules.dart';
|
||||||
import 'package:adguard_home_manager/providers/servers_provider.dart';
|
import 'package:adguard_home_manager/providers/servers_provider.dart';
|
||||||
import 'package:adguard_home_manager/classes/process_modal.dart';
|
import 'package:adguard_home_manager/classes/process_modal.dart';
|
||||||
|
|
||||||
class DnsRewrites extends StatelessWidget {
|
class DnsRewritesScreen extends StatefulWidget {
|
||||||
const DnsRewrites({Key? key}) : super(key: key);
|
const DnsRewritesScreen({Key? key}) : super(key: key);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
State<DnsRewritesScreen> createState() => _DnsRewritesScreenState();
|
||||||
final serversProvider = Provider.of<ServersProvider>(context);
|
|
||||||
final appConfigProvider = Provider.of<AppConfigProvider>(context);
|
|
||||||
|
|
||||||
return DnsRewritesWidget(
|
|
||||||
serversProvider: serversProvider,
|
|
||||||
appConfigProvider: appConfigProvider,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class DnsRewritesWidget extends StatefulWidget {
|
class _DnsRewritesScreenState extends State<DnsRewritesScreen> {
|
||||||
final ServersProvider serversProvider;
|
|
||||||
final AppConfigProvider appConfigProvider;
|
|
||||||
|
|
||||||
const DnsRewritesWidget({
|
|
||||||
Key? key,
|
|
||||||
required this.serversProvider,
|
|
||||||
required this.appConfigProvider
|
|
||||||
}) : super(key: key);
|
|
||||||
|
|
||||||
@override
|
|
||||||
State<DnsRewritesWidget> createState() => _DnsRewritesWidgetState();
|
|
||||||
}
|
|
||||||
|
|
||||||
class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
|
||||||
Future fetchData() async {
|
Future fetchData() async {
|
||||||
widget.serversProvider.setRewriteRulesLoadStatus(0, false);
|
final rewriteRulesProvider = Provider.of<RewriteRulesProvider>(context, listen: false);
|
||||||
|
final serversProvider = Provider.of<ServersProvider>(context, listen: false);
|
||||||
|
final appConfigProvider = Provider.of<AppConfigProvider>(context, listen: false);
|
||||||
|
|
||||||
final result = await getDnsRewriteRules(server: widget.serversProvider.selectedServer!);
|
rewriteRulesProvider.setRewriteRulesLoadStatus(LoadStatus.loading, false);
|
||||||
|
|
||||||
|
final result = await getDnsRewriteRules(server: serversProvider.selectedServer!);
|
||||||
|
|
||||||
if (result['result'] == 'success') {
|
if (result['result'] == 'success') {
|
||||||
widget.serversProvider.setRewriteRulesData(result['data']);
|
rewriteRulesProvider.setRewriteRulesData(result['data']);
|
||||||
widget.serversProvider.setRewriteRulesLoadStatus(1, true);
|
rewriteRulesProvider.setRewriteRulesLoadStatus(LoadStatus.loaded, true);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
widget.appConfigProvider.addLog(result['log']);
|
appConfigProvider.addLog(result['log']);
|
||||||
widget.serversProvider.setRewriteRulesLoadStatus(2, true);
|
rewriteRulesProvider.setRewriteRulesLoadStatus(LoadStatus.error, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,11 +54,12 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final serversProvider = Provider.of<ServersProvider>(context);
|
final serversProvider = Provider.of<ServersProvider>(context);
|
||||||
|
final rewriteRulesProvider = Provider.of<RewriteRulesProvider>(context);
|
||||||
final appConfigProvider = Provider.of<AppConfigProvider>(context);
|
final appConfigProvider = Provider.of<AppConfigProvider>(context);
|
||||||
|
|
||||||
final width = MediaQuery.of(context).size.width;
|
final width = MediaQuery.of(context).size.width;
|
||||||
|
|
||||||
void deleteDnsRewrite(RewriteRulesData rule) async {
|
void deleteDnsRewrite(RewriteRules rule) async {
|
||||||
ProcessModal processModal = ProcessModal(context: context);
|
ProcessModal processModal = ProcessModal(context: context);
|
||||||
processModal.open(AppLocalizations.of(context)!.deleting);
|
processModal.open(AppLocalizations.of(context)!.deleting);
|
||||||
|
|
||||||
|
@ -86,9 +71,9 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
||||||
processModal.close();
|
processModal.close();
|
||||||
|
|
||||||
if (result['result'] == 'success') {
|
if (result['result'] == 'success') {
|
||||||
List<RewriteRulesData> data = serversProvider.rewriteRules.data!;
|
List<RewriteRules> data = rewriteRulesProvider.rewriteRules!;
|
||||||
data = data.where((item) => item.domain != rule.domain).toList();
|
data = data.where((item) => item.domain != rule.domain).toList();
|
||||||
serversProvider.setRewriteRulesData(data);
|
rewriteRulesProvider.setRewriteRulesData(data);
|
||||||
|
|
||||||
showSnacbkar(
|
showSnacbkar(
|
||||||
appConfigProvider: appConfigProvider,
|
appConfigProvider: appConfigProvider,
|
||||||
|
@ -106,7 +91,7 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void addDnsRewrite(RewriteRulesData rule) async {
|
void addDnsRewrite(RewriteRules rule) async {
|
||||||
ProcessModal processModal = ProcessModal(context: context);
|
ProcessModal processModal = ProcessModal(context: context);
|
||||||
processModal.open(AppLocalizations.of(context)!.addingRewrite);
|
processModal.open(AppLocalizations.of(context)!.addingRewrite);
|
||||||
|
|
||||||
|
@ -118,9 +103,9 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
||||||
processModal.close();
|
processModal.close();
|
||||||
|
|
||||||
if (result['result'] == 'success') {
|
if (result['result'] == 'success') {
|
||||||
List<RewriteRulesData> data = serversProvider.rewriteRules.data!;
|
List<RewriteRules> data = rewriteRulesProvider.rewriteRules!;
|
||||||
data.add(rule);
|
data.add(rule);
|
||||||
serversProvider.setRewriteRulesData(data);
|
rewriteRulesProvider.setRewriteRulesData(data);
|
||||||
|
|
||||||
showSnacbkar(
|
showSnacbkar(
|
||||||
appConfigProvider: appConfigProvider,
|
appConfigProvider: appConfigProvider,
|
||||||
|
@ -139,8 +124,8 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
||||||
}
|
}
|
||||||
|
|
||||||
Widget generateBody() {
|
Widget generateBody() {
|
||||||
switch (serversProvider.rewriteRules.loadStatus) {
|
switch (rewriteRulesProvider.loadStatus) {
|
||||||
case 0:
|
case LoadStatus.loading:
|
||||||
return SizedBox(
|
return SizedBox(
|
||||||
width: double.maxFinite,
|
width: double.maxFinite,
|
||||||
child: Column(
|
child: Column(
|
||||||
|
@ -160,15 +145,15 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
case 1:
|
case LoadStatus.loaded:
|
||||||
if (serversProvider.rewriteRules.data!.isNotEmpty) {
|
if (rewriteRulesProvider.rewriteRules!.isNotEmpty) {
|
||||||
return RefreshIndicator(
|
return RefreshIndicator(
|
||||||
onRefresh: () async {
|
onRefresh: () async {
|
||||||
await fetchData();
|
await fetchData();
|
||||||
},
|
},
|
||||||
child: ListView.builder(
|
child: ListView.builder(
|
||||||
padding: const EdgeInsets.only(top: 0),
|
padding: const EdgeInsets.only(top: 0),
|
||||||
itemCount: serversProvider.rewriteRules.data!.length,
|
itemCount: rewriteRulesProvider.rewriteRules!.length,
|
||||||
itemBuilder: (context, index) => Container(
|
itemBuilder: (context, index) => Container(
|
||||||
padding: const EdgeInsets.symmetric(horizontal: 24, vertical: 10),
|
padding: const EdgeInsets.symmetric(horizontal: 24, vertical: 10),
|
||||||
decoration: BoxDecoration(
|
decoration: BoxDecoration(
|
||||||
|
@ -195,7 +180,7 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
Text(
|
Text(
|
||||||
serversProvider.rewriteRules.data![index].domain,
|
rewriteRulesProvider.rewriteRules![index].domain,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
color: Theme.of(context).colorScheme.onSurface
|
color: Theme.of(context).colorScheme.onSurface
|
||||||
),
|
),
|
||||||
|
@ -213,7 +198,7 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
Text(
|
Text(
|
||||||
serversProvider.rewriteRules.data![index].answer,
|
rewriteRulesProvider.rewriteRules![index].answer,
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
color: Theme.of(context).colorScheme.onSurface
|
color: Theme.of(context).colorScheme.onSurface
|
||||||
),
|
),
|
||||||
|
@ -227,7 +212,7 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
||||||
showDialog(
|
showDialog(
|
||||||
context: context,
|
context: context,
|
||||||
builder: (context) => DeleteDnsRewrite(
|
builder: (context) => DeleteDnsRewrite(
|
||||||
onConfirm: () => deleteDnsRewrite(serversProvider.rewriteRules.data![index])
|
onConfirm: () => deleteDnsRewrite(rewriteRulesProvider.rewriteRules![index])
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
},
|
},
|
||||||
|
@ -251,7 +236,7 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
case 2:
|
case LoadStatus.error:
|
||||||
return SizedBox(
|
return SizedBox(
|
||||||
width: double.maxFinite,
|
width: double.maxFinite,
|
||||||
child: Column(
|
child: Column(
|
||||||
|
|
|
@ -177,7 +177,7 @@ class SettingsWidget extends StatelessWidget {
|
||||||
title: AppLocalizations.of(context)!.dnsRewrites,
|
title: AppLocalizations.of(context)!.dnsRewrites,
|
||||||
subtitle: AppLocalizations.of(context)!.dnsRewritesDescription,
|
subtitle: AppLocalizations.of(context)!.dnsRewritesDescription,
|
||||||
thisItem: 5,
|
thisItem: 5,
|
||||||
screenToNavigate: const DnsRewrites(),
|
screenToNavigate: const DnsRewritesScreen(),
|
||||||
),
|
),
|
||||||
if (serversProvider.updateAvailable.data != null) settingsTile(
|
if (serversProvider.updateAvailable.data != null) settingsTile(
|
||||||
icon: Icons.system_update_rounded,
|
icon: Icons.system_update_rounded,
|
||||||
|
|
|
@ -1528,8 +1528,8 @@ Future getDnsRewriteRules({
|
||||||
|
|
||||||
if (result['hasResponse'] == true) {
|
if (result['hasResponse'] == true) {
|
||||||
if (result['statusCode'] == 200) {
|
if (result['statusCode'] == 200) {
|
||||||
final List<RewriteRulesData> data = List<RewriteRulesData>.from(
|
final List<RewriteRules> data = List<RewriteRules>.from(
|
||||||
jsonDecode(result['body']).map((item) => RewriteRulesData.fromJson(item))
|
jsonDecode(result['body']).map((item) => RewriteRules.fromJson(item))
|
||||||
);
|
);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
|
Loading…
Add table
Reference in a new issue