Files
gortsplib/pkg/headers/authorization.go
Alessandro Ros a1396206b5 convert Tracks into Medias and Formats (#155)
* split tracks from medias

* move tracks into dedicated package

* move media into dedicated package

* edit Medias.Marshal() in order to return SDP

* add medias.Find() and simplify examples

* improve coverage

* fix rebase errors

* replace TrackIDs with MediaIDs

* implement media-specific and track-specific callbacks for reading RTCP and RTP packets

* rename publish into record, read into play

* add v2 tag

* rename tracks into formats
2022-12-11 22:03:22 +01:00

86 lines
1.6 KiB
Go

package headers
import (
"encoding/base64"
"fmt"
"strings"
"github.com/aler9/gortsplib/v2/pkg/base"
)
// Authorization is an Authorization header.
type Authorization struct {
// authentication method
Method AuthMethod
// basic user
BasicUser string
// basic password
BasicPass string
// digest values
DigestValues Authenticate
}
// Unmarshal decodes an Authorization header.
func (h *Authorization) Unmarshal(v base.HeaderValue) error {
if len(v) == 0 {
return fmt.Errorf("value not provided")
}
if len(v) > 1 {
return fmt.Errorf("value provided multiple times (%v)", v)
}
v0 := v[0]
switch {
case strings.HasPrefix(v0, "Basic "):
h.Method = AuthBasic
v0 = v0[len("Basic "):]
tmp, err := base64.StdEncoding.DecodeString(v0)
if err != nil {
return fmt.Errorf("invalid value")
}
tmp2 := strings.Split(string(tmp), ":")
if len(tmp2) != 2 {
return fmt.Errorf("invalid value")
}
h.BasicUser, h.BasicPass = tmp2[0], tmp2[1]
case strings.HasPrefix(v0, "Digest "):
h.Method = AuthDigest
var vals Authenticate
err := vals.Unmarshal(base.HeaderValue{v0})
if err != nil {
return err
}
h.DigestValues = vals
default:
return fmt.Errorf("invalid authorization header")
}
return nil
}
// Marshal encodes an Authorization header.
func (h Authorization) Marshal() base.HeaderValue {
switch h.Method {
case AuthBasic:
response := base64.StdEncoding.EncodeToString([]byte(h.BasicUser + ":" + h.BasicPass))
return base.HeaderValue{"Basic " + response}
default: // AuthDigest
return h.DigestValues.Marshal()
}
}