diff --git a/api/hungryapi/appservice.go b/api/hungryapi/appservice.go index b90792b..c1d2eb1 100644 --- a/api/hungryapi/appservice.go +++ b/api/hungryapi/appservice.go @@ -1,6 +1,7 @@ package hungryapi import ( + "context" "net/http" "time" @@ -30,23 +31,24 @@ type ReqRegisterAppService struct { } func (cli *Client) RegisterAppService( + ctx context.Context, bridge string, req ReqRegisterAppService, ) (resp appservice.Registration, err error) { url := cli.BuildURL(mautrix.BaseURLPath{"_matrix", "asmux", "mxauth", "appservice", cli.Username, bridge}) - _, err = cli.MakeRequest(http.MethodPut, url, &req, &resp) + _, err = cli.MakeRequest(ctx, http.MethodPut, url, &req, &resp) return } -func (cli *Client) GetAppService(bridge string) (resp appservice.Registration, err error) { +func (cli *Client) GetAppService(ctx context.Context, bridge string) (resp appservice.Registration, err error) { url := cli.BuildURL(mautrix.BaseURLPath{"_matrix", "asmux", "mxauth", "appservice", cli.Username, bridge}) - _, err = cli.MakeRequest(http.MethodGet, url, nil, &resp) + _, err = cli.MakeRequest(ctx, http.MethodGet, url, nil, &resp) return } -func (cli *Client) DeleteAppService(bridge string) (err error) { +func (cli *Client) DeleteAppService(ctx context.Context, bridge string) (err error) { url := cli.BuildURL(mautrix.BaseURLPath{"_matrix", "asmux", "mxauth", "appservice", cli.Username, bridge}) - _, err = cli.MakeRequest(http.MethodDelete, url, nil, nil) + _, err = cli.MakeRequest(ctx, http.MethodDelete, url, nil, nil) return } @@ -54,10 +56,10 @@ type respGetSystemTime struct { Time jsontime.UnixMilli `json:"time_ms"` } -func (cli *Client) GetServerTime() (resp time.Time, precision time.Duration, err error) { +func (cli *Client) GetServerTime(ctx context.Context) (resp time.Time, precision time.Duration, err error) { var respData respGetSystemTime start := time.Now() - _, err = cli.MakeFullRequest(mautrix.FullRequest{ + _, err = cli.MakeFullRequest(ctx, mautrix.FullRequest{ Method: http.MethodGet, URL: cli.BuildURL(mautrix.BaseURLPath{"_matrix", "client", "unstable", "com.beeper.timesync"}), ResponseJSON: &respData, diff --git a/cmd/bbctl/login-email.go b/cmd/bbctl/login-email.go index a2b28fc..72f91a1 100644 --- a/cmd/bbctl/login-email.go +++ b/cmd/bbctl/login-email.go @@ -75,7 +75,7 @@ func doMatrixLogin(ctx *cli.Context, req *mautrix.ReqLogin, whoami *beeperapi.Re homeserver := ctx.String("homeserver") api := NewMatrixAPI(homeserver, "", "") - resp, err := api.Login(req) + resp, err := api.Login(ctx.Context, req) if err != nil { return fmt.Errorf("failed to log in: %w", err) } @@ -83,7 +83,7 @@ func doMatrixLogin(ctx *cli.Context, req *mautrix.ReqLogin, whoami *beeperapi.Re if whoami == nil { whoami, err = beeperapi.Whoami(homeserver, resp.AccessToken) if err != nil { - _, _ = api.Logout() + _, _ = api.Logout(ctx.Context) return fmt.Errorf("failed to get user details: %w", err) } } @@ -95,7 +95,7 @@ func doMatrixLogin(ctx *cli.Context, req *mautrix.ReqLogin, whoami *beeperapi.Re envCfg.BridgeDataDir = filepath.Join(UserDataDir, "bbctl", ctx.String("env")) err = cfg.Save() if err != nil { - _, _ = api.Logout() + _, _ = api.Logout(ctx.Context) return fmt.Errorf("failed to save config: %w", err) } return nil diff --git a/cmd/bbctl/logout.go b/cmd/bbctl/logout.go index 9d71ac6..7ec88b3 100644 --- a/cmd/bbctl/logout.go +++ b/cmd/bbctl/logout.go @@ -22,7 +22,7 @@ var logoutCommand = &cli.Command{ } func beeperLogout(ctx *cli.Context) error { - _, err := GetMatrixClient(ctx).Logout() + _, err := GetMatrixClient(ctx).Logout(ctx.Context) if err != nil && !ctx.Bool("force") { return fmt.Errorf("error logging out: %w", err) } diff --git a/cmd/bbctl/register.go b/cmd/bbctl/register.go index a4019ba..c5be5c0 100644 --- a/cmd/bbctl/register.go +++ b/cmd/bbctl/register.go @@ -97,9 +97,9 @@ func doRegisterBridge(ctx *cli.Context, bridge, bridgeType string, onlyGet bool) if req.Address != "" { return nil, UserError{"You can't use --get with --address"} } - resp, err = hungryAPI.GetAppService(bridge) + resp, err = hungryAPI.GetAppService(ctx.Context, bridge) } else { - resp, err = hungryAPI.RegisterAppService(bridge, req) + resp, err = hungryAPI.RegisterAppService(ctx.Context, bridge, req) } if err != nil { return nil, fmt.Errorf("failed to register appservice: %w", err) diff --git a/go.mod b/go.mod index df56b60..f631bad 100644 --- a/go.mod +++ b/go.mod @@ -9,10 +9,10 @@ require ( github.com/rs/zerolog v1.31.0 github.com/schollz/progressbar/v3 v3.14.1 github.com/tidwall/gjson v1.17.0 - github.com/urfave/cli/v2 v2.26.0 - go.mau.fi/util v0.2.1 - golang.org/x/exp v0.0.0-20231206192017-f3f8817b8deb - maunium.net/go/mautrix v0.16.2 + github.com/urfave/cli/v2 v2.27.1 + go.mau.fi/util v0.3.0 + golang.org/x/exp v0.0.0-20240112132812-db7319d0e0e3 + maunium.net/go/mautrix v0.17.0 ) require ( @@ -29,10 +29,10 @@ require ( github.com/tidwall/pretty v1.2.0 // indirect github.com/tidwall/sjson v1.2.5 // indirect github.com/xrash/smetrics v0.0.0-20201216005158-039620a65673 // indirect - golang.org/x/crypto v0.15.0 // indirect - golang.org/x/net v0.18.0 // indirect - golang.org/x/sys v0.14.0 // indirect - golang.org/x/term v0.14.0 // indirect + golang.org/x/crypto v0.18.0 // indirect + golang.org/x/net v0.20.0 // indirect + golang.org/x/sys v0.16.0 // indirect + golang.org/x/term v0.16.0 // indirect golang.org/x/text v0.14.0 // indirect gopkg.in/yaml.v3 v3.0.1 // indirect maunium.net/go/maulogger/v2 v2.4.1 // indirect diff --git a/go.sum b/go.sum index 79789cf..e17a3bc 100644 --- a/go.sum +++ b/go.sum @@ -59,25 +59,25 @@ github.com/tidwall/pretty v1.2.0 h1:RWIZEg2iJ8/g6fDDYzMpobmaoGh5OLl4AXtGUGPcqCs= github.com/tidwall/pretty v1.2.0/go.mod h1:ITEVvHYasfjBbM0u2Pg8T2nJnzm8xPwvNhhsoaGGjNU= github.com/tidwall/sjson v1.2.5 h1:kLy8mja+1c9jlljvWTlSazM7cKDRfJuR/bOJhcY5NcY= github.com/tidwall/sjson v1.2.5/go.mod h1:Fvgq9kS/6ociJEDnK0Fk1cpYF4FIW6ZF7LAe+6jwd28= -github.com/urfave/cli/v2 v2.26.0 h1:3f3AMg3HpThFNT4I++TKOejZO8yU55t3JnnSr4S4QEI= -github.com/urfave/cli/v2 v2.26.0/go.mod h1:8qnjx1vcq5s2/wpsqoZFndg2CE5tNFyrTvS6SinrnYQ= +github.com/urfave/cli/v2 v2.27.1 h1:8xSQ6szndafKVRmfyeUMxkNUJQMjL1F2zmsZ+qHpfho= +github.com/urfave/cli/v2 v2.27.1/go.mod h1:8qnjx1vcq5s2/wpsqoZFndg2CE5tNFyrTvS6SinrnYQ= github.com/xrash/smetrics v0.0.0-20201216005158-039620a65673 h1:bAn7/zixMGCfxrRTfdpNzjtPYqr8smhKouy9mxVdGPU= github.com/xrash/smetrics v0.0.0-20201216005158-039620a65673/go.mod h1:N3UwUGtsrSj3ccvlPHLoLsHnpR27oXr4ZE984MbSER8= github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY= -go.mau.fi/util v0.2.1 h1:eazulhFE/UmjOFtPrGg6zkF5YfAyiDzQb8ihLMbsPWw= -go.mau.fi/util v0.2.1/go.mod h1:MjlzCQEMzJ+G8RsPawHzpLB8rwTo3aPIjG5FzBvQT/c= +go.mau.fi/util v0.3.0 h1:Lt3lbRXP6ZBqTINK0EieRWor3zEwwwrDT14Z5N8RUCs= +go.mau.fi/util v0.3.0/go.mod h1:9dGsBCCbZJstx16YgnVMVi3O2bOizELoKpugLD4FoGs= golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= -golang.org/x/crypto v0.15.0 h1:frVn1TEaCEaZcn3Tmd7Y2b5KKPaZ+I32Q2OA3kYp5TA= -golang.org/x/crypto v0.15.0/go.mod h1:4ChreQoLWfG3xLDer1WdlH5NdlQ3+mwnQq1YTKY+72g= -golang.org/x/exp v0.0.0-20231206192017-f3f8817b8deb h1:c0vyKkb6yr3KR7jEfJaOSv4lG7xPkbN6r52aJz1d8a8= -golang.org/x/exp v0.0.0-20231206192017-f3f8817b8deb/go.mod h1:iRJReGqOEeBhDZGkGbynYwcHlctCvnjTYIamk7uXpHI= +golang.org/x/crypto v0.18.0 h1:PGVlW0xEltQnzFZ55hkuX5+KLyrMYhHld1YHO4AKcdc= +golang.org/x/crypto v0.18.0/go.mod h1:R0j02AL6hcrfOiy9T4ZYp/rcWeMxM3L6QYxlOuEG1mg= +golang.org/x/exp v0.0.0-20240112132812-db7319d0e0e3 h1:hNQpMuAJe5CtcUqCXaWga3FHu+kQvCqcsoVaQgSV60o= +golang.org/x/exp v0.0.0-20240112132812-db7319d0e0e3/go.mod h1:idGWGoKP1toJGkd5/ig9ZLuPcZBC3ewk7SzmH0uou08= golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4= golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= -golang.org/x/net v0.18.0 h1:mIYleuAkSbHh0tCv7RvjL3F6ZVbLjq4+R7zbOn3Kokg= -golang.org/x/net v0.18.0/go.mod h1:/czyP5RqHAH4odGYxBJ1qz0+CE5WZ+2j1YgoEo8F2jQ= +golang.org/x/net v0.20.0 h1:aCL9BSgETF1k+blQaYUBx9hJ9LOGP3gAVemcZlf1Kpo= +golang.org/x/net v0.20.0/go.mod h1:z8BVo6PvndSri0LbOE3hAn0apkU+1YvI6E70E9jsnvY= golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= @@ -89,12 +89,14 @@ golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBc golang.org/x/sys v0.0.0-20220811171246-fbc7d0a398ab/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.12.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= -golang.org/x/sys v0.14.0 h1:Vz7Qs629MkJkGyHxUlRHizWJRG2j8fbQKjELVSNhy7Q= golang.org/x/sys v0.14.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/sys v0.16.0 h1:xWw16ngr6ZMtmxDyKyIgsE93KNKz5HKmMa3b8ALHidU= +golang.org/x/sys v0.16.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= -golang.org/x/term v0.14.0 h1:LGK9IlZ8T9jvdy6cTdfKUCltatMFOehAQo9SRC46UQ8= golang.org/x/term v0.14.0/go.mod h1:TySc+nGkYR6qt8km8wUhuFRTVSMIX3XPR58y2lC8vww= +golang.org/x/term v0.16.0 h1:m+B6fahuftsE9qjo0VWp2FW0mB3MTJvR0BaMQrq0pmE= +golang.org/x/term v0.16.0/go.mod h1:yn7UURbUtPyrVJPGPq404EukNFxcm/foM+bV/bfcDsY= 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/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ= @@ -112,5 +114,5 @@ gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= maunium.net/go/maulogger/v2 v2.4.1 h1:N7zSdd0mZkB2m2JtFUsiGTQQAdP0YeFWT7YMc80yAL8= maunium.net/go/maulogger/v2 v2.4.1/go.mod h1:omPuYwYBILeVQobz8uO3XC8DIRuEb5rXYlQSuqrbCho= -maunium.net/go/mautrix v0.16.2 h1:a6GUJXNWsTEOO8VE4dROBfCIfPp50mqaqzv7KPzChvg= -maunium.net/go/mautrix v0.16.2/go.mod h1:YL4l4rZB46/vj/ifRMEjcibbvHjgxHftOF1SgmruLu4= +maunium.net/go/mautrix v0.17.0 h1:scc1qlUbzPn+wc+3eAPquyD+3gZwwy/hBANBm+iGKK8= +maunium.net/go/mautrix v0.17.0/go.mod h1:j+puTEQCEydlVxhJ/dQP5chfa26TdvBO7X6F3Ataav8=