Added delete dns rewrite rule

This commit is contained in:
Juan Gilsanz Polo 2022-10-15 20:20:35 +02:00
parent 79be1cca75
commit 9187521a70
5 changed files with 194 additions and 54 deletions

View file

@ -384,5 +384,9 @@
"loadingRewriteRules": "Loading rewrite rules...", "loadingRewriteRules": "Loading rewrite rules...",
"rewriteRulesNotLoaded": "DNS rewrite rules could not be loaded.", "rewriteRulesNotLoaded": "DNS rewrite rules could not be loaded.",
"noRewriteRules": "No DNS rewrite rules", "noRewriteRules": "No DNS rewrite rules",
"answer": "Answer" "answer": "Answer",
"deleteDnsRewrite": "Delete DNS rewrite",
"deleteDnsRewriteMessage": "Are you sure you want to delete this DNS rewrite? This action cannot be undone.",
"dnsRewriteRuleDeleted": "DNS rewrite rule deleted successfully",
"dnsRewriteRuleNotDeleted": "The DNS rewrite rule could not be deleted"
} }

View file

@ -384,5 +384,9 @@
"loadingRewriteRules": "Cargando reescrituras DNS...", "loadingRewriteRules": "Cargando reescrituras DNS...",
"rewriteRulesNotLoaded": "No se han podido cargar las reescrituras DNS.", "rewriteRulesNotLoaded": "No se han podido cargar las reescrituras DNS.",
"noRewriteRules": "No hay reescrituras DNS.", "noRewriteRules": "No hay reescrituras DNS.",
"answer": "Respuesta" "answer": "Respuesta",
"deleteDnsRewrite": "Eliminar reescritura DNS",
"deleteDnsRewriteMessage": "¿Estás seguro que deseas eliminar esta reescritura DNS? Esta acción no se puede deshacer.",
"dnsRewriteRuleDeleted": "Reescritura DNS eliminada correctamente",
"dnsRewriteRuleNotDeleted": "La reescritura DNS no pudo ser eliminada"
} }

View file

@ -0,0 +1,44 @@
import 'package:flutter/material.dart';
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
class DeleteDnsRewrite extends StatelessWidget {
final void Function() onConfirm;
const DeleteDnsRewrite({
Key? key,
required this.onConfirm
}) : super(key: key);
@override
Widget build(BuildContext context) {
return AlertDialog(
title: Column(
children: [
const Icon(
Icons.delete_rounded,
size: 26,
),
const SizedBox(height: 20),
Text(
AppLocalizations.of(context)!.deleteDnsRewrite,
textAlign: TextAlign.center,
)
],
),
content: Text(AppLocalizations.of(context)!.deleteDnsRewriteMessage),
actions: [
TextButton(
onPressed: () => Navigator.pop(context),
child: Text(AppLocalizations.of(context)!.cancel)
),
TextButton(
onPressed: () {
onConfirm();
Navigator.pop(context);
},
child: Text(AppLocalizations.of(context)!.confirm)
),
],
);
}
}

View file

