forked from TrueCloudLab/rclone
jottacloud: Handle empty time values
This commit is contained in:
parent
040768383b
commit
6199b95b61
2 changed files with 42 additions and 19 deletions
|
@ -12,41 +12,35 @@ const (
|
||||||
timeFormat = "2006-01-02-T15:04:05Z0700"
|
timeFormat = "2006-01-02-T15:04:05Z0700"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Time represents represents date and time information for the
|
// Time represents time values in the Jottacloud API. It uses a custom RFC3339 like format.
|
||||||
// Jottacloud API, by using a custom RFC3339 like format
|
|
||||||
type Time time.Time
|
type Time time.Time
|
||||||
|
|
||||||
// UnmarshalXML turns XML into a Time
|
// UnmarshalXML turns XML into a Time
|
||||||
func (t *Time) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error {
|
func (t *Time) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error {
|
||||||
var v string
|
var v string
|
||||||
err := d.DecodeElement(&v, &start)
|
if err := d.DecodeElement(&v, &start); err != nil {
|
||||||
if err != nil {
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
var newT time.Time
|
if v == "" {
|
||||||
newT, err = time.Parse(timeFormat, v)
|
*t = Time(time.Time{})
|
||||||
if err == nil {
|
return nil
|
||||||
*t = Time(newT)
|
}
|
||||||
|
newTime, err := time.Parse(timeFormat, v)
|
||||||
|
if err == nil {
|
||||||
|
*t = Time(newTime)
|
||||||
}
|
}
|
||||||
//fmt.Printf("UnmarshalTime (in: %s, out: %s)\n", v, newT.String())
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
// MarshalXML turns a Time into XML
|
// MarshalXML turns a Time into XML
|
||||||
func (t *Time) MarshalXML(e *xml.Encoder, start xml.StartElement) error {
|
func (t *Time) MarshalXML(e *xml.Encoder, start xml.StartElement) error {
|
||||||
timeString := (*time.Time)(t).Format(timeFormat)
|
return e.EncodeElement(t.String(), start)
|
||||||
return e.EncodeElement(timeString, start)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return Time string in Jottacloud format
|
// Return Time string in Jottacloud format
|
||||||
func (t Time) String() string {
|
func (t Time) String() string { return time.Time(t).Format(timeFormat) }
|
||||||
t1 := (time.Time)(t)
|
|
||||||
s := t1.Format(timeFormat)
|
|
||||||
//fmt.Printf("FormatTime: (in %s, out: %s)\n", t1.String(), s)
|
|
||||||
return s
|
|
||||||
}
|
|
||||||
|
|
||||||
// Flag is a Hacky type for checking if an attribute is present
|
// Flag is a hacky type for checking if an attribute is present
|
||||||
type Flag bool
|
type Flag bool
|
||||||
|
|
||||||
// UnmarshalXMLAttr sets Flag to true if the attribute is present
|
// UnmarshalXMLAttr sets Flag to true if the attribute is present
|
||||||
|
@ -260,7 +254,7 @@ type Error struct {
|
||||||
|
|
||||||
// Error returns a string for the error and statistifes the error interface
|
// Error returns a string for the error and statistifes the error interface
|
||||||
func (e *Error) Error() string {
|
func (e *Error) Error() string {
|
||||||
out := fmt.Sprintf("Error %d", e.StatusCode)
|
out := fmt.Sprintf("error %d", e.StatusCode)
|
||||||
if e.Message != "" {
|
if e.Message != "" {
|
||||||
out += ": " + e.Message
|
out += ": " + e.Message
|
||||||
}
|
}
|
||||||
|
|
29
backend/jottacloud/api/types_test.go
Normal file
29
backend/jottacloud/api/types_test.go
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
package api
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/xml"
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestMountpointEmptyModificationTime(t *testing.T) {
|
||||||
|
mountpoint := `
|
||||||
|
<mountPoint time="2018-08-12-T09:58:24Z" host="dn-157">
|
||||||
|
<name xml:space="preserve">Sync</name>
|
||||||
|
<path xml:space="preserve">/foo/Jotta</path>
|
||||||
|
<abspath xml:space="preserve">/foo/Jotta</abspath>
|
||||||
|
<size>0</size>
|
||||||
|
<modified></modified>
|
||||||
|
<device>Jotta</device>
|
||||||
|
<user>foo</user>
|
||||||
|
<metadata first="" max="" total="0" num_folders="0" num_files="0"/>
|
||||||
|
</mountPoint>
|
||||||
|
`
|
||||||
|
var jf JottaFolder
|
||||||
|
if err := xml.Unmarshal([]byte(mountpoint), &jf); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
if !time.Time(jf.ModifiedAt).IsZero() {
|
||||||
|
t.Errorf("got non-zero time, want zero")
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue