Skip to content

antfie/veracode-go-hmac-authentication

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Go Report Card License: MIT

Veracode HMAC Authentication for Go

A Go version of the Veracode HMAC authentication as found in Veracode Docs. This library has no dependencies.

Installation

go get -u github.com/antfie/veracode-go-hmac-authentication

Example Usage

package main

import (
	"io/ioutil"
	"net/http"
	"net/url"

	"github.com/antfie/veracode-go-hmac-authentication/hmac"
)

func main() {
	var apiKeyID = "YOUR_VERACODE_API_KEY_ID"
	var apiKeySecret = "YOUR_VERACODE_API_KEY_SECRET"
	var apiUrl = "https://analysiscenter.veracode.com/api/5.0/getapplist.do"

	response := makeApiRequest(apiKeyID, apiKeySecret, apiUrl, http.MethodGet)
	print(response)
}

func makeApiRequest(apiKeyID, apiKeySecret, apiUrl, httpMethod string) string {
	parsedUrl, err := url.Parse(apiUrl)

	if err != nil {
		panic(err)
	}

	client := &http.Client{}
	req, err := http.NewRequest(httpMethod, parsedUrl.String(), nil)

	if err != nil {
		panic(err)
	}

	authorizationHeader, err := hmac.CalculateAuthorizationHeader(parsedUrl, httpMethod, apiKeyID, apiKeySecret)

	if err != nil {
		panic(err)
	}

	req.Header.Add("Authorization", authorizationHeader)

	resp, err := client.Do(req)

	if err != nil {
		panic(err)
	}

	if resp.StatusCode != http.StatusOK {
		panic("Expected status 200. Status was: " + resp.Status)
	}

	body, err := ioutil.ReadAll(resp.Body)

	if err != nil {
		panic(err)
	}

	return string(body[:])
}

About

Veracode HMAC Authentication for Go

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages