2023-03-12 16:00:57 +01:00
|
|
|
// 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/>.
|
2021-08-20 12:26:56 +02:00
|
|
|
|
|
|
|
package db
|
|
|
|
|
|
|
|
import (
|
2021-08-25 15:34:33 +02:00
|
|
|
"context"
|
2024-04-11 11:45:53 +02:00
|
|
|
"time"
|
2021-08-20 12:26:56 +02:00
|
|
|
|
|
|
|
"github.com/superseriousbusiness/gotosocial/internal/gtsmodel"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Admin contains functions related to instance administration (new signups etc).
|
|
|
|
type Admin interface {
|
|
|
|
// IsUsernameAvailable checks whether a given username is available on our domain.
|
|
|
|
// Returns an error if the username is already taken, or something went wrong in the db.
|
2023-07-25 09:34:05 +01:00
|
|
|
IsUsernameAvailable(ctx context.Context, username string) (bool, error)
|
2021-08-20 12:26:56 +02:00
|
|
|
|
|
|
|
// IsEmailAvailable checks whether a given email address for a new account is available to be used on our domain.
|
|
|
|
// Return an error if:
|
|
|
|
// A) the email is already associated with an account
|
|
|
|
// B) we block signups from this email domain
|
|
|
|
// C) something went wrong in the db
|
2023-07-25 09:34:05 +01:00
|
|
|
IsEmailAvailable(ctx context.Context, email string) (bool, error)
|
2021-08-20 12:26:56 +02:00
|
|
|
|
2024-04-11 11:45:53 +02:00
|
|
|
// NewSignup creates a new user + account in the database with the given parameters.
|
2021-08-20 12:26:56 +02:00
|
|
|
// By the time this function is called, it should be assumed that all the parameters have passed validation!
|
2023-07-25 09:34:05 +01:00
|
|
|
NewSignup(ctx context.Context, newSignup gtsmodel.NewSignup) (*gtsmodel.User, error)
|
2021-08-20 12:26:56 +02:00
|
|
|
|
|
|
|
// CreateInstanceAccount creates an account in the database with the same username as the instance host value.
|
|
|
|
// Ie., if the instance is hosted at 'example.org' the instance user will have a username of 'example.org'.
|
|
|
|
// This is needed for things like serving files that belong to the instance and not an individual user/account.
|
2023-07-25 09:34:05 +01:00
|
|
|
CreateInstanceAccount(ctx context.Context) error
|
2021-08-20 12:26:56 +02:00
|
|
|
|
|
|
|
// CreateInstanceInstance creates an instance in the database with the same domain as the instance host value.
|
|
|
|
// Ie., if the instance is hosted at 'example.org' the instance will have a domain of 'example.org'.
|
|
|
|
// This is needed for things like serving instance information through /api/v1/instance
|
2023-07-25 09:34:05 +01:00
|
|
|
CreateInstanceInstance(ctx context.Context) error
|
2023-09-04 15:55:17 +02:00
|
|
|
|
2024-04-11 11:45:53 +02:00
|
|
|
// CreateInstanceApplication creates an application in the database
|
|
|
|
// for use in processing signups etc through the sign-up form.
|
|
|
|
CreateInstanceApplication(ctx context.Context) error
|
|
|
|
|
|
|
|
// GetInstanceApplication gets the instance application
|
|
|
|
// (ie., the application owned by the instance account).
|
|
|
|
GetInstanceApplication(ctx context.Context) (*gtsmodel.Application, error)
|
|
|
|
|
|
|
|
// CountApprovedSignupsSince counts the number of new account
|
|
|
|
// sign-ups approved on this instance since the given time.
|
|
|
|
CountApprovedSignupsSince(ctx context.Context, since time.Time) (int, error)
|
|
|
|
|
|
|
|
// CountUnhandledSignups counts the number of account sign-ups
|
|
|
|
// that have not yet been approved or denied. In other words,
|
|
|
|
// the number of pending sign-ups sitting in the backlog.
|
|
|
|
CountUnhandledSignups(ctx context.Context) (int, error)
|
|
|
|
|
2023-09-04 15:55:17 +02:00
|
|
|
/*
|
|
|
|
ACTION FUNCS
|
|
|
|
*/
|
|
|
|
|
|
|
|
// GetAdminAction returns the admin action with the given ID.
|
|
|
|
GetAdminAction(ctx context.Context, id string) (*gtsmodel.AdminAction, error)
|
|
|
|
|
|
|
|
// GetAdminActions gets all admin actions from the database.
|
|
|
|
GetAdminActions(ctx context.Context) ([]*gtsmodel.AdminAction, error)
|
|
|
|
|
|
|
|
// PutAdminAction puts one admin action in the database.
|
|
|
|
PutAdminAction(ctx context.Context, action *gtsmodel.AdminAction) error
|
|
|
|
|
|
|
|
// UpdateAdminAction updates one admin action by its ID.
|
|
|
|
UpdateAdminAction(ctx context.Context, action *gtsmodel.AdminAction, columns ...string) error
|
|
|
|
|
|
|
|
// DeleteAdminAction deletes admin action with the given ID.
|
|
|
|
DeleteAdminAction(ctx context.Context, id string) error
|
2021-08-20 12:26:56 +02:00
|
|
|
}
|