Compare commits

..

4 Commits

4 changed files with 37 additions and 10 deletions

23
atom.go
View File

@ -1,8 +1,31 @@
package atomfeed package atomfeed
import (
"mime"
"strings"
)
type ( type (
EmailAddress string EmailAddress string
LanguageTag string LanguageTag string
MediaType string MediaType string
URI string URI string
) )
func isCompositeMediaType(mediaType string) bool {
mediaType, _, err := mime.ParseMediaType(mediaType)
if err != nil {
return false
}
return strings.HasPrefix(mediaType, "multipart/") || strings.HasPrefix(mediaType, "message/")
}
func isXMLMediaType(mediaType string) bool {
mediaType, _, err := mime.ParseMediaType(mediaType)
if err != nil {
return false
}
return strings.HasSuffix(mediaType, "/xml") || strings.HasSuffix(mediaType, "+xml")
}

View File

@ -4,7 +4,6 @@ import (
"encoding/xml" "encoding/xml"
"errors" "errors"
"fmt" "fmt"
"mime"
"strings" "strings"
) )
@ -59,10 +58,6 @@ func alternateRelExists(l []*Link) bool {
return false return false
} }
func isXMLMediaType(mediaType string) bool {
return strings.HasSuffix(mediaType, "/xml") || strings.HasSuffix(mediaType, "+xml")
}
func (e *Entry) AddExtension(name string, value any) { func (e *Entry) AddExtension(name string, value any) {
e.Extensions = append(e.Extensions, &ExtensionElement{XMLName: xml.Name{Local: name}, Value: value}) e.Extensions = append(e.Extensions, &ExtensionElement{XMLName: xml.Name{Local: name}, Value: value})
} }
@ -148,10 +143,7 @@ func (e *Entry) Check() error {
// "type" attribute of atom:content is a MIME media type [MIMEREG], but // "type" attribute of atom:content is a MIME media type [MIMEREG], but
// is not an XML media type [RFC3023], does not begin with "text/", and // is not an XML media type [RFC3023], does not begin with "text/", and
// does not end with "/xml" or "+xml". // does not end with "/xml" or "+xml".
mediaType, _, err := mime.ParseMediaType(e.Content.getType()) mediaType := e.Content.getType()
if err != nil {
return fmt.Errorf("type attribute of content element of entry %v: %v", e.ID.URI, err)
}
if !isXMLMediaType(mediaType) && !strings.HasPrefix(mediaType, "text/") { if !isXMLMediaType(mediaType) && !strings.HasPrefix(mediaType, "text/") {
return fmt.Errorf("no summary element of entry %v but media type not xml", e.ID.URI) return fmt.Errorf("no summary element of entry %v but media type not xml", e.ID.URI)
} }

View File

@ -1,5 +1,7 @@
package atomfeed package atomfeed
import "errors"
type InlineOtherContent struct { type InlineOtherContent struct {
*CommonAttributes *CommonAttributes
Type MediaType `xml:"type,attr,omitempty"` Type MediaType `xml:"type,attr,omitempty"`
@ -12,4 +14,10 @@ func (i *InlineOtherContent) hasSRC() bool { return false }
func (i *InlineOtherContent) getType() string { return string(i.Type) } func (i *InlineOtherContent) getType() string { return string(i.Type) }
func (i *InlineOtherContent) Check() error { return nil } func (i *InlineOtherContent) Check() error {
if isCompositeMediaType(i.getType()) {
return errors.New("type attribute of inline other content must not be a composite type")
}
return nil
}

View File

@ -15,6 +15,10 @@ func (o *OutOfLineContent) hasSRC() bool { return true }
func (o *OutOfLineContent) getType() string { return string(o.Type) } func (o *OutOfLineContent) getType() string { return string(o.Type) }
func (o *OutOfLineContent) Check() error { func (o *OutOfLineContent) Check() error {
if isCompositeMediaType(o.getType()) {
return errors.New("type attribute of out of line content must not be a composite type")
}
if o.SRC == "" { if o.SRC == "" {
return errors.New("src attribute of out of line content empty") return errors.New("src attribute of out of line content empty")
} }