1
0
mirror of https://github.com/aclindsa/ofxgo.git synced 2024-11-21 19:20:05 -05:00
ofxgo/signon.go

89 lines
3.0 KiB
Go
Raw Normal View History

2017-03-11 07:15:15 -05:00
package ofxgo
import (
"errors"
2017-04-08 08:57:31 -04:00
"fmt"
"github.com/aclindsa/xml"
2017-03-11 07:15:15 -05:00
)
// SignonRequest identifies and authenticates a user to their FI and is
// provided with every Request
2017-03-11 07:18:02 -05:00
type SignonRequest struct {
2020-11-17 09:17:52 -05:00
XMLName xml.Name `xml:"SONRQ"`
DtClient Date `xml:"DTCLIENT"` // Current time on client, overwritten in Client.Request()
UserID String `xml:"USERID"`
UserPass String `xml:"USERPASS,omitempty"`
UserKey String `xml:"USERKEY,omitempty"`
GenUserKey Boolean `xml:"GENUSERKEY,omitempty"`
Language String `xml:"LANGUAGE"` // Defaults to ENG
Org String `xml:"FI>ORG"`
Fid String `xml:"FI>FID"`
AppID String `xml:"APPID"` // Overwritten in Client.Request()
AppVer String `xml:"APPVER"` // Overwritten in Client.Request()
ClientUID UID `xml:"CLIENTUID,omitempty"`
2017-03-11 07:15:15 -05:00
}
// Name returns the name of the top-level transaction XML/SGML element
2017-03-11 07:18:02 -05:00
func (r *SignonRequest) Name() string {
2017-03-11 07:15:15 -05:00
return "SONRQ"
}
// Valid returns (true, nil) if this struct would be valid OFX if marshalled
// into XML/SGML
func (r *SignonRequest) Valid(version ofxVersion) (bool, error) {
2017-04-12 21:40:42 -04:00
if len(r.UserID) < 1 || len(r.UserID) > 32 {
2017-03-11 07:15:15 -05:00
return false, errors.New("SONRQ>USERID invalid length")
}
if (len(r.UserPass) == 0) == (len(r.UserKey) == 0) {
return false, errors.New("One and only one of SONRQ>USERPASS and USERKEY must be supplied")
}
if len(r.UserPass) > 32 {
return false, errors.New("SONRQ>USERPASS invalid length")
}
if len(r.UserKey) > 64 {
return false, errors.New("SONRQ>USERKEY invalid length")
}
if len(r.Language) == 0 {
r.Language = "ENG"
} else if len(r.Language) != 3 {
return false, fmt.Errorf("SONRQ>LANGUAGE invalid length: \"%s\"", r.Language)
2017-03-11 07:15:15 -05:00
}
2017-04-12 21:40:42 -04:00
if len(r.AppID) < 1 || len(r.AppID) > 5 {
2017-03-11 07:15:15 -05:00
return false, errors.New("SONRQ>APPID invalid length")
}
2017-03-16 11:13:21 -04:00
if len(r.AppVer) < 1 || len(r.AppVer) > 4 {
2017-03-11 07:15:15 -05:00
return false, errors.New("SONRQ>APPVER invalid length")
}
return true, nil
}
// SignonResponse is provided with every Response and indicates the success or
// failure of the SignonRequest in the corresponding Request
2017-03-11 07:18:02 -05:00
type SignonResponse struct {
XMLName xml.Name `xml:"SONRS"`
Status Status `xml:"STATUS"`
2017-03-11 21:13:06 -05:00
DtServer Date `xml:"DTSERVER"`
2017-03-11 07:18:02 -05:00
UserKey String `xml:"USERKEY,omitempty"`
TsKeyExpire *Date `xml:"TSKEYEXPIRE,omitempty"`
2017-03-11 07:18:02 -05:00
Language String `xml:"LANGUAGE"`
DtProfUp *Date `xml:"DTPROFUP,omitempty"`
DtAcctUp *Date `xml:"DTACCTUP,omitempty"`
2017-03-11 07:18:02 -05:00
Org String `xml:"FI>ORG"`
Fid String `xml:"FI>FID"`
SessCookie String `xml:"SESSCOOKIE,omitempty"`
AccessKey String `xml:"ACCESSKEY,omitempty"`
2017-03-11 07:15:15 -05:00
}
// Name returns the name of the top-level transaction XML/SGML element
2017-03-11 07:18:02 -05:00
func (r *SignonResponse) Name() string {
2017-03-11 07:15:15 -05:00
return "SONRS"
}
// Valid returns (true, nil) if this struct was valid OFX when unmarshalled
func (r *SignonResponse) Valid(version ofxVersion) (bool, error) {
2017-03-11 07:15:15 -05:00
if len(r.Language) != 3 {
return false, fmt.Errorf("SONRS>LANGUAGE invalid length: \"%s\"", r.Language)
2017-03-11 07:15:15 -05:00
}
return r.Status.Valid()
}