mirror of
https://github.com/superseriousbusiness/gotosocial.git
synced 2025-01-10 16:40:12 +00:00
92de8fb396
* init instance rules database model, admin api * expose instance rules in public instance api * public /api/v1/instance/rules route * GET ruleById * createRule route * createRule auth check * updateRule * deleteRule * list rules on about page * ruleGet auth * add about page ids for anchors * process and store adding violated rules to reports * admin api models for instance rules * instance rule edit frontend * change rule inputs to textareas * database fixes after rebase (#2124) * remove unused imports * fix db migration column name * fix tests * fix more tests * fix postgres error with wrongly used Ident * add some tests, fiddle with rule model a bit, fix postgres migration * swagger docs --------- Co-authored-by: tsmethurst <tobi.smethurst@protonmail.com>
199 lines
7.8 KiB
Go
199 lines
7.8 KiB
Go
// 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 requesting an invite.
|
|
// Null if not known / 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"`
|
|
}
|
|
|
|
// AdminAccountActionRequest models the admin view of an account's details.
|
|
//
|
|
// swagger:ignore
|
|
type AdminAccountActionRequest struct {
|
|
// Type of the account action. 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 account to be acted on.
|
|
TargetAccountID string `form:"-" json:"-" xml:"-"`
|
|
}
|
|
|
|
// 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" xml:"email"`
|
|
}
|
|
|
|
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
|
|
}
|