/
buildpack_helper_service_client.go
79 lines (73 loc) · 2.08 KB
/
buildpack_helper_service_client.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
package grpc
import (
"connectrpc.com/connect"
"context"
"github.com/friendsofgo/errors"
"github.com/samber/lo"
"io"
"github.com/traPtitech/neoshowcase/pkg/domain"
"github.com/traPtitech/neoshowcase/pkg/domain/web"
"github.com/traPtitech/neoshowcase/pkg/infrastructure/grpc/pb"
"github.com/traPtitech/neoshowcase/pkg/infrastructure/grpc/pb/pbconnect"
)
type BuildpackHelperServiceClient struct {
client pbconnect.BuildpackHelperServiceClient
}
func NewBuildpackHelperServiceClient(
address string,
) domain.BuildpackHelperServiceClient {
return &BuildpackHelperServiceClient{
client: pbconnect.NewBuildpackHelperServiceClient(web.NewH2CClient(), address),
}
}
func (b *BuildpackHelperServiceClient) CopyFileTree(ctx context.Context, destination string, tarStream io.Reader) error {
content, err := io.ReadAll(tarStream)
if err != nil {
return err
}
req := connect.NewRequest(&pb.CopyFileTreeRequest{
Destination: destination,
TarContent: content,
})
_, err = b.client.CopyFileTree(ctx, req)
return err
}
func (b *BuildpackHelperServiceClient) Exec(ctx context.Context, workDir string, cmd []string, envs map[string]string, logWriter io.Writer) (int, error) {
arrayEnvs := lo.MapToSlice(envs, func(key string, value string) *pb.HelperExecEnv {
return &pb.HelperExecEnv{
Key: key,
Value: value,
}
})
req := connect.NewRequest(&pb.HelperExecRequest{
WorkDir: workDir,
Cmd: cmd,
Envs: arrayEnvs,
})
st, err := b.client.Exec(ctx, req)
if err != nil {
return 0, errors.Wrap(err, "requesting exec")
}
var exitCode *int
for st.Receive() {
msg := st.Msg()
switch msg.Type {
case pb.HelperExecResponse_LOG:
payload := msg.Body.(*pb.HelperExecResponse_Log).Log
_, err = logWriter.Write(payload)
if err != nil {
return 0, err
}
case pb.HelperExecResponse_EXIT_CODE:
payload := int(msg.Body.(*pb.HelperExecResponse_ExitCode).ExitCode)
exitCode = &payload
}
}
if err := st.Err(); err != nil {
return 0, errors.Wrap(err, "receiving logs")
}
if exitCode == nil {
return 0, errors.New("exit code not received")
}
return *exitCode, nil
}