From af61b2249ab9d0afb7424509112d06c578dca059 Mon Sep 17 00:00:00 2001 From: Gustavo Marin Date: Sat, 29 Feb 2020 07:19:32 +0100 Subject: adds API endpoints to manage OAuth2 Application (list/create/delete) (#10437) * add API endpoint to create OAuth2 Application. * move endpoint to /user. Add swagger documentations and proper response type. * change json tags to snake_case. add CreateOAuth2ApplicationOptions to swagger docs. * change response status to Created (201) * add methods to list OAuth2 apps and delete an existing OAuth2 app by ID. * add APIFormat convert method and file header * fixed header * hide secret on oauth2 application list * add Created time to API response * add API integration tests for create/list/delete OAuth2 applications. Co-authored-by: techknowlogick Co-authored-by: zeripath Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com> --- models/oauth2_application.go | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) (limited to 'models/oauth2_application.go') diff --git a/models/oauth2_application.go b/models/oauth2_application.go index 4df207ae16..f888cf61b8 100644 --- a/models/oauth2_application.go +++ b/models/oauth2_application.go @@ -252,6 +252,23 @@ func DeleteOAuth2Application(id, userid int64) error { return sess.Commit() } +// ListOAuth2Applications returns a list of oauth2 applications belongs to given user. +func ListOAuth2Applications(uid int64, listOptions ListOptions) ([]*OAuth2Application, error) { + sess := x. + Where("uid=?", uid). + Desc("id") + + if listOptions.Page != 0 { + sess = listOptions.setSessionPagination(sess) + + apps := make([]*OAuth2Application, 0, listOptions.PageSize) + return apps, sess.Find(&apps) + } + + apps := make([]*OAuth2Application, 0, 5) + return apps, sess.Find(&apps) +} + ////////////////////////////////////////////////////// // OAuth2AuthorizationCode is a code to obtain an access token in combination with the client secret once. It has a limited lifetime. -- cgit v1.2.3