-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathSetMxL3FwRule.cs
165 lines (141 loc) · 5.56 KB
/
SetMxL3FwRule.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
using System;
using System.Management.Automation;
using System.Management.Automation.Runspaces;
using System.Threading.Tasks;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text.Json;
using System.Text.Json.Serialization;
using System.Collections.Generic;
namespace GetMerakiOrgsCmdlet
{
[Cmdlet(VerbsCommon.Set, "MxL3Firewall")]
[OutputType(typeof(MxFirewallRule))]
public class SetL3FirewallRuleCommand : PSCmdlet
{
[Parameter(
Mandatory = true,
Position = 0,
ValueFromPipeline = true,
ValueFromPipelineByPropertyName = true)]
public string Token { get; set; }
[Parameter(
Mandatory = true,
Position = 1,
ValueFromPipeline = true,
ValueFromPipelineByPropertyName = true)]
public string netid { get; set; }
[ValidateSet("allow", "deny", IgnoreCase = true)]
[Parameter(
Mandatory = true,
Position = 2,
ValueFromPipeline = true,
ValueFromPipelineByPropertyName = true)]
public string policy { get; set; }
[Parameter(
Mandatory = true,
Position = 3,
ValueFromPipeline = true,
ValueFromPipelineByPropertyName = true)]
public string comment { get; set; }
[ValidateSet("tcp", "udp", "icmp", "any", IgnoreCase = true)]
[Parameter(
Mandatory = true,
Position = 4,
ValueFromPipeline = true,
ValueFromPipelineByPropertyName = true)]
public string protocol { get; set; }
[Parameter(
Mandatory = true,
Position = 5,
ValueFromPipeline = true,
ValueFromPipelineByPropertyName = true)]
public string srcPort { get; set; }
[Parameter(
Mandatory = true,
Position = 6,
ValueFromPipeline = true,
ValueFromPipelineByPropertyName = true)]
public string srcCidr { get; set; }
[Parameter(
Mandatory = true,
Position = 7,
ValueFromPipeline = true,
ValueFromPipelineByPropertyName = true)]
public string destPort { get; set; }
[Parameter(
Mandatory = true,
Position = 8,
ValueFromPipeline = true,
ValueFromPipelineByPropertyName = true)]
public string destCidr { get; set; }
[Parameter(
Mandatory = true,
Position = 9,
ValueFromPipeline = true,
ValueFromPipelineByPropertyName = true)]
public bool syslogEnabled { get; set; }
private static async Task<string> UpdateL3FWRule(string Token, string netid, L3RulesList rules)
{
using (HttpClient client = new HttpClient())
{
string jsonString;
string uri;
uri = $"https://dashboard.meraki.com/api/v0/networks/{netid}/l3FirewallRules";
jsonString = JsonSerializer.Serialize<L3RulesList>(rules);
var content = new StringContent(jsonString);
content.Headers.ContentType = new MediaTypeHeaderValue("application/json");
client.DefaultRequestHeaders.Accept.Clear();
client.DefaultRequestHeaders.Accept.Add(
new MediaTypeWithQualityHeaderValue("application/json"));
client.DefaultRequestHeaders.TryAddWithoutValidation("Content-Type", "application/json; charset=utf-8");
client.DefaultRequestHeaders.Add("X-Cisco-Meraki-API-Key", Token);
var response = await client.PutAsync(uri, content);
var contents = await response.Content.ReadAsStringAsync();
return contents;
}
}
private static string ProcessRecordAsync(string Token, string netid, L3RulesList rules)
{
var task = UpdateL3FWRule(Token, netid, rules);
task.Wait();
var result = task.Result;
return result;
}
// This method gets called once for each cmdlet in the pipeline when the pipeline starts executing
protected override void BeginProcessing()
{
WriteVerbose("Begin!");
WriteVerbose(Token);
}
// This method will be called for each input received from the pipeline to this cmdlet; if no input is received, this method is not called
protected override void ProcessRecord()
{
MxFirewallRule rule = new MxFirewallRule();
L3RulesList rules = new L3RulesList();
rule.comment = comment;
rule.protocol = protocol;
rule.policy = policy;
rule.srcCidr = srcCidr;
rule.srcPort = srcPort;
rule.destCidr = destCidr;
rule.destPort = destPort;
rule.syslogEnabled = syslogEnabled;
rules.rules.Add(rule);
WriteVerbose("Entering Get Orgs call");
var list = ProcessRecordAsync(Token, netid, rules);
MxFirewallRule result = JsonSerializer.Deserialize<MxFirewallRule>(list);
WriteObject(result, true);
WriteVerbose("Exiting foreach");
}
// // This method will be called once at the end of pipeline execution; if no input is received, this method is not called
protected override void EndProcessing()
{
WriteVerbose("End!");
}
}
public class L3RulesList
{
public List<MxFirewallRule> rules { get; set; }
}
}