mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-10-31 07:22:24 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			282 lines
		
	
	
	
		
			10 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			282 lines
		
	
	
	
		
			10 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 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"`
 | |
| }
 |