smg

package
v1.3.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 4, 2024 License: MIT Imports: 14 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type ChangeFreq

type ChangeFreq string

ChangeFreq is used for defining changefreq property in sitemap url items.

const (
	Always  ChangeFreq = "always"
	Hourly  ChangeFreq = "hourly"
	Daily   ChangeFreq = "daily"
	Weekly  ChangeFreq = "weekly"
	Monthly ChangeFreq = "monthly"
	Yearly  ChangeFreq = "yearly"
	Never   ChangeFreq = "never"
)

predefined ChangeFreq frequency values

type Options

type Options struct {
	Compress   bool   `xml:"-"`
	Name       string `xml:"-"`
	Hostname   string `xml:"-"`
	OutputPath string `xml:"-"`
	// contains filtered or unexported fields
}

Options contains general attributes of Sitemap and SitemapIndex. OutputPath is the dir path to save the SitemapIndex file and it's sitemaps. Name of Sitemap output xml file which must be without ".xml" extension. Hostname of Sitemap urls which be prepended to all URLs. Compress option can be either enabled or disabled for Sitemap and SitemapIndex.

type Sitemap

type Sitemap struct {
	Options
	SitemapIndexLoc *SitemapIndexLoc
	NextSitemap     *Sitemap
	// contains filtered or unexported fields
}

Sitemap struct which contains Options for general attributes, SitemapLoc as its location in SitemapIndex, NextSitemap that is a Linked-List pointing to the next Sitemap for large files.

func NewSitemap

func NewSitemap(prettyPrint bool) *Sitemap

NewSitemap builds and returns a new Sitemap.

func (*Sitemap) Add

func (s *Sitemap) Add(u *SitemapLoc) error

Add adds an URL to a Sitemap. in case of exceeding the Sitemaps.org limits, splits the Sitemap into several Sitemap instances using a Linked List

func (*Sitemap) Finalize

func (s *Sitemap) Finalize()

Finalize closes the XML data set and do not allow any further sm.Add() calls

func (*Sitemap) GetURLsCount

func (s *Sitemap) GetURLsCount() int

GetURLsCount returns the number of added URL items into this single sitemap.

func (*Sitemap) Save

func (s *Sitemap) Save() (filenames []string, err error)

Save makes the OutputPath in case of absence and saves the Sitemap into OutputPath using it's Name. it returns the filename.

func (*Sitemap) SetCompress

func (s *Sitemap) SetCompress(compress bool)

SetCompress sets the Compress option to be either enabled or disabled for Sitemap When Compress is enabled, the output file is compressed using gzip with .xml.gz extension.

func (*Sitemap) SetHostname

func (s *Sitemap) SetHostname(hostname string)

SetHostname sets the Hostname of Sitemap urls which be prepended to all URLs. Note: you do not have to call SetHostname in case you are building Sitemap using SitemapIndex.NewSitemap but you can set a separate Hostname for a specific Sitemap using SetHostname, else the SitemapIndex.SetHostname does this action for all Sitemaps of the entire SitemapIndex.

func (*Sitemap) SetLastMod

func (s *Sitemap) SetLastMod(lastMod *time.Time)

SetLastMod sets the LastMod if this Sitemap which will be used in it's URL in SitemapIndex

func (*Sitemap) SetMaxURLsCount

func (s *Sitemap) SetMaxURLsCount(maxURLsCount int)

SetMaxURLsCount sets the maximum # of URLs for a sitemap

func (*Sitemap) SetName

func (s *Sitemap) SetName(name string)

SetName sets the Name of Sitemap output xml file It must be without ".xml" extension

func (*Sitemap) SetOutputPath

func (s *Sitemap) SetOutputPath(outputPath string)

SetOutputPath sets the OutputPath of Sitemap which will be used to save the xml file. Note: you do not have to call SetOutputPath in case you are building Sitemap using SitemapIndex.NewSitemap but you can set a separate OutputPath for a specific Sitemap using SetOutputPath, else the SitemapIndex.SetOutputPath does this action for all Sitemaps of the entire SitemapIndex.

func (*Sitemap) WriteTo

func (s *Sitemap) WriteTo(w io.Writer) (n int64, err error)

type SitemapAlternateLoc

type SitemapAlternateLoc struct {
	Hreflang string `xml:"hreflang,attr"`
	Href     string `xml:"href,attr"`
	Rel      string `xml:"rel,attr"`
}

SitemapAlternateLoc contains data related to <xhtml:link> tag in Sitemap <url>

type SitemapImage

type SitemapImage struct {
	ImageLoc string `xml:"image:loc,omitempty"`
}

SitemapImage contains data related to <image:image> tag in Sitemap <url>

type SitemapIndex

