mirror of
https://github.com/bluenviron/mediamtx
synced 2025-01-07 07:20:01 +00:00
9c6ba7e2c7
This is a new authentication system that covers all the features exposed by the server, including playback, API, metrics and PPROF, improves internal authentication by adding permissions, improves HTTP-based authentication by adding the ability to exclude certain actions from being authenticated, adds an additional method (JWT-based authentication).
64 lines
1.0 KiB
Go
64 lines
1.0 KiB
Go
package conf
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
)
|
|
|
|
// Encryption is the encryption parameter.
|
|
type Encryption int
|
|
|
|
// values.
|
|
const (
|
|
EncryptionNo Encryption = iota
|
|
EncryptionOptional
|
|
EncryptionStrict
|
|
)
|
|
|
|
// MarshalJSON implements json.Marshaler.
|
|
func (d Encryption) MarshalJSON() ([]byte, error) {
|
|
var out string
|
|
|
|
switch d {
|
|
case EncryptionNo:
|
|
out = "no"
|
|
|
|
case EncryptionOptional:
|
|
out = "optional"
|
|
|
|
default:
|
|
out = "strict"
|
|
}
|
|
|
|
return json.Marshal(out)
|
|
}
|
|
|
|
// UnmarshalJSON implements json.Unmarshaler.
|
|
func (d *Encryption) UnmarshalJSON(b []byte) error {
|
|
var in string
|
|
if err := json.Unmarshal(b, &in); err != nil {
|
|
return err
|
|
}
|
|
|
|
switch in {
|
|
case "no", "false":
|
|
*d = EncryptionNo
|
|
|
|
case "optional":
|
|
*d = EncryptionOptional
|
|
|
|
case "strict", "yes", "true":
|
|
*d = EncryptionStrict
|
|
|
|
default:
|
|
return fmt.Errorf("invalid encryption: '%s'", in)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// UnmarshalEnv implements env.Unmarshaler.
|
|
func (d *Encryption) UnmarshalEnv(_ string, v string) error {
|
|
return d.UnmarshalJSON([]byte(`"` + v + `"`))
|
|
}
|