2021-05-09 15:06:06 +03:00
package instance
import (
"net/http"
2021-12-11 19:50:00 +03:00
"github.com/superseriousbusiness/gotosocial/internal/api"
2021-12-07 15:31:39 +03:00
"github.com/superseriousbusiness/gotosocial/internal/config"
2022-06-08 21:38:03 +03:00
"github.com/superseriousbusiness/gotosocial/internal/gtserror"
2021-12-07 15:31:39 +03:00
2021-05-09 15:06:06 +03:00
"github.com/gin-gonic/gin"
)
2021-08-02 20:06:44 +03:00
// InstanceInformationGETHandler swagger:operation GET /api/v1/instance instanceGet
//
// View instance information.
//
// This is mostly provided for Mastodon application compatibility, since many apps that work with Mastodon use `/api/v1/instance` to inform their connection parameters.
//
// However, it can also be used by other instances for gathering instance information and representing instances in some UI or other.
//
// ---
// tags:
// - instance
//
// produces:
// - application/json
//
// responses:
// '200':
// description: "Instance information."
// schema:
// "$ref": "#/definitions/instance"
2022-06-08 21:38:03 +03:00
// '406':
// description: not acceptable
2021-08-02 20:06:44 +03:00
// '500':
// description: internal error
2021-05-09 15:06:06 +03:00
func ( m * Module ) InstanceInformationGETHandler ( c * gin . Context ) {
2021-12-11 19:50:00 +03:00
if _ , err := api . NegotiateAccept ( c , api . JSONAcceptHeaders ... ) ; err != nil {
2022-06-08 21:38:03 +03:00
api . ErrorHandler ( c , gtserror . NewErrorNotAcceptable ( err , err . Error ( ) ) , m . processor . InstanceGet )
2021-12-11 19:50:00 +03:00
return
}
2022-06-08 21:38:03 +03:00
instance , errWithCode := m . processor . InstanceGet ( c . Request . Context ( ) , config . GetHost ( ) )
if errWithCode != nil {
api . ErrorHandler ( c , errWithCode , m . processor . InstanceGet )
2021-05-09 15:06:06 +03:00
return
}
c . JSON ( http . StatusOK , instance )
}