diff --git a/cw_core/lib/digest_auth.dart b/cw_core/lib/digest_auth.dart new file mode 100644 index 000000000..752ff0779 --- /dev/null +++ b/cw_core/lib/digest_auth.dart @@ -0,0 +1,41 @@ +import 'dart:convert'; +import 'dart:io'; + +import 'package:http/http.dart' as http; +import 'package:http/io_client.dart' as ioc; + +class DigestAuth{ + Futurerequest({ + String uri, + String login = "", + String password = "", + }) async { + final path = '/json_rpc'; + final rpcUri = Uri.http(uri, path); + final realm = 'monero-rpc'; + final postMap = { + 'jsonrpc': '2.0', + 'id': '0', + 'method': 'get_info' + }; + final authenticatingClient = HttpClient(); + + authenticatingClient.addCredentials( + rpcUri, + realm, + HttpClientDigestCredentials(login ?? "", password ?? ""), + ); + + final http.Client client = ioc.IOClient(authenticatingClient); + + final response = await client.post( + rpcUri, + headers: {'Content-Type': 'application/json'}, + body: json.encode(postMap), + ); + + client.close(); + + return response; + } +} \ No newline at end of file diff --git a/cw_core/lib/node.dart b/cw_core/lib/node.dart index 3dc876521..f7f24d89b 100644 --- a/cw_core/lib/node.dart +++ b/cw_core/lib/node.dart @@ -1,5 +1,6 @@ import 'dart:io'; +import 'package:cw_core/digest_auth.dart'; import 'package:cw_core/keyable.dart'; import 'package:flutter/foundation.dart'; import 'dart:convert'; @@ -95,20 +96,15 @@ class Node extends HiveObject with Keyable { } Future requestMoneroNode() async { - try { - Map resBody; - final rpcUri = Uri.http(uri.authority, '/json_rpc'); - final headers = {'Content-type': 'application/json'}; - final body = - json.encode({'jsonrpc': '2.0', 'id': '0', 'method': 'get_info'}); - final response = - await http.post(rpcUri.toString(), headers: headers, body: body); - resBody = json.decode(response.body) as Map; - return !(resBody['result']['offline'] as bool); - } catch (_) { + final digestAuth = DigestAuth(); + try { + final response = await digestAuth.request(uri: uri.authority, login: login, password: password); + final resBody = json.decode(response.body) as Map; + return !(resBody['result']['offline'] as bool); + } catch (_) { return false; } - } +} Future requestElectrumServer() async { try {