@ -1,10 +1,17 @@
// ignore_for_file: use_build_context_synchronously
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:provider/provider.dart'; import 'package:provider/provider.dart';
import 'package:flutter_gen/gen_l10n/app_localizations.dart'; import 'package:flutter_gen/gen_l10n/app_localizations.dart';
import 'package:adguard_home_manager/screens/settings/dns_rewrites/delete_dns_rewrite.dart';
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/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';
class DnsRewrites extends StatelessWidget { class DnsRewrites extends StatelessWidget {
const DnsRewrites({Key? key}) : super(key: key); const DnsRewrites({Key? key}) : super(key: key);
@ -36,7 +43,7 @@ class DnsRewritesWidget extends StatefulWidget {
} }
class _DnsRewritesWidgetState extends State<DnsRewritesWidget> { class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
void fetchData() async { Future fetchData() async {
widget.serversProvider.setRewriteRulesLoadStatus(0, false); widget.serversProvider.setRewriteRulesLoadStatus(0, false);
final result = await getDnsRewriteRules(server: widget.serversProvider.selectedServer!); final result = await getDnsRewriteRules(server: widget.serversProvider.selectedServer!);
@ -60,6 +67,41 @@ 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 appConfigProvider = Provider.of<AppConfigProvider>(context);
void deleteDnsRewrite(RewriteRulesData rule) async {
ProcessModal processModal = ProcessModal(context: context);
processModal.open(AppLocalizations.of(context)!.deleting);
final result = await deleteDnsRewriteRule(server: serversProvider.selectedServer!, data: {
"domain": rule.domain,
"answer": rule.answer
});
processModal.close();
if (result['result'] == 'success') {
List<RewriteRulesData> data = serversProvider.rewriteRules.data!;
data = data.where((item) => item.domain != rule.domain).toList();
serversProvider.setRewriteRulesData(data);
showSnacbkar(
context: context,
appConfigProvider: appConfigProvider,
label: AppLocalizations.of(context)!.dnsRewriteRuleDeleted,
color: Colors.green
);
}
else {
appConfigProvider.addLog(result['log']);
showSnacbkar(
context: context,
appConfigProvider: appConfigProvider,
label: AppLocalizations.of(context)!.dnsRewriteRuleNotDeleted,
color: Colors.red
);
}
}
Widget generateBody() { Widget generateBody() {
switch (serversProvider.rewriteRules.loadStatus) { switch (serversProvider.rewriteRules.loadStatus) {
@ -85,60 +127,72 @@ class _DnsRewritesWidgetState extends State<DnsRewritesWidget> {
case 1: case 1:
if (serversProvider.rewriteRules.data!.isNotEmpty) { if (serversProvider.rewriteRules.data!.isNotEmpty) {
return ListView.builder( return RefreshIndicator(
padding: const EdgeInsets.only(top: 0), onRefresh: () async {
itemCount: serversProvider.rewriteRules.data!.length, await fetchData();
itemBuilder: (context, index) => Container( },
padding: const EdgeInsets.symmetric(horizontal: 20, vertical: 10), child: ListView.builder(
decoration: BoxDecoration( padding: const EdgeInsets.only(top: 0),
border: Border( itemCount: serversProvider.rewriteRules.data!.length,
bottom: BorderSide( itemBuilder: (context, index) => Container(
color: Colors.grey.shade200 padding: const EdgeInsets.symmetric(horizontal: 20, vertical: 10),
decoration: BoxDecoration(
border: Border(
bottom: BorderSide(
color: Colors.grey.shade200
)
) )
) ),
), child: Row(
child: Row( mainAxisAlignment: MainAxisAlignment.spaceBetween,
mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [
children: [ Column(
Column( crossAxisAlignment: CrossAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.start, children: [
children: [ Row(
Row( children: [
children: [ Text(
Text( "${AppLocalizations.of(context)!.domain}: ",
"${AppLocalizations.of(context)!.domain}: ", style: const TextStyle(
style: const TextStyle( fontWeight: FontWeight.w500
fontWeight: FontWeight.w500 ),
), ),
), Text(
Text( serversProvider.rewriteRules.data![index].domain,
serversProvider.rewriteRules.data![index].domain,
),
],
),
const SizedBox(height: 3),
Row(
children: [
Text(
"${AppLocalizations.of(context)!.answer}: ",
style: const TextStyle(
fontWeight: FontWeight.w500
), ),
), ],
Text( ),
serversProvider.rewriteRules.data![index].answer, const SizedBox(height: 3),
), Row(
], children: [
), Text(
], "${AppLocalizations.of(context)!.answer}: ",
), style: const TextStyle(
IconButton( fontWeight: FontWeight.w500
onPressed: () => {}, ),
icon: const Icon(Icons.delete) ),
) Text(
], serversProvider.rewriteRules.data![index].answer,
), ),
) ],
),
],
),
IconButton(
onPressed: () => {
showDialog(
context: context,
builder: (context) => DeleteDnsRewrite(
onConfirm: () => deleteDnsRewrite(serversProvider.rewriteRules.data![index])
)
)
},
icon: const Icon(Icons.delete)
)
],
),
)
),
); );
} }
else { else {

View file

@ -1394,4 +1394,38 @@ Future getDnsRewriteRules({
else { else {
return result; return result;
} }
}
Future deleteDnsRewriteRule({
required Server server,
required Map<String, dynamic> data,
}) async {
final result = await apiRequest(
urlPath: '/rewrite/delete',
method: 'post',
server: server,
body: data,
type: 'delete_dns_rewrite_rule'
);
if (result['hasResponse'] == true) {
if (result['statusCode'] == 200) {
return { 'result': 'success' };
}
else {
return {
'result': 'error',
'log': AppLog(
type: 'delete_dns_rewrite_rule',
dateTime: DateTime.now(),
message: 'error_code_not_expected',
statusCode: result['statusCode'].toString(),
resBody: result['body'],
)
};
}
}
else {
return result;
}
} }