Compare commits
No commits in common. "e6c076a8f4cda74db326e0f105588f9a17152939" and "e55263590961e2004b5e66bc21b7a4398c0e3142" have entirely different histories.
e6c076a8f4
...
e552635909
|
@ -1,4 +1,4 @@
|
||||||
There are special collections that are managed by server side-effects, such as `followers` `following` `liked` on actors and possibly ~~`replies`~~, `likes`, `shares` on objects. In most cases, the side-effects are the only intended way of interacting with these collections; for example, a Follow results in an Accept Follow, which has the side effect of adding them to `followers` and them adding you to `following`; a Like has the side effect of you adding the object to `liked` and them adding your Like to `likes`; an Announce has the side effect of them adding the Announce to `shares`, and a small exception for `replies` which may be managed manually.
|
There are special collections that are managed by server side-effects, such as `followers` `following` `liked` on actors and possibly `replies`, `likes`, `shares` on objects. In most cases, the side-effects are the only intended way of interacting with these collections; for example, a Follow results in an Accept Follow, which has the side effect of adding them to `followers` and them adding you to `following`; a Like has the side effect of you adding the object to `liked` and them adding your Like to `likes`; an Announce has the side effect of them adding the Announce to `shares`, and a small exception for `replies` which may be managed manually.
|
||||||
|
|
||||||
But there's nothing in ActivityPub explicitly preventing a user from targeting their followers/following with an Add/Remove. In the case of a Remove, you can say that there is a legitimate use-case for this; perhaps you no longer wish to follow or be followed by a certain actor. However, for Add, it's a bit weirder -- you can Add an actor to your `followers` despite never receiving a Follow from them. You can add an actor to your `following` despite never receiving an Accept Follow from them.
|
But there's nothing in ActivityPub explicitly preventing a user from targeting their followers/following with an Add/Remove. In the case of a Remove, you can say that there is a legitimate use-case for this; perhaps you no longer wish to follow or be followed by a certain actor. However, for Add, it's a bit weirder -- you can Add an actor to your `followers` despite never receiving a Follow from them. You can add an actor to your `following` despite never receiving an Accept Follow from them.
|
||||||
|
|
||||||
|
@ -13,5 +13,3 @@ and in 6.6/6.7 for Add/Remove:
|
||||||
Taken together, we conclude that the logical `iff` regarding Accept Follow is the only way to add the other actor to your following. A C2S Add/Remove would not be allowed due to "discretion".
|
Taken together, we conclude that the logical `iff` regarding Accept Follow is the only way to add the other actor to your following. A C2S Add/Remove would not be allowed due to "discretion".
|
||||||
|
|
||||||
Given this: how do we signal server management instead of actor management of these collections? My initial leaning would be to exclude `attributedTo` from the representation of these collections; in the absence of any attribution, it is assumed that the collection is owned by the server running at that origin / domain / hostname. (For S2S follower removal, this would have to be a special case handled similarly to Reject Follow being sent at any time after an Accept Follow, but that's a separate topic.)
|
Given this: how do we signal server management instead of actor management of these collections? My initial leaning would be to exclude `attributedTo` from the representation of these collections; in the absence of any attribution, it is assumed that the collection is owned by the server running at that origin / domain / hostname. (For S2S follower removal, this would have to be a special case handled similarly to Reject Follow being sent at any time after an Accept Follow, but that's a separate topic.)
|
||||||
|
|
||||||
https://github.com/w3c/activitypub/issues/377
|
|
|
@ -1 +0,0 @@
|
||||||
Collection mechanism is very similar to ldp:Container and i guess solid as well? can be backed by filesystem directory/folder and files.
|
|
|
@ -1,3 +0,0 @@
|
||||||
if you turn everything into an actor, then Following that actor is like subscribing to a topic for that actor
|
|
||||||
|
|
||||||
the actor's role is to programmatically forward or announce activities/objects related to that topic?
|
|
|
@ -4,4 +4,4 @@ consider an unlisted youtube video, which doesn't appear in the uploads tab. how
|
||||||
|
|
||||||
instead: have an explicit profile Collection. Add stuff into it. when we federate social data we should explicitly be managing the expected presentation of that social data, in as generic a way as possible.
|
instead: have an explicit profile Collection. Add stuff into it. when we federate social data we should explicitly be managing the expected presentation of that social data, in as generic a way as possible.
|
||||||
|
|
||||||
related problem: constructing conversations based on a chain of `inReplyTo` instead of having an explicit collection (likely being used as `context`) -- actually the activitypub spec [doesn't specify side effects for inReplyTo]({{< relref "replies-have-no-side-effect" >}}) and for that matter neither does it specify use of context or a context-collection. these are both cases where the Add makes sense to send out explicitly.
|
related problem: constructing conversations based on a chain of `inReplyTo` instead of having an explicit collection (likely being used as `context`)
|
|
@ -1,4 +1,4 @@
|
||||||
see [Note vs Article]({{<relref "note-vs-article" >}}) for more. but basically:
|
see [Note vs Article]({{<relref "note-vs-article.md" >}}) for more. but basically:
|
||||||
|
|
||||||
in summary:
|
in summary:
|
||||||
|
|
||||||
|
|
|
@ -28,7 +28,3 @@ what might this imply is needed for activitypub?
|
||||||
## querying
|
## querying
|
||||||
|
|
||||||
how do you tell if an arbitrary object is included in a collection or not? without iterating over the entire collection, that is.
|
how do you tell if an arbitrary object is included in a collection or not? without iterating over the entire collection, that is.
|
||||||
|
|
||||||
## constraining range
|
|
||||||
|
|
||||||
how do you know what a collection contains?
|
|
|
@ -5,4 +5,4 @@ the recommendation in the spec is to use JSON-LD for extensions, which leaves op
|
||||||
my thoughts:
|
my thoughts:
|
||||||
|
|
||||||
- if you consider the mastodon protocol/profile, then you basically have to compact against the same context as them, because mastodon only understands shorthand terms that match their own definitions.
|
- if you consider the mastodon protocol/profile, then you basically have to compact against the same context as them, because mastodon only understands shorthand terms that match their own definitions.
|
||||||
- a full IRI is the only unambiguous way to refer to the same thing. namespaces / prefixes are bad because you could have infinitely many ways of expressing the same thing
|
- a full IRI is the only unambiguous way to refer to the same thing
|
|
@ -1,4 +0,0 @@
|
||||||
|
|
||||||
`likes` and `shares` are defined in terms of side effects of `Like` and `Announce`, but there is no specified side effect for `Create` with `inReplyTo`. this implies manual management of the replies collection?
|
|
||||||
|
|
||||||
https://github.com/w3c/activitypub/issues/374
|
|
|
@ -1,38 +0,0 @@
|
||||||
it's often stated that hierarchical categories are too limited and that a tagging system is better. putting aside arguments about what a "category" represents taxonomically and how it differs from a "tag" (e.g. "grouping vs describing", "general vs specific", etc), there ought to be more flexibility in tags and tagging in order to make it a worthwhile mental model shift vs. categories.
|
|
||||||
|
|
||||||
i generally agree that a strict hierarchy is not the best, even if it is sometimes (often?) good (enough?). the classic issue is with e.g. folders in a filesystem, a folder can have only one parent. sure you can set up symlinks but the one-parent rule is an issue that needs to be worked around.
|
|
||||||
|
|
||||||
the shift from categories to tags "solves" this "one-parent rule" issue. (but again, you could just as easily say that an item can belong to multiple categories; etc etc. we leave this argument out because it is too similar to the taxonomic argument above)
|
|
||||||
|
|
||||||
now we have to come up with improvements to the tagging system. below are some mechanisms
|
|
||||||
|
|
||||||
## hierarchical tags
|
|
||||||
|
|
||||||
> x.y.z implies x.y and also implies x. it might also imply y (unclear)
|
|
||||||
|
|
||||||
cons: it replicates the one-parent rule and its issues, and it's unclear how inheritance works. also what do you use as the separator between hierarchy layers? a dot? a slash?
|
|
||||||
|
|
||||||
prior art:
|
|
||||||
|
|
||||||
- also called "nested tags" by obsidian
|
|
||||||
|
|
||||||
## taggable tags
|
|
||||||
|
|
||||||
just like modern OOP principles tell you to favor composition over inheritance, we favor taggable tags over hierarchical tags.
|
|
||||||
|
|
||||||
> z is tagged with x and y; therefore, anything tagged with z implies x and implies y
|
|
||||||
|
|
||||||
example: tagging a character from a series implies tagging the series. #gaimon_(one_piece) is your classic booru style binary tag that is too basic. what you *want* is to imply that #one_piece tag without actually having to tag it yourself. but you also want to imply many other tags: #green_hair, #treasure_chest, #afro, and so on. you don't want to add these tags yourself every single time.
|
|
||||||
|
|
||||||
prior art:
|
|
||||||
|
|
||||||
- hydrus network calls this "tag parents". it works off of semantic subsets and supersets.
|
|
||||||
|
|
||||||
## tag aliases
|
|
||||||
|
|
||||||
> z implies zee (and vice versa); z implies zed (and vice versa)
|
|
||||||
|
|
||||||
prior art:
|
|
||||||
- also called "tag siblings" by hydrus network. allows you to set up equivalence between semantic concepts.
|
|
||||||
|
|
||||||
you can chain these together transitively or keep them flat, but it is generally a good idea to mark one of the ends as "canonical" implying it overrides the other. say you want to have a common misspelling be overridden by the correct spelling
|
|
|
@ -1,92 +1,85 @@
|
||||||
|
{{ "<!-- title -->" | safeHTML }}
|
||||||
{{- $firstH1 := partial "name.html" . }}
|
{{- $firstH1 := partial "name.html" . }}
|
||||||
{{- $title := or .Title $firstH1 $.File.ContentBaseName }}
|
{{- $title := or .Title $firstH1 $.File.ContentBaseName }}
|
||||||
|
{{- if $title }}
|
||||||
{{- $cover := ($.Resources.ByType "image").GetMatch "{*opengraph*}" -}}
|
<title itemprop="name">{{ $title }} - {{ .Site.Title }}</title>
|
||||||
{{ $icon := resources.GetMatch (default "" .Site.Params.icon) -}}
|
|
||||||
|
|
||||||
{{/*=== title ===*/}}
|
|
||||||
{{ "<!-- text -->" | safeHTML }}
|
|
||||||
{{- with .Site.Title }}
|
|
||||||
<meta name="application-name" property="og:site_name" content="{{ . }}" />
|
|
||||||
{{- end -}}
|
|
||||||
{{- if .IsHome}}
|
|
||||||
{{- with or .Params.name .Site.Title }}
|
|
||||||
<title>{{ . }}</title>
|
|
||||||
<meta property="og:title" name="twitter:title" itemprop="name" content="{{ . }}" />
|
|
||||||
{{- end }}
|
|
||||||
{{- else }}
|
{{- else }}
|
||||||
<title>{{ or .Params.name (print $title " - " .Site.Title) }}</title>
|
<title itemprop="name">{{ .Site.Title }}</title>
|
||||||
<meta property="og:title" name="twitter:title" itemprop="name" content="{{ or .Params.name $title }}" />
|
{{- end }}
|
||||||
{{- end -}}
|
<meta property="og:title" content="{{ $title }}" />
|
||||||
|
<meta name="twitter:title" content="{{ $title }}" />
|
||||||
|
<meta name="application-name" content="{{ .Site.Title }}" />
|
||||||
|
<meta property="og:site_name" content="{{ .Site.Title }}" />
|
||||||
|
|
||||||
{{/*=== description ===*/}}
|
|
||||||
{{- with or .Description .Summary .Site.Params.description }}
|
{{- with or .Description .Summary .Site.Params.description }}
|
||||||
<meta name="description" itemprop="description" property="og:description" content="{{ . }}" />
|
{{ "<!-- description -->" | safeHTML }}
|
||||||
<meta name="twitter:description" content="{{ . }}" />
|
<meta name="description" content="{{.}}">
|
||||||
|
<meta itemprop="description" content="{{.}}" />
|
||||||
|
<meta property="og:description" content="{{.}}" />
|
||||||
|
<meta name="twitter:description" content="{{.}}" />
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{ "<!-- url -->" | safeHTML }}
|
{{ "<!-- url -->" | safeHTML }}
|
||||||
{{- with .Permalink | absURL}}
|
<base href="{{ .Permalink | absURL }}">
|
||||||
<base href="{{ . }}" />
|
<link rel="canonical" href="{{ .Permalink | absURL }}" itemprop="url" />
|
||||||
<link rel="canonical" href="{{ or $.Params.canonical . }}" />
|
<meta name="url" content="{{ .Permalink | absURL }}" />
|
||||||
<meta name="url" property="og:url" itemprop="url" content="{{ . }}" />
|
<meta name="twitter:url" content="{{ .Permalink | absURL }}" />
|
||||||
<meta name="twitter:url" content="{{ . }}" />
|
<meta property="og:url" content="{{ .Permalink | absURL }}" />
|
||||||
{{- end -}}
|
|
||||||
|
|
||||||
{{/*=== image ===*/}}
|
{{- $cover := ($.Resources.ByType "image").GetMatch "{*cover*,*thumbnail*,*featured*}" -}}
|
||||||
|
{{ $icon := resources.GetMatch (default "" .Site.Params.icon) -}}
|
||||||
{{- $staticIcon := "icon.png" | absURL -}}
|
{{- $staticIcon := "icon.png" | absURL -}}
|
||||||
{{- with or $cover $icon }}
|
{{- with or $cover $icon }}
|
||||||
{{- with or $cover $icon }}
|
|
||||||
{{ "<!-- image -->" | safeHTML }}
|
{{ "<!-- image -->" | safeHTML }}
|
||||||
<meta property="og:image" itemprop="image" content="{{ .Permalink | absURL }}" />
|
<meta itemprop="image" content='{{ .Permalink | absURL }}' />
|
||||||
|
<meta property="og:image" content='{{ .Permalink | absURL }}' />
|
||||||
{{- with .Width }}
|
{{- with .Width }}
|
||||||
<meta property="og:image:width" content="{{ . }}" />
|
<meta property="og:image:width" content='{{ . }}' />
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- with .Height }}
|
{{- with .Height }}
|
||||||
<meta property="og:image:height" content="{{ . }}" />
|
<meta property="og:image:height" content='{{ . }}' />
|
||||||
{{- end }}
|
{{- end }}
|
||||||
<meta name="twitter:image" content="{{ .Permalink | absURL }}" />
|
<meta name="twitter:image" content='{{ .Permalink | absURL }}' />
|
||||||
<meta name="twitter:image:src" content="{{ .Permalink | absURL }}" />
|
<meta name="twitter:image:src" content='{{ .Permalink | absURL }}' />
|
||||||
{{- else }}
|
{{- else }}
|
||||||
{{ "<!-- image -->" | safeHTML }}
|
{{ "<!-- image -->" | safeHTML }}
|
||||||
<meta property="og:image" itemprop="image" content="{{ $staticIcon }}" />
|
<meta itemprop="image" content='{{ $staticIcon }}' />
|
||||||
<meta name="twitter:image" content="{{ $staticIcon }}" />
|
<meta property="og:image" content='{{ $staticIcon }}' />
|
||||||
<meta name="twitter:image:src" content="{{ $staticIcon }}" />
|
<meta name="twitter:image" content='{{ $staticIcon }}' />
|
||||||
|
<meta name="twitter:image:src" content='{{ $staticIcon }}' />
|
||||||
{{- end -}}
|
{{- end -}}
|
||||||
|
|
||||||
{{/*=== extra params? ===*/}}
|
{{/*=== author ===*/}}
|
||||||
{{- with .Params.audio }}<meta property="og:audio" content="{{ . }}" />{{ end }}
|
|
||||||
{{- with .Params.locale }}<meta property="og:locale" content="{{ . }}" />{{ end }}
|
|
||||||
{{- with .Params.videos }}{{- range . }}
|
|
||||||
<meta property="og:video" content="{{ . | absURL }}" />
|
|
||||||
{{ end }}{{ end }}
|
|
||||||
|
|
||||||
{{/*=== article ===*/}}
|
|
||||||
{{ with or .Params.author .Site.Params.author -}}
|
{{ with or .Params.author .Site.Params.author -}}
|
||||||
{{ "<!-- author -->" | safeHTML }}
|
{{ "<!-- author -->" | safeHTML }}
|
||||||
<meta name="author" property="article:author" content="{{ . }}" />
|
<meta property="article:publisher" content="{{ . }}" />
|
||||||
{{- end }}
|
<meta property="og:article:author" content="{{ . }}" />
|
||||||
<meta property="article:publisher" content="{{ .Site.BaseURL }}" />
|
<meta property="article:author" content="{{ . }}" />
|
||||||
{{ "<!-- time -->" | safeHTML }}
|
<meta name="author" content="{{ . }}" />
|
||||||
{{ with .Date -}}
|
{{- end -}}
|
||||||
<meta property="article:published_time" itemprop="datePublished" content={{ .Format "2006-01-02T03:04:05Z" | safeHTML }} />
|
|
||||||
|
{{/*=== published and updated ===*/}}
|
||||||
|
{{- "<!-- time -->" | safeHTML }}
|
||||||
|
{{ with .Date }}
|
||||||
|
<meta property="og:article:published_time" content={{ .Format "2006-01-02T15:04:05Z0700" | safeHTML }} />
|
||||||
|
<meta property="article:published_time" content={{ .Format "2006-01-02T15:04:05Z0700" | safeHTML }} />
|
||||||
{{ end -}}
|
{{ end -}}
|
||||||
{{ with .Lastmod -}}
|
{{ with .Lastmod -}}
|
||||||
<meta property="article:modified_time" itemprop="dateModified" content={{ .Format "2006-01-02T03:04:05Z" | safeHTML }} />
|
<meta property="og:updated_time" content={{ .Format "2006-01-02T15:04:05Z0700" | safeHTML }} />
|
||||||
{{ end -}}
|
{{ end -}}
|
||||||
|
|
||||||
{{/*=== section and keywords ===*/}}
|
{{/*=== section and keywords ===*/}}
|
||||||
{{- "<!-- keywords -->" | safeHTML }}
|
{{- "<!-- keywords -->" | safeHTML }}
|
||||||
{{ with.Params.category -}}
|
{{- with.Params.category -}}
|
||||||
|
<meta name="news_keywords" content="{{ . }}" />
|
||||||
<meta property="article:section" content="{{ . }}" />
|
<meta property="article:section" content="{{ . }}" />
|
||||||
{{- end -}}
|
{{- end -}}
|
||||||
{{- with .Params.tags }}
|
{{- with .Params.tags }}
|
||||||
<meta property="article:tag" itemprop="keywords" name="keywords" content='{{ delimit . " "}}' />
|
<meta name="keywords" content='{{ delimit . " "}}'>
|
||||||
{{- end -}}
|
{{- end -}}
|
||||||
|
|
||||||
{{- if isset .Params "date" }}
|
{{- if isset .Params "date" -}}
|
||||||
{{ "<!-- article metadata -->" | safeHTML }}
|
{{ "<!-- article metadata -->" | safeHTML }}
|
||||||
<meta property="og:type" content="article" />
|
<meta property="og:type" content="article" />
|
||||||
<meta itemprop="wordCount" content="{{ .WordCount }}" />
|
|
||||||
<script defer type="application/ld+json">
|
<script defer type="application/ld+json">
|
||||||
{
|
{
|
||||||
"@context": "http://schema.org",
|
"@context": "http://schema.org",
|
||||||
|
@ -94,23 +87,21 @@
|
||||||
"headline": {{ $title }},
|
"headline": {{ $title }},
|
||||||
"author": {
|
"author": {
|
||||||
"@type": "Person",
|
"@type": "Person",
|
||||||
"name": {{ or .Params.author .Site.Params.author }},
|
"name": "{{ or .Params.author .Site.Params.author }}"
|
||||||
"url": {{ .Site.BaseURL }}
|
|
||||||
},
|
},
|
||||||
"datePublished": {{ .Date.UTC.Format "2006-01-02T03:04:05Z" }},
|
"datePublished": "{{ .Date.Format "2006-01-02" }}",
|
||||||
"description": {{ (or .Description .Summary) | plainify }},
|
"description": {{ or .Description .Summary }},
|
||||||
"wordCount": {{ .WordCount }},
|
"wordCount": {{ .WordCount }},
|
||||||
"mainEntityOfPage": {{.Permalink}},
|
"mainEntityOfPage": "True",
|
||||||
"dateModified": "{{ .Lastmod.UTC.Format "2006-01-02T03:04:05Z" }}",
|
"dateModified": "{{ .Lastmod.Format "2006-01-02" }}",
|
||||||
"image": {
|
"image": {
|
||||||
"@type": "ImageObject",
|
"@type": "ImageObject",
|
||||||
"url": {{ with or $cover $icon }}{{ .Permalink | absURL }}{{ end }}
|
"url": "{{ with or $cover $icon }}{{ .Permalink | absURL }}{{ end }}"
|
||||||
},
|
},
|
||||||
"publisher": {
|
"publisher": {
|
||||||
"@type": "WebSite",
|
"@type": "Person",
|
||||||
"name": {{ .Site.Title }},
|
"name": "{{ or .Params.author .Site.Params.author .Site.Title }}",
|
||||||
"url": {{ .Site.BaseURL }},
|
"logo": {
|
||||||
"image": {
|
|
||||||
"@type": "ImageObject",
|
"@type": "ImageObject",
|
||||||
"url": {{with $icon}}{{.Permalink}}{{else}}{{$staticIcon}}{{end}}
|
"url": {{with $icon}}{{.Permalink}}{{else}}{{$staticIcon}}{{end}}
|
||||||
}
|
}
|
||||||
|
@ -118,39 +109,31 @@
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
{{- else }}
|
{{- else }}
|
||||||
{{- else }}
|
|
||||||
{{ "<!-- webpage metadata -->" | safeHTML }}
|
{{ "<!-- webpage metadata -->" | safeHTML }}
|
||||||
<meta property="og:type" content="website" />
|
<meta property="og:type" content="website" />
|
||||||
<script defer type="application/ld+json">
|
<script defer type="application/ld+json">
|
||||||
{
|
{
|
||||||
"@context": "http://schema.org",
|
"@context": "http://schema.org",
|
||||||
"@type": "WebPage",
|
"@type": "WebSite",
|
||||||
"name": {{ .Title }},
|
"url": {{ .Permalink }},
|
||||||
"url": {{ .Permalink }},
|
"name": "{{ .Site.Title }}",
|
||||||
"description": {{ (or .Description .Summary) | plainify }},
|
"logo": {{with $icon}}{{.Permalink}}{{else}}{{$staticIcon}}{{end}}
|
||||||
"image": {
|
|
||||||
"@type": "ImageObject",
|
|
||||||
"url": {{with $icon}}{{.Permalink}}{{else}}{{$staticIcon}}{{end}}
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
</script>
|
</script>
|
||||||
{{- end -}}
|
{{- end -}}
|
||||||
|
|
||||||
{{/* auxiliary info */}}
|
{{/* auxiliary info */}}
|
||||||
{{ "<!-- site presentation -->" | safeHTML }}
|
{{ "<!-- site presentation -->" | safeHTML }}
|
||||||
{{ with $icon }}
|
{{ with $icon }}
|
||||||
<link rel="shortcut icon" href='{{ .Permalink }}' sizes="{{.Width}}x{{.Height}}" />
|
<link rel="shortcut icon" href='{{ .Permalink }}' sizes="{{.Width}}x{{.Height}}">
|
||||||
{{- else -}}
|
{{- else -}}
|
||||||
<link rel="shortcut icon" href='{{ $staticIcon }}' sizes="512x512" />
|
<link rel="shortcut icon" href='{{ $staticIcon }}' sizes="512x512">
|
||||||
{{- end }}
|
{{- end }}
|
||||||
<meta name="theme-color" content="#ffffff" />
|
<meta name="theme-color" content="#ffffff" />
|
||||||
<meta name="msapplication-TileColor" content="#ffffff" />
|
<meta name="msapplication-TileColor" content="#ffffff" />
|
||||||
<link rel="sitemap" type="application/xml" title="Sitemap" href="{{ .Site.BaseURL }}sitemap.xml" />
|
<link rel="sitemap" type="application/xml" title="Sitemap" href="{{ .Site.BaseURL }}sitemap.xml" />
|
||||||
{{ with .OutputFormats.Get "RSS" -}}
|
{{ with .OutputFormats.Get "RSS" -}}
|
||||||
<link href="{{ .Permalink }}" rel="feed alternate" type="application/rss+xml" title="{{ $.Site.Title }}" />
|
<link href="{{ .Permalink }}" rel="feed alternate" type="application/rss+xml" title="{{ $.Site.Title }}" />
|
||||||
{{- end -}}
|
{{- end }}
|
||||||
|
|
||||||
{{/* robots */}}
|
|
||||||
{{ "<!-- robots -->" | safeHTML }}
|
|
||||||
<meta name="robots" content="index,follow" />
|
<meta name="robots" content="index,follow" />
|
||||||
<meta name="googlebot" content="index,follow" />
|
<meta name="googlebot" content="index,follow" />
|
||||||
|
|
Loading…
Reference in a new issue