refactor(args): request argument access and update dependencies (#42) All checks were successful release-nightly / release-image (push) Successful in 3m4s
All checks were successful
release-nightly / release-image (push) Successful in 3m4s
- Update dependencies to newer versions in go.mod - Refactor all request argument accesses to use req.GetArguments() instead of direct access to req.Params.Arguments - Change variable declaration for ListRepoCommitsTool from a grouped var block to a single var statement for consistency Signed-off-by: Bo-Yi Wu <appleboy.tw@gmail.com> Reviewed-on: #42 Co-authored-by: Bo-Yi Wu <appleboy.tw@gmail.com> Co-committed-by: Bo-Yi Wu <appleboy.tw@gmail.com>
This commit was merged in pull request #42.
This commit is contained in:
10 go.mod
10
go.mod @@ -4,20 +4,20 @@ go 1.24.0 | ||||
| ||||
require ( | ||||
code.gitea.io/sdk/gitea v0.21.0 | ||||
github.com/mark3labs/mcp-go v0.22.0 | ||||
github.com/mark3labs/mcp-go v0.30.0 | ||||
go.uber.org/zap v1.27.0 | ||||
gopkg.in/natefinch/lumberjack.v2 v2.2.1 | ||||
) | ||||
| ||||
require ( | ||||
github.com/42wim/httpsig v1.2.2 // indirect | ||||
github.com/42wim/httpsig v1.2.3 // indirect | ||||
github.com/davidmz/go-pageant v1.0.2 // indirect | ||||
github.com/go-fed/httpsig v1.1.0 // indirect | ||||
github.com/google/uuid v1.6.0 // indirect | ||||
github.com/hashicorp/go-version v1.7.0 // indirect | ||||
github.com/spf13/cast v1.7.1 // indirect | ||||
github.com/spf13/cast v1.8.0 // indirect | ||||
github.com/yosida95/uritemplate/v3 v3.0.2 // indirect | ||||
go.uber.org/multierr v1.11.0 // indirect | ||||
golang.org/x/crypto v0.37.0 // indirect | ||||
golang.org/x/sys v0.32.0 // indirect | ||||
golang.org/x/crypto v0.38.0 // indirect | ||||
golang.org/x/sys v0.33.0 // indirect | ||||
) | ||||
|
24 go.sum
24
go.sum @@ -1,7 +1,7 @@ | ||||
code.gitea.io/sdk/gitea v0.21.0 h1:69n6oz6kEVHRo1+APQQyizkhrZrLsTLXey9142pfkD4= | ||||
code.gitea.io/sdk/gitea v0.21.0/go.mod h1:tnBjVhuKJCn8ibdyyhvUyxrR1Ca2KHEoTWoukNhXQPA= | ||||
github.com/42wim/httpsig v1.2.2 h1:ofAYoHUNs/MJOLqQ8hIxeyz2QxOz8qdSVvp3PX/oPgA= | ||||
github.com/42wim/httpsig v1.2.2/go.mod h1:P/UYo7ytNBFwc+dg35IubuAUIs8zj5zzFIgUCEl55WY= | ||||
github.com/42wim/httpsig v1.2.3 h1:xb0YyWhkYj57SPtfSttIobJUPJZB9as1nsfo7KWVcEs= | ||||
github.com/42wim/httpsig v1.2.3/go.mod h1:nZq9OlYKDrUBhptd77IHx4/sZZD+IxTBADvAPI9G/EM= | ||||
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= | ||||
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= | ||||
github.com/davidmz/go-pageant v1.0.2 h1:bPblRCh5jGU+Uptpz6LgMZGD5hJoOt7otgT454WvHn0= | ||||
@@ -20,14 +20,14 @@ github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE= | ||||
github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk= | ||||
github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= | ||||
github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= | ||||
github.com/mark3labs/mcp-go v0.22.0 h1:cCEBWi4Yy9Kio+OW1hWIyi4WLsSr+RBBK6FI5tj+b7I= | ||||
github.com/mark3labs/mcp-go v0.22.0/go.mod h1:rXqOudj/djTORU/ThxYx8fqEVj/5pvTuuebQ2RC7uk4= | ||||
github.com/mark3labs/mcp-go v0.30.0 h1:Taz7fiefkxY/l8jz1nA90V+WdM2eoMtlvwfWforVYbo= | ||||
github.com/mark3labs/mcp-go v0.30.0/go.mod h1:rXqOudj/djTORU/ThxYx8fqEVj/5pvTuuebQ2RC7uk4= | ||||
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= | ||||
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= | ||||
github.com/rogpeppe/go-internal v1.9.0 h1:73kH8U+JUqXU8lRuOHeVHaa/SZPifC7BkcraZVejAe8= | ||||
github.com/rogpeppe/go-internal v1.9.0/go.mod h1:WtVeX8xhTBvf0smdhujwtBcq4Qrzq/fJaraNFVN+nFs= | ||||
github.com/spf13/cast v1.7.1 h1:cuNEagBQEHWN1FnbGEjCXL2szYEXqfJPbP2HNUaca9Y= | ||||
github.com/spf13/cast v1.7.1/go.mod h1:ancEpBxwJDODSW/UG4rDrAqiKolqNNh2DX3mk86cAdo= | ||||
github.com/spf13/cast v1.8.0 h1:gEN9K4b8Xws4EX0+a0reLmhq8moKn7ntRlQYgjPeCDk= | ||||
github.com/spf13/cast v1.8.0/go.mod h1:ancEpBxwJDODSW/UG4rDrAqiKolqNNh2DX3mk86cAdo= | ||||
github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA= | ||||
github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY= | ||||
github.com/yosida95/uritemplate/v3 v3.0.2 h1:Ed3Oyj9yrmi9087+NczuL5BwkIc4wvTb5zIM+UJPGz4= | ||||
@@ -41,18 +41,18 @@ go.uber.org/zap v1.27.0/go.mod h1:GB2qFLM7cTU87MWRP2mPIjqfIDnGu+VIO4V/SdhGo2E= | ||||
golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= | ||||
golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= | ||||
golang.org/x/crypto v0.0.0-20210513164829-c07d793c2f9a/go.mod h1:P+XmwS30IXTQdn5tA2iutPOUgjI07+tq3H3K9MVA1s8= | ||||
golang.org/x/crypto v0.37.0 h1:kJNSjF/Xp7kU0iB2Z+9viTPMW4EqqsrywMXLJOOsXSE= | ||||
golang.org/x/crypto v0.37.0/go.mod h1:vg+k43peMZ0pUMhYmVAWysMK35e6ioLh3wB8ZCAfbVc= | ||||
golang.org/x/crypto v0.38.0 h1:jt+WWG8IZlBnVbomuhg2Mdq0+BBQaHbtqHEFEigjUV8= | ||||
golang.org/x/crypto v0.38.0/go.mod h1:MvrbAqul58NNYPKnOra203SB9vpuZW0e+RRZV+Ggqjw= | ||||
golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= | ||||
golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= | ||||
golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||
golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
golang.org/x/sys v0.32.0 h1:s77OFDvIQeibCmezSnk/q6iAfkdiQaJi4VzroCFrN20= | ||||
golang.org/x/sys v0.32.0/go.mod h1:BJP2sWEmIv4KK5OTEluFJCKSidICx8ciO85XgH3Ak8k= | ||||
golang.org/x/sys v0.33.0 h1:q3i8TbbEz+JRD9ywIRlyRAQbM0qF7hu24q3teo2hbuw= | ||||
golang.org/x/sys v0.33.0/go.mod h1:BJP2sWEmIv4KK5OTEluFJCKSidICx8ciO85XgH3Ak8k= | ||||
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= | ||||
golang.org/x/term v0.31.0 h1:erwDkOK1Msy6offm1mOgvspSkslFnIGsFnxOKoufg3o= | ||||
golang.org/x/term v0.31.0/go.mod h1:R4BeIy7D95HzImkxGkTW1UQTtP54tio2RyHz7PwK0aw= | ||||
golang.org/x/term v0.32.0 h1:DR4lr0TjUs3epypdhTOkMmuF5CDFJ/8pOnbzMZPQ7bg= | ||||
golang.org/x/term v0.32.0/go.mod h1:uZG1FhGx848Sqfsq4/DlJr3xGGsYMu/L5GW4abiaEPQ= | ||||
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= | ||||
golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= | ||||
golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
|
@@ -99,15 +99,15 @@ func init() { | ||||
| ||||
func GetIssueByIndexFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called GetIssueByIndexFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
index, ok := req.Params.Arguments["index"].(float64) | ||||
index, ok := req.GetArguments()["index"].(float64) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("index is required")) | ||||
} | ||||
@@ -121,23 +121,23 @@ func GetIssueByIndexFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallT | ||||
| ||||
func ListRepoIssuesFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called ListIssuesFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
state, ok := req.Params.Arguments["state"].(string) | ||||
state, ok := req.GetArguments()["state"].(string) | ||||
if !ok { | ||||
state = "all" | ||||
} | ||||
page, ok := req.Params.Arguments["page"].(float64) | ||||
page, ok := req.GetArguments()["page"].(float64) | ||||
if !ok { | ||||
page = 1 | ||||
} | ||||
pageSize, ok := req.Params.Arguments["pageSize"].(float64) | ||||
pageSize, ok := req.GetArguments()["pageSize"].(float64) | ||||
if !ok { | ||||
pageSize = 100 | ||||
} | ||||
@@ -157,19 +157,19 @@ func ListRepoIssuesFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallTo | ||||
| ||||
func CreateIssueFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called CreateIssueFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
title, ok := req.Params.Arguments["title"].(string) | ||||
title, ok := req.GetArguments()["title"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("title is required")) | ||||
} | ||||
body, ok := req.Params.Arguments["body"].(string) | ||||
body, ok := req.GetArguments()["body"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("body is required")) | ||||
} | ||||
@@ -186,19 +186,19 @@ func CreateIssueFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolR | ||||
| ||||
func CreateIssueCommentFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called CreateIssueCommentFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
index, ok := req.Params.Arguments["index"].(float64) | ||||
index, ok := req.GetArguments()["index"].(float64) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("index is required")) | ||||
} | ||||
body, ok := req.Params.Arguments["body"].(string) | ||||
body, ok := req.GetArguments()["body"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("body is required")) | ||||
} | ||||
@@ -215,38 +215,38 @@ func CreateIssueCommentFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.Ca | ||||
| ||||
func EditIssueFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called EditIssueFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
index, ok := req.Params.Arguments["index"].(float64) | ||||
index, ok := req.GetArguments()["index"].(float64) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("index is required")) | ||||
} | ||||
| ||||
opt := gitea_sdk.EditIssueOption{} | ||||
| ||||
title, ok := req.Params.Arguments["title"].(string) | ||||
title, ok := req.GetArguments()["title"].(string) | ||||
if ok { | ||||
opt.Title = title | ||||
} | ||||
body, ok := req.Params.Arguments["body"].(string) | ||||
body, ok := req.GetArguments()["body"].(string) | ||||
if ok { | ||||
opt.Body = ptr.To(body) | ||||
} | ||||
assignees, ok := req.Params.Arguments["assignees"].([]string) | ||||
assignees, ok := req.GetArguments()["assignees"].([]string) | ||||
if ok { | ||||
opt.Assignees = assignees | ||||
} | ||||
milestone, ok := req.Params.Arguments["milestone"].(float64) | ||||
milestone, ok := req.GetArguments()["milestone"].(float64) | ||||
if ok { | ||||
opt.Milestone = ptr.To(int64(milestone)) | ||||
} | ||||
state, ok := req.Params.Arguments["state"].(string) | ||||
state, ok := req.GetArguments()["state"].(string) | ||||
if ok { | ||||
opt.State = ptr.To(gitea_sdk.StateType(state)) | ||||
} | ||||
|
@@ -72,15 +72,15 @@ func init() { | ||||
| ||||
func GetPullRequestByIndexFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called GetPullRequestByIndexFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
index, ok := req.Params.Arguments["index"].(float64) | ||||
index, ok := req.GetArguments()["index"].(float64) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("index is required")) | ||||
} | ||||
@@ -94,25 +94,25 @@ func GetPullRequestByIndexFn(ctx context.Context, req mcp.CallToolRequest) (*mcp | ||||
| ||||
func ListRepoPullRequestsFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called ListRepoPullRequests") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
state, _ := req.Params.Arguments["state"].(string) | ||||
sort, ok := req.Params.Arguments["sort"].(string) | ||||
state, _ := req.GetArguments()["state"].(string) | ||||
sort, ok := req.GetArguments()["sort"].(string) | ||||
if !ok { | ||||
sort = "recentupdate" | ||||
} | ||||
milestone, _ := req.Params.Arguments["milestone"].(float64) | ||||
page, ok := req.Params.Arguments["page"].(float64) | ||||
milestone, _ := req.GetArguments()["milestone"].(float64) | ||||
page, ok := req.GetArguments()["page"].(float64) | ||||
if !ok { | ||||
page = 1 | ||||
} | ||||
pageSize, ok := req.Params.Arguments["pageSize"].(float64) | ||||
pageSize, ok := req.GetArguments()["pageSize"].(float64) | ||||
if !ok { | ||||
pageSize = 100 | ||||
} | ||||
@@ -135,27 +135,27 @@ func ListRepoPullRequestsFn(ctx context.Context, req mcp.CallToolRequest) (*mcp. | ||||
| ||||
func CreatePullRequestFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called CreatePullRequestFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
title, ok := req.Params.Arguments["title"].(string) | ||||
title, ok := req.GetArguments()["title"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("title is required")) | ||||
} | ||||
body, ok := req.Params.Arguments["body"].(string) | ||||
body, ok := req.GetArguments()["body"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("body is required")) | ||||
} | ||||
head, ok := req.Params.Arguments["head"].(string) | ||||
head, ok := req.GetArguments()["head"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("head is required")) | ||||
} | ||||
base, ok := req.Params.Arguments["base"].(string) | ||||
base, ok := req.GetArguments()["base"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("base is required")) | ||||
} | ||||
|
@@ -62,19 +62,19 @@ func init() { | ||||
| ||||
func CreateBranchFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called CreateBranchFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
branch, ok := req.Params.Arguments["branch"].(string) | ||||
branch, ok := req.GetArguments()["branch"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("branch is required")) | ||||
} | ||||
oldBranch, _ := req.Params.Arguments["old_branch"].(string) | ||||
oldBranch, _ := req.GetArguments()["old_branch"].(string) | ||||
| ||||
_, _, err := gitea.Client().CreateBranch(owner, repo, gitea_sdk.CreateBranchOption{ | ||||
BranchName: branch, | ||||
@@ -89,15 +89,15 @@ func CreateBranchFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallTool | ||||
| ||||
func DeleteBranchFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called DeleteBranchFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
branch, ok := req.Params.Arguments["branch"].(string) | ||||
branch, ok := req.GetArguments()["branch"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("branch is required")) | ||||
} | ||||
@@ -111,11 +111,11 @@ func DeleteBranchFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallTool | ||||
| ||||
func ListBranchesFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called ListBranchesFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
|
@@ -17,17 +17,15 @@ const ( | ||||
ListRepoCommitsToolName = "list_repo_commits" | ||||
) | ||||
| ||||
var ( | ||||
ListRepoCommitsTool = mcp.NewTool( | ||||
ListRepoCommitsToolName, | ||||
mcp.WithDescription("List repository commits"), | ||||
mcp.WithString("owner", mcp.Required(), mcp.Description("repository owner")), | ||||
mcp.WithString("repo", mcp.Required(), mcp.Description("repository name")), | ||||
mcp.WithString("sha", mcp.Description("SHA or branch to start listing commits from")), | ||||
mcp.WithString("path", mcp.Description("path indicates that only commits that include the path's file/dir should be returned.")), | ||||
mcp.WithNumber("page", mcp.Required(), mcp.Description("page number"), mcp.DefaultNumber(1), mcp.Min(1)), | ||||
mcp.WithNumber("page_size", mcp.Required(), mcp.Description("page size"), mcp.DefaultNumber(50), mcp.Min(1)), | ||||
) | ||||
var ListRepoCommitsTool = mcp.NewTool( | ||||
ListRepoCommitsToolName, | ||||
mcp.WithDescription("List repository commits"), | ||||
mcp.WithString("owner", mcp.Required(), mcp.Description("repository owner")), | ||||
mcp.WithString("repo", mcp.Required(), mcp.Description("repository name")), | ||||
mcp.WithString("sha", mcp.Description("SHA or branch to start listing commits from")), | ||||
mcp.WithString("path", mcp.Description("path indicates that only commits that include the path's file/dir should be returned.")), | ||||
mcp.WithNumber("page", mcp.Required(), mcp.Description("page number"), mcp.DefaultNumber(1), mcp.Min(1)), | ||||
mcp.WithNumber("page_size", mcp.Required(), mcp.Description("page size"), mcp.DefaultNumber(50), mcp.Min(1)), | ||||
) | ||||
| ||||
func init() { | ||||
@@ -39,24 +37,24 @@ func init() { | ||||
| ||||
func ListRepoCommitsFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called ListRepoCommitsFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
page, ok := req.Params.Arguments["page"].(float64) | ||||
page, ok := req.GetArguments()["page"].(float64) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("page is required")) | ||||
} | ||||
pageSize, ok := req.Params.Arguments["page_size"].(float64) | ||||
pageSize, ok := req.GetArguments()["page_size"].(float64) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("page_size is required")) | ||||
} | ||||
sha, _ := req.Params.Arguments["sha"].(string) | ||||
path, _ := req.Params.Arguments["path"].(string) | ||||
sha, _ := req.GetArguments()["sha"].(string) | ||||
path, _ := req.GetArguments()["path"].(string) | ||||
opt := gitea_sdk.ListCommitOptions{ | ||||
ListOptions: gitea_sdk.ListOptions{ | ||||
Page: int(page), | ||||
|
@@ -88,16 +88,16 @@ func init() { | ||||
| ||||
func GetFileContentFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called GetFileFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
ref, _ := req.Params.Arguments["ref"].(string) | ||||
filePath, ok := req.Params.Arguments["filePath"].(string) | ||||
ref, _ := req.GetArguments()["ref"].(string) | ||||
filePath, ok := req.GetArguments()["filePath"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("filePath is required")) | ||||
} | ||||
@@ -110,21 +110,21 @@ func GetFileContentFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallTo | ||||
| ||||
func CreateFileFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called CreateFileFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
filePath, ok := req.Params.Arguments["filePath"].(string) | ||||
filePath, ok := req.GetArguments()["filePath"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("filePath is required")) | ||||
} | ||||
content, _ := req.Params.Arguments["content"].(string) | ||||
message, _ := req.Params.Arguments["message"].(string) | ||||
branchName, _ := req.Params.Arguments["branch_name"].(string) | ||||
content, _ := req.GetArguments()["content"].(string) | ||||
message, _ := req.GetArguments()["message"].(string) | ||||
branchName, _ := req.GetArguments()["branch_name"].(string) | ||||
opt := gitea_sdk.CreateFileOptions{ | ||||
Content: base64.StdEncoding.EncodeToString([]byte(content)), | ||||
FileOptions: gitea_sdk.FileOptions{ | ||||
@@ -142,25 +142,25 @@ func CreateFileFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolRe | ||||
| ||||
func UpdateFileFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called UpdateFileFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
filePath, ok := req.Params.Arguments["filePath"].(string) | ||||
filePath, ok := req.GetArguments()["filePath"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("filePath is required")) | ||||
} | ||||
sha, ok := req.Params.Arguments["sha"].(string) | ||||
sha, ok := req.GetArguments()["sha"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("sha is required")) | ||||
} | ||||
content, _ := req.Params.Arguments["content"].(string) | ||||
message, _ := req.Params.Arguments["message"].(string) | ||||
branchName, _ := req.Params.Arguments["branch_name"].(string) | ||||
content, _ := req.GetArguments()["content"].(string) | ||||
message, _ := req.GetArguments()["message"].(string) | ||||
branchName, _ := req.GetArguments()["branch_name"].(string) | ||||
| ||||
opt := gitea_sdk.UpdateFileOptions{ | ||||
SHA: sha, | ||||
@@ -179,21 +179,21 @@ func UpdateFileFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolRe | ||||
| ||||
func DeleteFileFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called DeleteFileFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("owner is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("repo is required")) | ||||
} | ||||
filePath, ok := req.Params.Arguments["filePath"].(string) | ||||
filePath, ok := req.GetArguments()["filePath"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("filePath is required")) | ||||
} | ||||
message, _ := req.Params.Arguments["message"].(string) | ||||
branchName, _ := req.Params.Arguments["branch_name"].(string) | ||||
sha, ok := req.Params.Arguments["sha"].(string) | ||||
message, _ := req.GetArguments()["message"].(string) | ||||
branchName, _ := req.GetArguments()["branch_name"].(string) | ||||
sha, ok := req.GetArguments()["sha"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("sha is required")) | ||||
} | ||||
|
@@ -109,28 +109,28 @@ type ListReleaseResult struct { | ||||
| ||||
func CreateReleaseFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called CreateReleasesFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("owner is required") | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("repo is required") | ||||
} | ||||
tagName, ok := req.Params.Arguments["tag_name"].(string) | ||||
tagName, ok := req.GetArguments()["tag_name"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("tag_name is required") | ||||
} | ||||
target, ok := req.Params.Arguments["target"].(string) | ||||
target, ok := req.GetArguments()["target"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("target is required") | ||||
} | ||||
title, ok := req.Params.Arguments["title"].(string) | ||||
title, ok := req.GetArguments()["title"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("title is required") | ||||
} | ||||
isDraft, _ := req.Params.Arguments["is_draft"].(bool) | ||||
isPreRelease, _ := req.Params.Arguments["is_pre_release"].(bool) | ||||
isDraft, _ := req.GetArguments()["is_draft"].(bool) | ||||
isPreRelease, _ := req.GetArguments()["is_pre_release"].(bool) | ||||
| ||||
_, _, err := gitea.Client().CreateRelease(owner, repo, gitea_sdk.CreateReleaseOption{ | ||||
TagName: tagName, | ||||
@@ -148,15 +148,15 @@ func CreateReleaseFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToo | ||||
| ||||
func DeleteReleaseFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called DeleteReleaseFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("owner is required") | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("repo is required") | ||||
} | ||||
id, ok := req.Params.Arguments["id"].(float64) | ||||
id, ok := req.GetArguments()["id"].(float64) | ||||
if !ok { | ||||
return nil, fmt.Errorf("id is required") | ||||
} | ||||
@@ -171,15 +171,15 @@ func DeleteReleaseFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToo | ||||
| ||||
func GetReleaseFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called GetReleaseFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("owner is required") | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("repo is required") | ||||
} | ||||
id, ok := req.Params.Arguments["id"].(float64) | ||||
id, ok := req.GetArguments()["id"].(float64) | ||||
if !ok { | ||||
return nil, fmt.Errorf("id is required") | ||||
} | ||||
@@ -194,11 +194,11 @@ func GetReleaseFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolRe | ||||
| ||||
func GetLatestReleaseFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called GetLatestReleaseFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("owner is required") | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("repo is required") | ||||
} | ||||
@@ -213,18 +213,18 @@ func GetLatestReleaseFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.Call | ||||
| ||||
func ListReleasesFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called ListReleasesFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("owner is required") | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("repo is required") | ||||
} | ||||
isDraft, _ := req.Params.Arguments["is_draft"].(bool) | ||||
isPreRelease, _ := req.Params.Arguments["is_pre_release"].(bool) | ||||
page, _ := req.Params.Arguments["page"].(float64) | ||||
pageSize, _ := req.Params.Arguments["pageSize"].(float64) | ||||
isDraft, _ := req.GetArguments()["is_draft"].(bool) | ||||
isPreRelease, _ := req.GetArguments()["is_pre_release"].(bool) | ||||
page, _ := req.GetArguments()["page"].(float64) | ||||
pageSize, _ := req.GetArguments()["pageSize"].(float64) | ||||
| ||||
releases, _, err := gitea.Client().ListReleases(owner, repo, gitea_sdk.ListReleasesOptions{ | ||||
ListOptions: gitea_sdk.ListOptions{ | ||||
|
@@ -107,19 +107,19 @@ func RegisterTool(s *server.MCPServer) { | ||||
| ||||
func CreateRepoFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called CreateRepoFn") | ||||
name, ok := req.Params.Arguments["name"].(string) | ||||
name, ok := req.GetArguments()["name"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(errors.New("repository name is required")) | ||||
} | ||||
description, _ := req.Params.Arguments["description"].(string) | ||||
private, _ := req.Params.Arguments["private"].(bool) | ||||
issueLabels, _ := req.Params.Arguments["issue_labels"].(string) | ||||
autoInit, _ := req.Params.Arguments["auto_init"].(bool) | ||||
template, _ := req.Params.Arguments["template"].(bool) | ||||
gitignores, _ := req.Params.Arguments["gitignores"].(string) | ||||
license, _ := req.Params.Arguments["license"].(string) | ||||
readme, _ := req.Params.Arguments["readme"].(string) | ||||
defaultBranch, _ := req.Params.Arguments["default_branch"].(string) | ||||
description, _ := req.GetArguments()["description"].(string) | ||||
private, _ := req.GetArguments()["private"].(bool) | ||||
issueLabels, _ := req.GetArguments()["issue_labels"].(string) | ||||
autoInit, _ := req.GetArguments()["auto_init"].(bool) | ||||
template, _ := req.GetArguments()["template"].(bool) | ||||
gitignores, _ := req.GetArguments()["gitignores"].(string) | ||||
license, _ := req.GetArguments()["license"].(string) | ||||
readme, _ := req.GetArguments()["readme"].(string) | ||||
defaultBranch, _ := req.GetArguments()["default_branch"].(string) | ||||
| ||||
opt := gitea_sdk.CreateRepoOption{ | ||||
Name: name, | ||||
@@ -142,20 +142,20 @@ func CreateRepoFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolRe | ||||
| ||||
func ForkRepoFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called ForkRepoFn") | ||||
user, ok := req.Params.Arguments["user"].(string) | ||||
user, ok := req.GetArguments()["user"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(errors.New("user name is required")) | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(errors.New("repository name is required")) | ||||
} | ||||
organization, ok := req.Params.Arguments["organization"].(string) | ||||
organization, ok := req.GetArguments()["organization"].(string) | ||||
organizationPtr := ptr.To(organization) | ||||
if !ok || organization == "" { | ||||
organizationPtr = nil | ||||
} | ||||
name, ok := req.Params.Arguments["name"].(string) | ||||
name, ok := req.GetArguments()["name"].(string) | ||||
namePtr := ptr.To(name) | ||||
if !ok || name == "" { | ||||
namePtr = nil | ||||
@@ -173,11 +173,11 @@ func ForkRepoFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResu | ||||
| ||||
func ListMyReposFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called ListMyReposFn") | ||||
page, ok := req.Params.Arguments["page"].(float64) | ||||
page, ok := req.GetArguments()["page"].(float64) | ||||
if !ok { | ||||
page = 1 | ||||
} | ||||
pageSize, ok := req.Params.Arguments["pageSize"].(float64) | ||||
pageSize, ok := req.GetArguments()["pageSize"].(float64) | ||||
if !ok { | ||||
pageSize = 100 | ||||
} | ||||
|
@@ -87,20 +87,20 @@ type ListTagResult struct { | ||||
| ||||
func CreateTagFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called CreateTagFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("owner is required") | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("repo is required") | ||||
} | ||||
tagName, ok := req.Params.Arguments["tag_name"].(string) | ||||
tagName, ok := req.GetArguments()["tag_name"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("tag_name is required") | ||||
} | ||||
target, _ := req.Params.Arguments["target"].(string) | ||||
message, _ := req.Params.Arguments["message"].(string) | ||||
target, _ := req.GetArguments()["target"].(string) | ||||
message, _ := req.GetArguments()["message"].(string) | ||||
| ||||
_, _, err := gitea.Client().CreateTag(owner, repo, gitea_sdk.CreateTagOption{ | ||||
TagName: tagName, | ||||
@@ -116,15 +116,15 @@ func CreateTagFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolRes | ||||
| ||||
func DeleteTagFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called DeleteTagFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("owner is required") | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("repo is required") | ||||
} | ||||
tagName, ok := req.Params.Arguments["tag_name"].(string) | ||||
tagName, ok := req.GetArguments()["tag_name"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("tag_name is required") | ||||
} | ||||
@@ -139,15 +139,15 @@ func DeleteTagFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolRes | ||||
| ||||
func GetTagFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called GetTagFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("owner is required") | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("repo is required") | ||||
} | ||||
tagName, ok := req.Params.Arguments["tag_name"].(string) | ||||
tagName, ok := req.GetArguments()["tag_name"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("tag_name is required") | ||||
} | ||||
@@ -162,16 +162,16 @@ func GetTagFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult | ||||
| ||||
func ListTagsFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called ListTagsFn") | ||||
owner, ok := req.Params.Arguments["owner"].(string) | ||||
owner, ok := req.GetArguments()["owner"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("owner is required") | ||||
} | ||||
repo, ok := req.Params.Arguments["repo"].(string) | ||||
repo, ok := req.GetArguments()["repo"].(string) | ||||
if !ok { | ||||
return nil, fmt.Errorf("repo is required") | ||||
} | ||||
page, _ := req.Params.Arguments["page"].(float64) | ||||
pageSize, _ := req.Params.Arguments["pageSize"].(float64) | ||||
page, _ := req.GetArguments()["page"].(float64) | ||||
pageSize, _ := req.GetArguments()["pageSize"].(float64) | ||||
| ||||
tags, _, err := gitea.Client().ListRepoTags(owner, repo, gitea_sdk.ListRepoTagsOptions{ | ||||
ListOptions: gitea_sdk.ListOptions{ | ||||
|
@@ -75,15 +75,15 @@ func init() { | ||||
| ||||
func SearchUsersFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called SearchUsersFn") | ||||
keyword, ok := req.Params.Arguments["keyword"].(string) | ||||
keyword, ok := req.GetArguments()["keyword"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("keyword is required")) | ||||
} | ||||
page, ok := req.Params.Arguments["page"].(float64) | ||||
page, ok := req.GetArguments()["page"].(float64) | ||||
if !ok { | ||||
page = 1 | ||||
} | ||||
pageSize, ok := req.Params.Arguments["pageSize"].(float64) | ||||
pageSize, ok := req.GetArguments()["pageSize"].(float64) | ||||
if !ok { | ||||
pageSize = 100 | ||||
} | ||||
@@ -103,20 +103,20 @@ func SearchUsersFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolR | ||||
| ||||
func SearchOrgTeamsFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called SearchOrgTeamsFn") | ||||
org, ok := req.Params.Arguments["org"].(string) | ||||
org, ok := req.GetArguments()["org"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("organization is required")) | ||||
} | ||||
query, ok := req.Params.Arguments["query"].(string) | ||||
query, ok := req.GetArguments()["query"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("query is required")) | ||||
} | ||||
includeDescription, _ := req.Params.Arguments["includeDescription"].(bool) | ||||
page, ok := req.Params.Arguments["page"].(float64) | ||||
includeDescription, _ := req.GetArguments()["includeDescription"].(bool) | ||||
page, ok := req.GetArguments()["page"].(float64) | ||||
if !ok { | ||||
page = 1 | ||||
} | ||||
pageSize, ok := req.Params.Arguments["pageSize"].(float64) | ||||
pageSize, ok := req.GetArguments()["pageSize"].(float64) | ||||
if !ok { | ||||
pageSize = 100 | ||||
} | ||||
@@ -137,22 +137,22 @@ func SearchOrgTeamsFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallTo | ||||
| ||||
func SearchReposFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called SearchReposFn") | ||||
keyword, ok := req.Params.Arguments["keyword"].(string) | ||||
keyword, ok := req.GetArguments()["keyword"].(string) | ||||
if !ok { | ||||
return to.ErrorResult(fmt.Errorf("keyword is required")) | ||||
} | ||||
keywordIsTopic, _ := req.Params.Arguments["keywordIsTopic"].(bool) | ||||
keywordInDescription, _ := req.Params.Arguments["keywordInDescription"].(bool) | ||||
ownerID, _ := req.Params.Arguments["ownerID"].(float64) | ||||
isPrivate, _ := req.Params.Arguments["isPrivate"].(bool) | ||||
isArchived, _ := req.Params.Arguments["isArchived"].(bool) | ||||
sort, _ := req.Params.Arguments["sort"].(string) | ||||
order, _ := req.Params.Arguments["order"].(string) | ||||
page, ok := req.Params.Arguments["page"].(float64) | ||||
keywordIsTopic, _ := req.GetArguments()["keywordIsTopic"].(bool) | ||||
keywordInDescription, _ := req.GetArguments()["keywordInDescription"].(bool) | ||||
ownerID, _ := req.GetArguments()["ownerID"].(float64) | ||||
isPrivate, _ := req.GetArguments()["isPrivate"].(bool) | ||||
isArchived, _ := req.GetArguments()["isArchived"].(bool) | ||||
sort, _ := req.GetArguments()["sort"].(string) | ||||
order, _ := req.GetArguments()["order"].(string) | ||||
page, ok := req.GetArguments()["page"].(float64) | ||||
if !ok { | ||||
page = 1 | ||||
} | ||||
pageSize, ok := req.Params.Arguments["pageSize"].(float64) | ||||
pageSize, ok := req.GetArguments()["pageSize"].(float64) | ||||
if !ok { | ||||
pageSize = 100 | ||||
} | ||||
|
@@ -59,11 +59,11 @@ func GetUserInfoFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolR | ||||
| ||||
func GetUserOrgsFn(ctx context.Context, req mcp.CallToolRequest) (*mcp.CallToolResult, error) { | ||||
log.Debugf("Called GetUserOrgsFn") | ||||
page, ok := req.Params.Arguments["page"].(float64) | ||||
page, ok := req.GetArguments()["page"].(float64) | ||||
if !ok || page < 1 { | ||||
page = 1 | ||||
} | ||||
pageSize, ok := req.Params.Arguments["pageSize"].(float64) | ||||
pageSize, ok := req.GetArguments()["pageSize"].(float64) | ||||
if !ok || pageSize < 1 { | ||||
pageSize = 100 | ||||
} | ||||
|
Reference in New Issue
Block a user