package anidb
import (
+ "io/ioutil"
+ "log"
"time"
)
// by a previous Auth() call.
type AniDB struct {
Timeout time.Duration // Timeout for the various calls (default: 45s)
+ Logger *log.Logger // Logger where HTTP/UDP traffic is logged
udp *udpWrap
}
// Initialises a new AniDB.
func NewAniDB() *AniDB {
- return &AniDB{
+ ret := &AniDB{
Timeout: 45 * time.Second,
- udp: newUDPWrap(),
+ Logger: log.New(ioutil.Discard, "", log.LstdFlags),
}
+ ret.udp = newUDPWrap(ret)
+ return ret
}
func (adb *AniDB) User() *User {
if adb.udp.user != nil {
return adb.udp.user
} else if adb.udp.credentials != nil {
- // see if we can get it from the cache
+ // see if we can get it from the cache (we don't care if it's stale)
adb.udp.user = UserByName(decrypt(adb.udp.credentials.username))
+ if adb.udp.user != nil {
+ return adb.udp.user
+ }
+ // we have to go through the slow path
+ adb.udp.user = <-adb.GetUserByName(decrypt(adb.udp.credentials.username))
return adb.udp.user
}
}