diff options
author | 2021-06-24 14:26:08 +0200 | |
---|---|---|
committer | 2021-06-24 14:26:08 +0200 | |
commit | c1e107266fc47e59657825f1178f5e79c78ab0e6 (patch) | |
tree | 1daa297f6e61bead4ed3d728fedc2a39604d377f /internal/api/model | |
parent | Timeline bugfix (#60) (diff) | |
download | gotosocial-c1e107266fc47e59657825f1178f5e79c78ab0e6.tar.xz |
nodeinfo compliance (#61)
Diffstat (limited to 'internal/api/model')
-rw-r--r-- | internal/api/model/webfinger.go | 39 | ||||
-rw-r--r-- | internal/api/model/well-known.go | 78 |
2 files changed, 78 insertions, 39 deletions
diff --git a/internal/api/model/webfinger.go b/internal/api/model/webfinger.go deleted file mode 100644 index bb5008949..000000000 --- a/internal/api/model/webfinger.go +++ /dev/null @@ -1,39 +0,0 @@ -package model - -/* - GoToSocial - Copyright (C) 2021 GoToSocial Authors admin@gotosocial.org - - This program is free software: you can redistribute it and/or modify - it under the terms of the GNU Affero General Public License as published by - the Free Software Foundation, either version 3 of the License, or - (at your option) any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU Affero General Public License for more details. - - You should have received a copy of the GNU Affero General Public License - along with this program. If not, see <http://www.gnu.org/licenses/>. -*/ - -// WebfingerAccountResponse represents the response to a webfinger request for an 'acct' resource. -// For example, it would be returned from https://example.org/.well-known/webfinger?resource=acct:some_username@example.org -// -// See https://webfinger.net/ -type WebfingerAccountResponse struct { - Subject string `json:"subject"` - Aliases []string `json:"aliases"` - Links []WebfingerLink `json:"links"` -} - -// WebfingerLink represents one 'link' in a slice of webfinger links returned from a lookup request. -// -// See https://webfinger.net/ -type WebfingerLink struct { - Rel string `json:"rel"` - Type string `json:"type,omitempty"` - Href string `json:"href,omitempty"` - Template string `json:"template,omitempty"` -} diff --git a/internal/api/model/well-known.go b/internal/api/model/well-known.go new file mode 100644 index 000000000..945215e4e --- /dev/null +++ b/internal/api/model/well-known.go @@ -0,0 +1,78 @@ +/* + GoToSocial + Copyright (C) 2021 GoToSocial Authors admin@gotosocial.org + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Affero General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see <http://www.gnu.org/licenses/>. +*/ + +package model + +// WellKnownResponse represents the response to either a webfinger request for an 'acct' resource, or a request to nodeinfo. +// For example, it would be returned from https://example.org/.well-known/webfinger?resource=acct:some_username@example.org +// +// See https://webfinger.net/ +type WellKnownResponse struct { + Subject string `json:"subject,omitempty"` + Aliases []string `json:"aliases,omitempty"` + Links []Link `json:"links,omitempty"` +} + +// Link represents one 'link' in a slice of links returned from a lookup request. +// +// See https://webfinger.net/ +type Link struct { + Rel string `json:"rel"` + Type string `json:"type,omitempty"` + Href string `json:"href,omitempty"` + Template string `json:"template,omitempty"` +} + +// Nodeinfo represents a version 2.1 or version 2.0 nodeinfo schema. +// See: https://nodeinfo.diaspora.software/schema.html +type Nodeinfo struct { + // The schema version + Version string `json:"version"` + // Metadata about server software in use. + Software NodeInfoSoftware `json:"software"` + // The protocols supported on this server. + Protocols []string `json:"protocols"` + // The third party sites this server can connect to via their application API. + Services NodeInfoServices `json:"services"` + // Whether this server allows open self-registration. + OpenRegistrations bool `json:"openRegistrations"` + // Usage statistics for this server. + Usage NodeInfoUsage `json:"usage"` + // Free form key value pairs for software specific values. Clients should not rely on any specific key present. + Metadata map[string]interface{} `json:"metadata"` +} + +// NodeInfoSoftware represents the name and version number of the software of this node. +type NodeInfoSoftware struct { + Name string `json:"name"` + Version string `json:"version"` +} + +// NodeInfoServices represents inbound and outbound services that this node offers connections to. +type NodeInfoServices struct { + Inbound []string `json:"inbound"` + Outbound []string `json:"outbound"` +} + +// NodeInfoUsage represents usage information about this server, such as number of users. +type NodeInfoUsage struct { + Users NodeInfoUsers `json:"users"` +} + +// NodeInfoUsers is a stub for usage information, currently empty. +type NodeInfoUsers struct{} |