summaryrefslogtreecommitdiff
path: root/windows/WinUI
diff options
context:
space:
mode:
authorGrant Limberg <glimberg@gmail.com>2015-10-23 15:37:36 -0700
committerGrant Limberg <glimberg@gmail.com>2015-10-23 15:37:36 -0700
commitb7b973624ad1f17e21ca72b0ffff827664d2732c (patch)
tree9b1798a80f31d52ff3aa195e39253a8f64933ee7 /windows/WinUI
parent62059a91aa22cb8e109f96b9d2290136d599eca1 (diff)
downloadinfinitytier-b7b973624ad1f17e21ca72b0ffff827664d2732c.tar.gz
infinitytier-b7b973624ad1f17e21ca72b0ffff827664d2732c.zip
add methods for joining/leaving networks, and getting peers
Diffstat (limited to 'windows/WinUI')
-rw-r--r--windows/WinUI/APIHandler.cs70
1 files changed, 65 insertions, 5 deletions
diff --git a/windows/WinUI/APIHandler.cs b/windows/WinUI/APIHandler.cs
index c13bca53..0755c28d 100644
--- a/windows/WinUI/APIHandler.cs
+++ b/windows/WinUI/APIHandler.cs
@@ -27,7 +27,7 @@ namespace WinUI
url = "http://" + host + ":" + port;
}
- public ZeroTierStatus getStatus()
+ public ZeroTierStatus GetStatus()
{
var request = WebRequest.Create(url + "/status" + "?auth=" + authtoken) as HttpWebRequest;
if (request != null)
@@ -46,15 +46,17 @@ namespace WinUI
}
}
- public List<ZeroTierNetwork> getNetworks()
+ public List<ZeroTierNetwork> GetNetworks()
{
var request = WebRequest.Create(url + "/network" + "?auth=" + authtoken) as HttpWebRequest;
- if (request != null)
+ if (request == null)
{
- request.Method = "GET";
- request.ContentType = "application/json";
+ return null;
}
+ request.Method = "GET";
+ request.ContentType = "application/json";
+
var httpResponse = (HttpWebResponse)request.GetResponse();
using (var streamReader = new StreamReader(httpResponse.GetResponseStream()))
{
@@ -65,5 +67,63 @@ namespace WinUI
return networkList;
}
}
+
+ public void JoinNetwork(string nwid)
+ {
+ var request = WebRequest.Create(url + "/network/" + nwid + "?auth=" + authtoken) as HttpWebRequest;
+ if (request == null)
+ {
+ return;
+ }
+
+ request.Method = "POST";
+
+ var httpResponse = (HttpWebResponse)request.GetResponse();
+
+ if (httpResponse.StatusCode != HttpStatusCode.OK)
+ {
+ Console.WriteLine("Error sending join network message");
+ }
+ }
+
+ public void LeaveNetwork(string nwid)
+ {
+ var request = WebRequest.Create(url + "/network/" + nwid + "?auth=" + authtoken) as HttpWebRequest;
+ if (request == null)
+ {
+ return;
+ }
+
+ request.Method = "DELETE";
+
+ var httpResponse = (HttpWebResponse)request.GetResponse();
+
+ if (httpResponse.StatusCode != HttpStatusCode.OK)
+ {
+ Console.WriteLine("Error sending leave network message");
+ }
+ }
+
+ public List<ZeroTierPeer> GetPeers()
+ {
+ var request = WebRequest.Create(url + "/peer" + "?auth=" + authtoken) as HttpWebRequest;
+ if (request == null)
+ {
+ return null;
+ }
+
+ request.Method = "GET";
+ request.ContentType = "application/json";
+
+ var httpResponse = (HttpWebResponse)request.GetResponse();
+ using (var streamReader = new StreamReader(httpResponse.GetResponseStream()))
+ {
+ var responseText = streamReader.ReadToEnd();
+ Console.WriteLine(responseText);
+
+ List<ZeroTierPeer> peerList = JsonConvert.DeserializeObject<List<ZeroTierPeer>>(responseText);
+ return peerList;
+ }
+ }
}
}