type SitemapIndex struct {
	Options
	XMLName     xml.Name           `xml:"sitemapindex"`
	Xmlns       string             `xml:"xmlns,attr"`
	SitemapLocs []*SitemapIndexLoc `xml:"sitemap"`
	Sitemaps    []*Sitemap         `xml:"-"`
	ServerURI   string             `xml:"-"`
	// contains filtered or unexported fields
}

SitemapIndex contains sitemap_index items which are SitemapURLs. New instances must be created with NewSitemapIndex() in order to set the Xmlns attribute correctly. Options is for general attributes Name is the filename which is used in Save method. Hostname is a prefix which wll be used for all URLs in SitemapIndex and it's Sitemaps. SitemapLocs is list of location structs of its Sitemaps. Sitemaps contains all Sitemaps which is belong to this SitemapIndex. ServerURI is used for making url of Sitemap in SitemapIndex.

func NewSitemapIndex

func NewSitemapIndex(prettyPrint bool) *SitemapIndex

NewSitemapIndex builds returns new SitemapIndex. prettyPrint param makes the file easy to read and is recommended to be set to false for production use and is not changeable after initialization.

func (*SitemapIndex) Add

func (s *SitemapIndex) Add(u *SitemapIndexLoc)

Add adds an URL to a SitemapIndex.

func (*SitemapIndex) AppendSitemap

func (s *SitemapIndex) AppendSitemap(sm *Sitemap)

AppendSitemap appends a Sitemap instance into it's Sitemaps. Does not change and configurations.

func (*SitemapIndex) NewSitemap

func (s *SitemapIndex) NewSitemap() *Sitemap

NewSitemap builds a new instance of Sitemap and appends it in SitemapIndex's Sitemaps and sets it's Name nad Hostname

func (*SitemapIndex) PingSearchEngines

func (s *SitemapIndex) PingSearchEngines(pingURLs ...string) error

PingSearchEngines pings search engines

func (*SitemapIndex) Save

func (s *SitemapIndex) Save() (string, error)

Save makes the OutputPath in case of absence and saves the SitemapIndex and it's Sitemaps into OutputPath as separate files using their Name.

func (*SitemapIndex) SetCompress

func (s *SitemapIndex) SetCompress(compress bool)

SetCompress sets the Compress option to be either enabled or disabled for SitemapIndex and it's Sitemaps and sets it as Compress of new Sitemap entries built using NewSitemap method. When Compress is enabled, the output file is compressed using gzip with .xml.gz extension.

func (*SitemapIndex) SetHostname

func (s *SitemapIndex) SetHostname(hostname string)

SetHostname sets the Hostname for SitemapIndex and it's Sitemaps and sets it as Hostname of new Sitemap entries built using NewSitemap method.

func (*SitemapIndex) SetOutputPath

func (s *SitemapIndex) SetOutputPath(outputPath string)

SetOutputPath sets the OutputPath for SitemapIndex and it's Sitemaps and sets it as OutputPath of new Sitemap entries built using NewSitemap method. this path can be a multi-level dir path and will be used in Save method.

func (*SitemapIndex) SetServerURI

func (s *SitemapIndex) SetServerURI(serverURI string)

SetServerURI sets the ServerURI for SitemapIndex and it's Sitemaps and sets it as OutputPath of new Sitemap entries built using NewSitemap method.

func (*SitemapIndex) SetSitemapIndexName

func (s *SitemapIndex) SetSitemapIndexName(name string)

SetSitemapIndexName sets the filename of SitemapIndex which be used to save the xml file. name param must not have .xml extension.

func (*SitemapIndex) WriteTo

func (s *SitemapIndex) WriteTo(writer io.Writer) (int64, error)

WriteTo writes XML encoded sitemap to given io.Writer. Implements io.WriterTo interface.

type SitemapIndexLoc

type SitemapIndexLoc struct {
	XMLName xml.Name   `xml:"sitemap"`
	Loc     string     `xml:"loc"`
	LastMod *time.Time `xml:"lastmod,omitempty"`
}

SitemapIndexLoc contains data related to <sitemap> tag in SitemapIndex.

type SitemapLoc

type SitemapLoc struct {
	XMLName    xml.Name               `xml:"url"`
	Loc        string                 `xml:"loc"`
	LastMod    *time.Time             `xml:"lastmod,omitempty"`
	ChangeFreq ChangeFreq             `xml:"changefreq,omitempty"`
	Priority   float32                `xml:"priority,omitempty"`
	Images     []*SitemapImage        `xml:"image:image,omitempty"`
	Alternate  []*SitemapAlternateLoc `xml:"xhtml:link,omitempty"`
}

SitemapLoc contains data related to <url> tag in Sitemap.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL