diff options
Diffstat (limited to 'internal/db/bundb')
| -rw-r--r-- | internal/db/bundb/media.go | 91 | ||||
| -rw-r--r-- | internal/db/bundb/media_test.go | 15 | ||||
| -rw-r--r-- | internal/db/bundb/migrations/20230821075342_attachment_cleanup_updates.go | 61 | 
3 files changed, 64 insertions, 103 deletions
| diff --git a/internal/db/bundb/media.go b/internal/db/bundb/media.go index 7f079cb34..fe6aefa90 100644 --- a/internal/db/bundb/media.go +++ b/internal/db/bundb/media.go @@ -200,23 +200,6 @@ func (m *mediaDB) DeleteAttachment(ctx context.Context, id string) error {  	return err  } -func (m *mediaDB) CountRemoteOlderThan(ctx context.Context, olderThan time.Time) (int, error) { -	q := m.db. -		NewSelect(). -		TableExpr("? AS ?", bun.Ident("media_attachments"), bun.Ident("media_attachment")). -		Column("media_attachment.id"). -		Where("? = ?", bun.Ident("media_attachment.cached"), true). -		Where("? IS NOT NULL", bun.Ident("media_attachment.remote_url")). -		Where("? < ?", bun.Ident("media_attachment.created_at"), olderThan) - -	count, err := q.Count(ctx) -	if err != nil { -		return 0, err -	} - -	return count, nil -} -  func (m *mediaDB) GetAttachments(ctx context.Context, maxID string, limit int) ([]*gtsmodel.MediaAttachment, error) {  	attachmentIDs := make([]string, 0, limit) @@ -286,77 +269,3 @@ func (m *mediaDB) GetCachedAttachmentsOlderThan(ctx context.Context, olderThan t  	return m.GetAttachmentsByIDs(ctx, attachmentIDs)  } - -func (m *mediaDB) GetAvatarsAndHeaders(ctx context.Context, maxID string, limit int) ([]*gtsmodel.MediaAttachment, error) { -	attachmentIDs := make([]string, 0, limit) - -	q := m.db.NewSelect(). -		TableExpr("? AS ?", bun.Ident("media_attachments"), bun.Ident("media_attachment")). -		Column("media_attachment.id"). -		WhereGroup(" AND ", func(innerQ *bun.SelectQuery) *bun.SelectQuery { -			return innerQ. -				WhereOr("? = ?", bun.Ident("media_attachment.avatar"), true). -				WhereOr("? = ?", bun.Ident("media_attachment.header"), true) -		}). -		Order("media_attachment.id DESC") - -	if maxID != "" { -		q = q.Where("? < ?", bun.Ident("media_attachment.id"), maxID) -	} - -	if limit != 0 { -		q = q.Limit(limit) -	} - -	if err := q.Scan(ctx, &attachmentIDs); err != nil { -		return nil, err -	} - -	return m.GetAttachmentsByIDs(ctx, attachmentIDs) -} - -func (m *mediaDB) GetLocalUnattachedOlderThan(ctx context.Context, olderThan time.Time, limit int) ([]*gtsmodel.MediaAttachment, error) { -	attachmentIDs := make([]string, 0, limit) - -	q := m.db. -		NewSelect(). -		TableExpr("? AS ?", bun.Ident("media_attachments"), bun.Ident("media_attachment")). -		Column("media_attachment.id"). -		Where("? = ?", bun.Ident("media_attachment.cached"), true). -		Where("? = ?", bun.Ident("media_attachment.avatar"), false). -		Where("? = ?", bun.Ident("media_attachment.header"), false). -		Where("? < ?", bun.Ident("media_attachment.created_at"), olderThan). -		Where("? IS NULL", bun.Ident("media_attachment.remote_url")). -		Where("? IS NULL", bun.Ident("media_attachment.status_id")). -		Order("media_attachment.created_at DESC") - -	if limit != 0 { -		q = q.Limit(limit) -	} - -	if err := q.Scan(ctx, &attachmentIDs); err != nil { -		return nil, err -	} - -	return m.GetAttachmentsByIDs(ctx, attachmentIDs) -} - -func (m *mediaDB) CountLocalUnattachedOlderThan(ctx context.Context, olderThan time.Time) (int, error) { -	q := m.db. -		NewSelect(). -		TableExpr("? AS ?", bun.Ident("media_attachments"), bun.Ident("media_attachment")). -		Column("media_attachment.id"). -		Where("? = ?", bun.Ident("media_attachment.cached"), true). -		Where("? = ?", bun.Ident("media_attachment.avatar"), false). -		Where("? = ?", bun.Ident("media_attachment.header"), false). -		Where("? < ?", bun.Ident("media_attachment.created_at"), olderThan). -		Where("? IS NULL", bun.Ident("media_attachment.remote_url")). -		Where("? IS NULL", bun.Ident("media_attachment.status_id")) - -	count, err := q.Count(ctx) -	if err != nil { -		return 0, err -	} - -	return count, nil -} diff --git a/internal/db/bundb/media_test.go b/internal/db/bundb/media_test.go index 59b927119..691c81729 100644 --- a/internal/db/bundb/media_test.go +++ b/internal/db/bundb/media_test.go @@ -23,7 +23,6 @@ import (  	"time"  	"github.com/stretchr/testify/suite" -	"github.com/superseriousbusiness/gotosocial/testrig"  )  type MediaTestSuite struct { @@ -43,20 +42,12 @@ func (suite *MediaTestSuite) TestGetOlder() {  	suite.Len(attachments, 2)  } -func (suite *MediaTestSuite) TestGetAvisAndHeaders() { +func (suite *MediaTestSuite) TestGetCachedAttachmentsOlderThan() {  	ctx := context.Background() -	attachments, err := suite.db.GetAvatarsAndHeaders(ctx, "", 20) +	attachments, err := suite.db.GetCachedAttachmentsOlderThan(ctx, time.Now(), 20)  	suite.NoError(err) -	suite.Len(attachments, 3) -} - -func (suite *MediaTestSuite) TestGetLocalUnattachedOlderThan() { -	ctx := context.Background() - -	attachments, err := suite.db.GetLocalUnattachedOlderThan(ctx, testrig.TimeMustParse("2090-06-04T13:12:00Z"), 10) -	suite.NoError(err) -	suite.Len(attachments, 1) +	suite.Len(attachments, 2)  }  func TestMediaTestSuite(t *testing.T) { diff --git a/internal/db/bundb/migrations/20230821075342_attachment_cleanup_updates.go b/internal/db/bundb/migrations/20230821075342_attachment_cleanup_updates.go new file mode 100644 index 000000000..2ee0a0c7d --- /dev/null +++ b/internal/db/bundb/migrations/20230821075342_attachment_cleanup_updates.go @@ -0,0 +1,61 @@ +// 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 migrations + +import ( +	"context" + +	"github.com/superseriousbusiness/gotosocial/internal/log" +	"github.com/uptrace/bun" +) + +func init() { +	up := func(ctx context.Context, db *bun.DB) error { +		return db.RunInTx(ctx, nil, func(ctx context.Context, tx bun.Tx) error { +			log.Info(ctx, "dropping previous media attachment cleanup index, please wait and don't interrupt it (this may take a while)") +			if _, err := tx. +				NewDropIndex(). +				Index("media_attachments_cleanup_idx"). +				Exec(ctx); err != nil { +				return err +			} + +			log.Info(ctx, "creating new media attachment cleanup index, please wait and don't interrupt it (this may take a while)") +			if _, err := tx. +				NewCreateIndex(). +				Table("media_attachments"). +				Index("media_attachments_cleanup_idx"). +				Column("cached", "created_at"). +				Exec(ctx); err != nil { +				return err +			} + +			return nil +		}) +	} + +	down := func(ctx context.Context, db *bun.DB) error { +		return db.RunInTx(ctx, nil, func(ctx context.Context, tx bun.Tx) error { +			return nil +		}) +	} + +	if err := Migrations.Register(up, down); err != nil { +		panic(err) +	} +} | 
