forked from PaloAltoNetworks/pango
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexample_addressgroup_test.go
125 lines (110 loc) · 3.6 KB
/
example_addressgroup_test.go
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
package pango_test
import (
"log"
"github.com/PaloAltoNetworks/pango"
"github.com/PaloAltoNetworks/pango/commit"
"github.com/PaloAltoNetworks/pango/objs/addr"
"github.com/PaloAltoNetworks/pango/objs/addrgrp"
"github.com/PaloAltoNetworks/pango/poli/security"
"github.com/PaloAltoNetworks/pango/util"
)
// Example_createAddressGroup is a Panorama example on how to create/delete a
// security policy with the associated address group and addresses
func Example_createAddressGroup() {
var deviceGroup = "MyDeviceGroup"
var tags = []string{"sometag"}
var err error
pan := &pango.Panorama{Client: pango.Client{
Hostname: "192.168.1.1",
Username: "admin",
Password: "admin",
Logging: pango.LogAction | pango.LogOp,
}}
if err = pan.Initialize(); err != nil {
log.Panic(err)
return
}
// Create the addresses, address group and security policy
addr1 := addr.Entry{
Name: "SampleAddress1",
Value: "10.192.226.101/32",
Type: addr.IpNetmask,
Description: "First address of a sample address group",
Tags: tags,
}
if err = pan.Objects.Address.Set(deviceGroup, addr1); err != nil {
log.Panic(err)
}
addr2 := addr.Entry{
Name: "SampleAddress2",
Value: "10.192.226.102/32",
Type: addr.IpNetmask,
Description: "Second address of a sample address group",
Tags: tags,
}
if err = pan.Objects.Address.Set(deviceGroup, addr2); err != nil {
log.Panic(err)
}
ag := addrgrp.Entry{
Name: "SampleAddressGroup",
Description: "This in an example on how to use address groups",
StaticAddresses: []string{addr1.Name, addr2.Name},
Tags: tags,
}
if err = pan.Objects.AddressGroup.Set(deviceGroup, ag); err != nil {
log.Panic(err)
}
securityPolicy := security.Entry{
Name: "SamplePolicy",
Description: "This is where the request number goes",
Tags: tags,
SourceZones: []string{"CORPEXT"},
SourceAddresses: []string{"any"},
DestinationZones: []string{"CORPDMZ"},
DestinationAddresses: []string{ag.Name},
Applications: []string{"ssl"},
Services: []string{"application-default"},
LogSetting: "Standard-Logging",
Group: "Corp_Default",
}
securityPolicy.Defaults()
if err = pan.Policies.Security.VerifiableSet(deviceGroup, util.PreRulebase, securityPolicy); err != nil {
log.Panic(err)
}
panCommit := commit.PanoramaCommit{
Description: "Created example address group",
Admins: nil,
DeviceGroups: []string{deviceGroup},
}
resp, bytes, err := pan.Commit(panCommit, "", nil)
if err != nil {
log.Panic(err)
}
log.Printf("Job ID: %v\n", resp)
log.Printf("Response XML: %v\n", string(bytes))
// Delete the addresses, address group and security policy
// Note that the Delete function can take their respective enty structs, or just a string with the name as shown below
if err = pan.Policies.Security.Delete(deviceGroup, util.PreRulebase, securityPolicy.Name); err != nil {
log.Panic(err)
}
if err = pan.Objects.AddressGroup.Delete(deviceGroup, ag.Name); err != nil {
log.Panic(err)
}
if err = pan.Objects.Address.Delete(deviceGroup, addr1.Name); err != nil {
log.Panic(err)
}
if err = pan.Objects.Address.Delete(deviceGroup, addr2.Name); err != nil {
log.Panic(err)
}
panCommit = commit.PanoramaCommit{
Description: "Deleted sample address group",
Admins: nil,
DeviceGroups: []string{deviceGroup},
}
resp, bytes, err = pan.Commit(panCommit, "", nil)
if err != nil {
log.Panic(err)
}
log.Printf("Job ID: %v\n", resp)
log.Printf("Response XML: %v\n", string(bytes))
}