Note
I forked this repo from gstotts to merge his pending PRs.
Go Module for Interacting with InsightCloudSec API (formerly DivvyCloud)
package main
import(
"github.com/gstotts/insightcloudsec"
)
func main() {
config := insightcloudsec.Config{
BaseURL: "http://localhost:8001",
ApiKey: "1232351351235ABSLAFL:JSDFA"
}
// Can also use environment variables above and pass nil
ics := insightcloudsec.NewClient(config)
}
List Clouds
package main
import (
"fmt"
"github.com/gstotts/insightcloudsec"
)
func main() {
// Get a client
c, err := insightcloudsec.NewClient(nil)
if err != nil {
fmt.Println(err)
}
clouds, err := c.Clouds.List()
if err != nil {
fmt.Println(err)
}
for _, cloud := range clouds.Clouds {
fmt.Println(cloud.Name)
}
}
List Cloud Types
package main
import (
"fmt"
"github.com/gstotts/insightcloudsec"
)
func main() {
// Get a client
c, err := insightcloudsec.NewClient(nil)
if err != nil {
fmt.Println(err)
}
types, err := c.Clouds.ListTypes()
if err != nil {
fmt.Println(err)
}
for _, t := range types.CloudTypesList {
fmt.Println(t.Name)
}
}
List Cloud Regions
package main
import (
"fmt"
"os"
"github.com/gstotts/insightcloudsec"
)
func main() {
// Get a client
c, err := insightcloudsec.NewClient(nil)
if err != nil {
fmt.Println(err)
}
clouds, err := c.Clouds.ListClouds()
if err != nil {
fmt.Println(err)
os.Exit(1)
}
for _, cloud := range clouds.Clouds {
fmt.Printf("Name: %s\n", cloud.Name)
regions, _ := c.ListCloudRegions(cloud)
fmt.Println("Regions:")
for _, region := range regions.Regions {
fmt.Printf("- %s\n", region.Name)
}
}
}
List Harvesting Strategies
package main
import (
"fmt"
"os"
"github.com/gstotts/insightcloudsec"
)
func main() {
// Get a client
c, err := insightcloudsec.NewClient(nil)
if err != nil {
fmt.Println(err)
}
hs, err := c.Clouds.ListHarvestingStrategies()
if err != nil {
fmt.Println(err)
os.Exit(1)
}
for _, s := range hs {
fmt.Printf("Name: %s\n", s.Name)
}
}
Create Insight
package main
import (
"github.com/gstotts/insightcloudsec"
)
func main() {
filter := insightcloudsec.InsightFilter{}
filter.Name = "divvy.filter.cloud_trail_in_all_regions"
insight := insightcloudsec.Insight{}
insight.Name = "Test Divvy Insight"
insight.Description = "Test Divvy Insight Description"
insight.Severity = insightcloudsec.INSIGHT_SEVERITY_MINOR
insight.Tags = nil
insight.Badges = nil
insight.BadgeFilterOperator = ""
insight.ResourceTypes = []string{"divvyorganizationservice"}
insight.Filters = []insightcloudsec.InsightFilter{filter}
ics, _ := insightcloudsec.NewClient(nil)
ics.Insights.Create(insight)
}
List Insights
package main
import (
"fmt"
"os"
"github.com/gstotts/insightcloudsec"
)
func main() {
// Get a client
c, err := insightcloudsec.NewClient(nil)
if err != nil {
fmt.Println(err)
}
insights, err := c.Insights.List()
if err != nil {
fmt.Println(err)
os.Exit(1)
}
for _, insight := range insights {
fmt.Printf(" Name: %s\n", insight.Name)
fmt.Printf("Description: %s\n\n", insight.Description)
}
}
Add Azure Cloud
package main
import (
"fmt"
"github.com/gstotts/insightcloudsec"
)
func main() {
ics, _ := insightcloudsec.NewClient(nil)
azure_cloud := insightcloudsec.AzureCloudAccount{
CreationParameters: insightcloudsec.CloudAccountParameters{
CloudType: insightcloudsec.AZURE_CLOUD_TYPE,
AuthType: insightcloudsec.STANDARD_AUTH,
Name: "Azure Test",
ApiKeyOrCert: "1111111111111111111111111111",
TenantID: "01234567-1234-1234-1234-012345678901",
SubscriptionID: "01234567-1234-1234-1234-012345678901",
AppID: "01234567-1234-1234-1234-012345678901",
},
}
account, err := ics.Clouds.AddAzureCloud(azure_cloud)
if err != nil {
fmt.Println(err)
}
fmt.Println(account)
}
Create User
package main
import (
"fmt"
"github.com/gstotts/insightcloudsec"
)
func main() {
ics, _ := insightcloudsec.NewClient(nil)
details, err := ics.Users.Create(insightcloudsec.User{
Name: "Testy McTester",
Username: "tmctester",
Email: "[email protected]",
Password: "testpassword123",
AccessLevel: "BASIC_USER",
})
if err != nil {
fmt.Println(err)
}
fmt.Println(details)
}