forked from snyk-tech-services/jira-tickets-for-new-vulns
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathsnyk.go
97 lines (76 loc) · 3.82 KB
/
snyk.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
package main
import (
"errors"
"fmt"
"log"
"strings"
"github.com/michael-go/go-jsn/jsn"
)
func getOrgProjects(flags flags, customDebug debug) ([]jsn.Json, error) {
verb := "GET"
api_version := "2022-07-08~beta"
baseURL := flags.mandatoryFlags.endpointAPI + "/rest"
projectsAPI := "/orgs/" + flags.mandatoryFlags.orgID + "/projects?version=" + api_version + "&status=active&limit=100"
if len(flags.optionalFlags.projectCriticality) > 0 || len(flags.optionalFlags.projectEnvironment) > 0 || len(flags.optionalFlags.projectLifecycle) > 0 {
if len(flags.optionalFlags.projectCriticality) > 0 {
projectsAPI += "&businessCriticality=" + strings.Replace(flags.optionalFlags.projectCriticality, ",", "%2C", -1)
}
if len(flags.optionalFlags.projectEnvironment) > 0 {
projectsAPI += "&environment=" + strings.Replace(flags.optionalFlags.projectEnvironment, ",", "%2C", -1)
}
if len(flags.optionalFlags.projectLifecycle) > 0 {
projectsAPI += "&lifecycle=" + strings.Replace(flags.optionalFlags.projectLifecycle, ",", "%2C", -1)
}
}
var err error
projectList, err := makeSnykAPIRequest_REST(verb, baseURL, projectsAPI, flags.mandatoryFlags.apiToken, nil, customDebug)
if err != nil {
filters := "projectCriticality: " + flags.optionalFlags.projectCriticality + "\n projectEnvironment: " + flags.optionalFlags.projectEnvironment + "\n projectLifecycle: " + flags.optionalFlags.projectLifecycle
log.Printf("*** ERROR *** Could not list the Project(s) for endpoint %s\n Applied Filters: %s\n", projectsAPI, filters)
errorMessage := fmt.Sprintf("Failure, Could not list the Project(s) for endpoint %s .\n Applied filters: %s\n", projectsAPI, filters)
writeErrorFile("getOrgProjects", errorMessage, customDebug)
err = errors.New(errorMessage)
}
return projectList, err
}
func getProjectsIds(options flags, customDebug debug, notCreatedLogFile string) ([]string, error) {
var projectIds []string
if len(options.optionalFlags.projectID) == 0 {
filters := "projectCriticality: " + options.optionalFlags.projectCriticality + "\n projectEnvironment: " + options.optionalFlags.projectEnvironment + "\n projectLifecycle: " + options.optionalFlags.projectLifecycle
log.Println("*** INFO *** Project ID not specified - listing all projects that match the following filters: ", filters)
projects, err := getOrgProjects(options, customDebug)
if err != nil {
message := fmt.Sprintf("error while getting projects ID for org %s", options.mandatoryFlags.orgID)
writeErrorFile("getProjectsIds", message, customDebug)
return nil, err
}
for _, project := range projects {
projectID := project.K("id").String().Value
projectIds = append(projectIds, projectID)
}
if len(projectIds) == 0 {
ErrorMessage := fmt.Sprintf("Failure, Could not retrieve project ID")
writeErrorFile("getProjectsIds", ErrorMessage, customDebug)
return projectIds, errors.New(ErrorMessage)
}
return projectIds, nil
}
projectIds = append(projectIds, options.optionalFlags.projectID)
return projectIds, nil
}
func getProjectDetails(Mf MandatoryFlags, projectID string, customDebug debug) (jsn.Json, error) {
responseData, err := makeSnykAPIRequest("GET", Mf.endpointAPI+"/v1/org/"+Mf.orgID+"/project/"+projectID, Mf.apiToken, nil, customDebug)
if err != nil {
log.Printf("*** ERROR *** Could not get the Project detail for endpoint %s\n", Mf.endpointAPI)
errorMessage := fmt.Sprintf("Failure, Could not get the Project detail for endpoint %s\n", Mf.endpointAPI)
err = errors.New(errorMessage)
writeErrorFile("getProjectDetails", errorMessage, customDebug)
}
project, err := jsn.NewJson(responseData)
if err != nil {
errorMessage := fmt.Sprintf("Failure, Could not read the Project detail for endpoint %s\n", Mf.endpointAPI)
err = errors.New(errorMessage)
writeErrorFile("getProjectDetails", errorMessage, customDebug)
}
return project, err
}