2022-06-23 17:54:54 +03:00
/ *
GoToSocial
Copyright ( C ) 2021 - 2022 GoToSocial Authors admin @ gotosocial . org
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-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 )
}