summaryrefslogtreecommitdiff
path: root/internal/processing/admin/getdomainblock.go
diff options
context:
space:
mode:
Diffstat (limited to 'internal/processing/admin/getdomainblock.go')
-rw-r--r--internal/processing/admin/getdomainblock.go30
1 files changed, 30 insertions, 0 deletions
diff --git a/internal/processing/admin/getdomainblock.go b/internal/processing/admin/getdomainblock.go
new file mode 100644
index 000000000..170d82e0b
--- /dev/null
+++ b/internal/processing/admin/getdomainblock.go
@@ -0,0 +1,30 @@
+package admin
+
+import (
+ "fmt"
+
+ apimodel "github.com/superseriousbusiness/gotosocial/internal/api/model"
+ "github.com/superseriousbusiness/gotosocial/internal/db"
+ "github.com/superseriousbusiness/gotosocial/internal/gtserror"
+ "github.com/superseriousbusiness/gotosocial/internal/gtsmodel"
+)
+
+func (p *processor) DomainBlockGet(account *gtsmodel.Account, id string, export bool) (*apimodel.DomainBlock, gtserror.WithCode) {
+ domainBlock := &gtsmodel.DomainBlock{}
+
+ if err := p.db.GetByID(id, domainBlock); err != nil {
+ if _, ok := err.(db.ErrNoEntries); !ok {
+ // something has gone really wrong
+ return nil, gtserror.NewErrorInternalError(err)
+ }
+ // there are no entries for this ID
+ return nil, gtserror.NewErrorNotFound(fmt.Errorf("no entry for ID %s", id))
+ }
+
+ mastoDomainBlock, err := p.tc.DomainBlockToMasto(domainBlock, export)
+ if err != nil {
+ return nil, gtserror.NewErrorInternalError(err)
+ }
+
+ return mastoDomainBlock, nil
+}