You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
282 lines
10 KiB
282 lines
10 KiB
// GoToSocial |
|
// Copyright (C) GoToSocial Authors admin@gotosocial.org |
|
// SPDX-License-Identifier: AGPL-3.0-or-later |
|
// |
|
// 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 |
|
|
|
// AdminAccountInfo models the admin view of an account's details. |
|
// |
|
// swagger:model adminAccountInfo |
|
type AdminAccountInfo struct { |
|
// The ID of the account in the database. |
|
// example: 01GQ4PHNT622DQ9X95XQX4KKNR |
|
ID string `json:"id"` |
|
// The username of the account. |
|
// example: dril |
|
Username string `json:"username"` |
|
// The domain of the account. |
|
// Null for local accounts. |
|
// example: example.org |
|
Domain *string `json:"domain"` |
|
// When the account was first discovered. (ISO 8601 Datetime) |
|
// example: 2021-07-30T09:20:25+00:00 |
|
CreatedAt string `json:"created_at"` |
|
// The email address associated with the account. |
|
// Empty string for remote accounts or accounts with |
|
// no known email address. |
|
// example: someone@somewhere.com |
|
Email string `json:"email"` |
|
// The IP address last used to login to this account. |
|
// Null if not known. |
|
// example: 192.0.2.1 |
|
IP *string `json:"ip"` |
|
// All known IP addresses associated with this account. |
|
// NOT IMPLEMENTED (will always be empty array). |
|
// example: [] |
|
IPs []interface{} `json:"ips"` |
|
// The locale of the account. (ISO 639 Part 1 two-letter language code) |
|
// example: en |
|
Locale string `json:"locale"` |
|
// The reason given when signing up. |
|
// Null if no reason / remote account. |
|
// example: Pleaaaaaaaaaaaaaaase!! |
|
InviteRequest *string `json:"invite_request"` |
|
// The current role of the account. |
|
Role AccountRole `json:"role"` |
|
// Whether the account has confirmed their email address. |
|
Confirmed bool `json:"confirmed"` |
|
// Whether the account is currently approved. |
|
Approved bool `json:"approved"` |
|
// Whether the account is currently disabled. |
|
Disabled bool `json:"disabled"` |
|
// Whether the account is currently silenced |
|
Silenced bool `json:"silenced"` |
|
// Whether the account is currently suspended. |
|
Suspended bool `json:"suspended"` |
|
// User-level information about the account. |
|
Account *Account `json:"account"` |
|
// The ID of the application that created this account. |
|
CreatedByApplicationID string `json:"created_by_application_id,omitempty"` |
|
// The ID of the account that invited this user |
|
InvitedByAccountID string `json:"invited_by_account_id,omitempty"` |
|
} |
|
|
|
// AdminReport models the admin view of a report. |
|
// |
|
// swagger:model adminReport |
|
type AdminReport struct { |
|
// ID of the report. |
|
// example: 01FBVD42CQ3ZEEVMW180SBX03B |
|
ID string `json:"id"` |
|
// Whether an action has been taken by an admin in response to this report. |
|
// example: false |
|
ActionTaken bool `json:"action_taken"` |
|
// If an action was taken, at what time was this done? (ISO 8601 Datetime) |
|
// Will be null if not set / no action yet taken. |
|
// example: 2021-07-30T09:20:25+00:00 |
|
ActionTakenAt *string `json:"action_taken_at"` |
|
// Under what category was this report created? |
|
// example: spam |
|
Category string `json:"category"` |
|
// Comment submitted when the report was created. |
|
// Will be empty if no comment was submitted. |
|
// example: This person has been harassing me. |
|
Comment string `json:"comment"` |
|
// Bool to indicate that report should be federated to remote instance. |
|
// example: true |
|
Forwarded bool `json:"forwarded"` |
|
// The date when this report was created (ISO 8601 Datetime). |
|
// example: 2021-07-30T09:20:25+00:00 |
|
CreatedAt string `json:"created_at"` |
|
// Time of last action on this report (ISO 8601 Datetime). |
|
// example: 2021-07-30T09:20:25+00:00 |
|
UpdatedAt string `json:"updated_at"` |
|
// The account that created the report. |
|
Account *AdminAccountInfo `json:"account"` |
|
// Account that was reported. |
|
TargetAccount *AdminAccountInfo `json:"target_account"` |
|
// The account assigned to handle the report. |
|
// Null if no account assigned. |
|
AssignedAccount *AdminAccountInfo `json:"assigned_account"` |
|
// Account that took admin action (if any). |
|
// Null if no action (yet) taken. |
|
ActionTakenByAccount *AdminAccountInfo `json:"action_taken_by_account"` |
|
// Array of statuses that were submitted along with this report. |
|
// Will be empty if no status IDs were submitted with the report. |
|
Statuses []*Status `json:"statuses"` |
|
// Array of rules that were broken according to this report. |
|
// Will be empty if no rule IDs were submitted with the report. |
|
Rules []*InstanceRule `json:"rules"` |
|
// If an action was taken, what comment was made by the admin on the taken action? |
|
// Will be null if not set / no action yet taken. |
|
// example: Account was suspended. |
|
ActionTakenComment *string `json:"action_taken_comment"` |
|
} |
|
|
|
// AdminReportResolveRequest can be submitted along with a POST to /api/v1/admin/reports/{id}/resolve |
|
// |
|
// swagger:ignore |
|
type AdminReportResolveRequest struct { |
|
// Comment to show to the creator of the report when an admin marks it as resolved. |
|
ActionTakenComment *string `form:"action_taken_comment" json:"action_taken_comment" xml:"action_taken_comment"` |
|
} |
|
|
|
// AdminEmoji models the admin view of a custom emoji. |
|
// |
|
// swagger:model adminEmoji |
|
type AdminEmoji struct { |
|
Emoji |
|
// The ID of the emoji. |
|
// example: 01GEM7SFDZ7GZNRXFVZ3X4E4N1 |
|
ID string `json:"id"` |
|
// True if this emoji has been disabled by an admin action. |
|
// example: false |
|
Disabled bool `json:"disabled"` |
|
// The domain from which the emoji originated. Only defined for remote domains, otherwise key will not be set. |
|
// |
|
// example: example.org |
|
Domain string `json:"domain,omitempty"` |
|
// Time when the emoji image was last updated. |
|
// example: 2022-10-05T09:21:26.419Z |
|
UpdatedAt string `json:"updated_at"` |
|
// The total file size taken up by the emoji in bytes, including static and animated versions. |
|
// example: 69420 |
|
TotalFileSize int `json:"total_file_size"` |
|
// The MIME content type of the emoji. |
|
// example: image/png |
|
ContentType string `json:"content_type"` |
|
// The ActivityPub URI of the emoji. |
|
// example: https://example.org/emojis/016T5Q3SQKBT337DAKVSKNXXW1 |
|
URI string `json:"uri"` |
|
} |
|
|
|
// AdminActionRequest models a request |
|
// for an admin action to be performed. |
|
// |
|
// swagger:ignore |
|
type AdminActionRequest struct { |
|
// Category of the target entity. |
|
Category string `form:"-" json:"-" xml:"-"` |
|
// Type of admin action to take. One of disable, silence, suspend. |
|
Type string `form:"type" json:"type" xml:"type"` |
|
// Text describing why an action was taken. |
|
Text string `form:"text" json:"text" xml:"text"` |
|
// ID of the target entity. |
|
TargetID string `form:"-" json:"-" xml:"-"` |
|
} |
|
|
|
// AdminActionResponse models the server |
|
// response to an admin action. |
|
// |
|
// swagger:model adminActionResponse |
|
type AdminActionResponse struct { |
|
// Internal ID of the action. |
|
// |
|
// example: 01H9QG6TZ9W5P0402VFRVM17TH |
|
ActionID string `json:"action_id"` |
|
} |
|
|
|
// MediaCleanupRequest models admin media cleanup parameters |
|
// |
|
// swagger:parameters mediaCleanup |
|
type MediaCleanupRequest struct { |
|
// Number of days of remote media to keep. Native values will be treated as 0. |
|
// If value is not specified, the value of media-remote-cache-days in the server config will be used. |
|
RemoteCacheDays *int `form:"remote_cache_days" json:"remote_cache_days" xml:"remote_cache_days"` |
|
} |
|
|
|
// AdminSendTestEmailRequest models a test email send request (woah). |
|
type AdminSendTestEmailRequest struct { |
|
// Email address to send the test email to. |
|
Email string `form:"email" json:"email"` |
|
// Optional message to include in the test email. |
|
Message string `form:"message" json:"message"` |
|
} |
|
|
|
type AdminInstanceRule struct { |
|
ID string `json:"id"` // id of this item in the database |
|
CreatedAt string `json:"created_at"` // when was item created |
|
UpdatedAt string `json:"updated_at"` // when was item last updated |
|
Text string `json:"text"` // text content of the rule |
|
} |
|
|
|
// DebugAPUrlResponse provides detailed debug |
|
// information for an AP URL dereference request. |
|
// |
|
// swagger:model debugAPUrlResponse |
|
type DebugAPUrlResponse struct { |
|
// Remote AP URL that was requested. |
|
RequestURL string `json:"request_url"` |
|
// HTTP headers used in the outgoing request. |
|
RequestHeaders map[string][]string `json:"request_headers"` |
|
// HTTP headers returned from the remote instance. |
|
ResponseHeaders map[string][]string `json:"response_headers"` |
|
// HTTP response code returned from the remote instance. |
|
ResponseCode int `json:"response_code"` |
|
// Body returned from the remote instance. |
|
// Will be stringified bytes; may be JSON, |
|
// may be an error, may be both! |
|
ResponseBody string `json:"response_body"` |
|
} |
|
|
|
// AdminGetAccountsRequest models a request |
|
// to get an admin view of one or more |
|
// accounts using given parameters. |
|
// |
|
// swagger:ignore |
|
type AdminGetAccountsRequest struct { |
|
// Filter for `local` or `remote` accounts. |
|
Origin string |
|
// Filter for `active`, `pending`, `disabled`, |
|
// `silenced`, or `suspended` accounts. |
|
Status string |
|
// Filter for accounts with staff perms |
|
// (users that can manage reports). |
|
Permissions string |
|
// Filter for users with these roles. |
|
RoleIDs []string |
|
// Lookup users invited by the account with this ID. |
|
InvitedBy string |
|
// Search for the given username. |
|
Username string |
|
// Search for the given display name. |
|
DisplayName string |
|
// Filter by the given domain. |
|
ByDomain string |
|
// Lookup a user with this email. |
|
Email string |
|
// Lookup users with this IP address. |
|
IP string |
|
// API version to use for this request (1 or 2). |
|
// Set internally, not by callers. |
|
APIVersion int |
|
} |
|
|
|
// AdminAccountRejectRequest models a |
|
// request to deny a new account sign-up. |
|
// |
|
// swagger:ignore |
|
type AdminAccountRejectRequest struct { |
|
// Comment to leave on why the account was denied. |
|
// The comment will be visible to admins only. |
|
PrivateComment string `form:"private_comment" json:"private_comment"` |
|
// Message to include in email to applicant. |
|
// Will be included only if send_email is true. |
|
Message string `form:"message" json:"message"` |
|
// Send an email to the applicant informing |
|
// them that their sign-up has been rejected. |
|
SendEmail bool `form:"send_email" json:"send_email"` |
|
}
|
|
|