2024-08-22 23:03:38 +02:00
|
|
|
package versia
|
2024-08-11 03:51:22 +02:00
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"encoding/json"
|
2024-08-22 23:03:38 +02:00
|
|
|
versiacrypto "github.com/lysand-org/versia-go/pkg/versia/crypto"
|
|
|
|
|
versiautils "github.com/lysand-org/versia-go/pkg/versia/utils"
|
2024-08-11 03:51:22 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
// User represents a user object in the Lysand protocol. For more information, see the [Spec].
|
|
|
|
|
//
|
|
|
|
|
// [Spec]: https://lysand.org/objects/user
|
|
|
|
|
type User struct {
|
|
|
|
|
Entity
|
|
|
|
|
|
|
|
|
|
// PublicKey is the public key of the user.
|
|
|
|
|
// https://lysand.org/objects/user#public-key
|
2024-08-20 22:43:26 +02:00
|
|
|
PublicKey UserPublicKey `json:"public_key"`
|
2024-08-11 03:51:22 +02:00
|
|
|
|
|
|
|
|
// DisplayName is the display name of the user.
|
|
|
|
|
// https://lysand.org/objects/user#display-name
|
|
|
|
|
DisplayName *string `json:"display_name,omitempty"`
|
|
|
|
|
|
|
|
|
|
// Username is the username of the user. Must be unique on the instance and match the following regex: ^[a-z0-9_-]+$
|
|
|
|
|
// https://lysand.org/objects/user#username
|
|
|
|
|
Username string `json:"username"`
|
|
|
|
|
|
|
|
|
|
// Indexable is a boolean that indicates whether the user is indexable by search engines.
|
|
|
|
|
// https://lysand.org/objects/user#indexable
|
|
|
|
|
Indexable bool `json:"indexable"`
|
|
|
|
|
|
|
|
|
|
// ManuallyApprovesFollowers is a boolean that indicates whether the user manually approves followers.
|
|
|
|
|
// https://lysand.org/objects/user#manually-approves-followers
|
|
|
|
|
ManuallyApprovesFollowers bool `json:"manually_approves_followers"`
|
|
|
|
|
|
|
|
|
|
// Avatar is the avatar of the user in different image content types.
|
|
|
|
|
// https://lysand.org/objects/user#avatar
|
2024-08-22 23:03:38 +02:00
|
|
|
Avatar versiautils.ImageContentTypeMap `json:"avatar,omitempty"`
|
2024-08-11 03:51:22 +02:00
|
|
|
|
|
|
|
|
// Header is the header image of the user in different image content types.
|
|
|
|
|
// https://lysand.org/objects/user#header
|
2024-08-22 23:03:38 +02:00
|
|
|
Header versiautils.ImageContentTypeMap `json:"header,omitempty"`
|
2024-08-11 03:51:22 +02:00
|
|
|
|
|
|
|
|
// Bio is the biography of the user in different text content types.
|
|
|
|
|
// https://lysand.org/objects/user#bio
|
2024-08-22 23:03:38 +02:00
|
|
|
Bio versiautils.TextContentTypeMap `json:"bio"`
|
2024-08-11 03:51:22 +02:00
|
|
|
|
|
|
|
|
// Fields is a list of fields that the user has filled out.
|
|
|
|
|
// https://lysand.org/objects/user#fields
|
2024-08-22 23:03:38 +02:00
|
|
|
Fields []UserField `json:"fields,omitempty"`
|
2024-08-11 03:51:22 +02:00
|
|
|
|
|
|
|
|
// Featured is the featured posts of the user.
|
|
|
|
|
// https://lysand.org/objects/user#featured
|
2024-08-22 23:03:38 +02:00
|
|
|
Featured *versiautils.URL `json:"featured"`
|
2024-08-11 03:51:22 +02:00
|
|
|
|
|
|
|
|
// Followers is the followers of the user.
|
|
|
|
|
// https://lysand.org/objects/user#followers
|
2024-08-22 23:03:38 +02:00
|
|
|
Followers *versiautils.URL `json:"followers"`
|
2024-08-11 03:51:22 +02:00
|
|
|
|
|
|
|
|
// Following is the users that the user is following.
|
|
|
|
|
// https://lysand.org/objects/user#following
|
2024-08-22 23:03:38 +02:00
|
|
|
Following *versiautils.URL `json:"following"`
|
2024-08-11 03:51:22 +02:00
|
|
|
|
|
|
|
|
// Inbox is the inbox of the user.
|
|
|
|
|
// https://lysand.org/objects/user#posts
|
2024-08-22 23:03:38 +02:00
|
|
|
Inbox *versiautils.URL `json:"inbox"`
|
2024-08-11 03:51:22 +02:00
|
|
|
|
|
|
|
|
// Outbox is the outbox of the user.
|
|
|
|
|
// https://lysand.org/objects/user#outbox
|
2024-08-22 23:03:38 +02:00
|
|
|
Outbox *versiautils.URL `json:"outbox"`
|
2024-08-11 03:51:22 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (u User) MarshalJSON() ([]byte, error) {
|
|
|
|
|
type user User
|
|
|
|
|
u2 := user(u)
|
|
|
|
|
u2.Type = "User"
|
|
|
|
|
return json.Marshal(u2)
|
|
|
|
|
}
|
|
|
|
|
|
2024-08-22 23:03:38 +02:00
|
|
|
type UserField struct {
|
|
|
|
|
Key versiautils.TextContentTypeMap `json:"key"`
|
|
|
|
|
Value versiautils.TextContentTypeMap `json:"value"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// UserPublicKey represents a public key for a user. For more information, see the [Spec].
|
|
|
|
|
//
|
|
|
|
|
// [Spec]: https://lysand.org/security/keys#public-key-cryptography
|
|
|
|
|
type UserPublicKey struct {
|
|
|
|
|
Actor *versiautils.URL `json:"actor"`
|
|
|
|
|
|
|
|
|
|
// Algorithm can only be `ed25519` for now
|
|
|
|
|
Algorithm string `json:"algorithm"`
|
|
|
|
|
|
|
|
|
|
Key *versiacrypto.SPKIPublicKey `json:"-"`
|
|
|
|
|
RawKey json.RawMessage `json:"key"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (k *UserPublicKey) UnmarshalJSON(raw []byte) error {
|
|
|
|
|
type t UserPublicKey
|
|
|
|
|
k2 := (*t)(k)
|
|
|
|
|
|
|
|
|
|
if err := json.Unmarshal(raw, k2); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var err error
|
|
|
|
|
if k2.Key, err = versiacrypto.UnmarshalSPKIPubKey(k2.Algorithm, k2.RawKey); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
*k = UserPublicKey(*k2)
|
|
|
|
|
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (k UserPublicKey) MarshalJSON() ([]byte, error) {
|
|
|
|
|
type t UserPublicKey
|
|
|
|
|
k2 := t(k)
|
|
|
|
|
|
|
|
|
|
var err error
|
|
|
|
|
if k2.RawKey, err = k2.Key.MarshalJSON(); err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return json.Marshal(k2)
|
2024-08-11 03:51:22 +02:00
|
|
|
}
|