apiauth

package
v1.0.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 4, 2022 License: LGPL-3.0 Imports: 5 Imported by: 0

Documentation

Overview

Package apiauth provides handlers to enable apiauth support.

Simple Usage:

import(
	"github.com/W3-Engineers-Ltd/Radiant"
	"github.com/W3-Engineers-Ltd/Radiant/server/web/filter/apiauth"
)

func main(){
	// apiauth every request
	radiant.InsertFilter("*", radiant.BeforeRouter,apiauth.APIBaiscAuth("appid","appkey"))
	radiant.Run()
}

Advanced Usage:

func getAppSecret(appid string) string {
	// get appsecret by appid
	// maybe store in configure, maybe in database
}

radiant.InsertFilter("*", radiant.BeforeRouter,apiauth.APISecretAuth(getAppSecret, 360))

Information:

In the request user should include these params in the query

1. appid

appid is assigned to the application

2. signature

get the signature use apiauth.Signature()

when you send to server remember use url.QueryEscape()

3. timestamp:

send the request time, the format is yyyy-mm-dd HH:ii:ss

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func APIBaiscAuth

func APIBaiscAuth(appid, appkey string) radiant.FilterFunc

APIBaiscAuth calls APIBasicAuth for previous callers

func APIBasicAuth

func APIBasicAuth(appid, appkey string) radiant.FilterFunc

APIBasicAuth use the basic appid/appkey as the AppIdToAppSecret

func APISecretAuth

func APISecretAuth(f AppIDToAppSecret, timeout int) radiant.FilterFunc

APISecretAuth use AppIdToAppSecret verify and

func Signature

func Signature(appsecret, method string, params url.Values, requestURL string) string

Signature used to generate signature with the appsecret/method/params/RequestURI

Types

type AppIDToAppSecret

type AppIDToAppSecret apiauth.AppIDToAppSecret

AppIDToAppSecret is used to get appsecret throw appid

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL