Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
4c91b2db
Commit
4c91b2db
authored
Apr 26, 2017
by
Jacob Vosmaer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use io.Copy in gitaly smarthttp
parent
a3be5472
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
43 additions
and
72 deletions
+43
-72
internal/gitaly/smarthttp.go
internal/gitaly/smarthttp.go
+43
-72
No files found.
internal/gitaly/smarthttp.go
View file @
4c91b2db
...
...
@@ -8,23 +8,12 @@ import (
pbhelper
"gitlab.com/gitlab-org/gitaly-proto/go/helper"
"golang.org/x/net/context"
"google.golang.org/grpc"
)
type
SmartHTTPClient
struct
{
pb
.
SmartHTTPClient
}
type
uploadPackWriter
struct
{
pb
.
SmartHTTP_PostUploadPackClient
}
type
receivePackWriter
struct
{
pb
.
SmartHTTP_PostReceivePackClient
}
const
sendChunkSize
=
16384
func
(
client
*
SmartHTTPClient
)
InfoRefsResponseWriterTo
(
ctx
context
.
Context
,
repo
*
pb
.
Repository
,
rpc
string
)
(
io
.
WriterTo
,
error
)
{
rpcRequest
:=
&
pb
.
InfoRefsRequest
{
Repository
:
repo
}
var
c
pbhelper
.
InfoRefsClient
...
...
@@ -64,21 +53,31 @@ func (client *SmartHTTPClient) ReceivePack(repo *pb.Repository, GlId string, cli
return
fmt
.
Errorf
(
"initial request: %v"
,
err
)
}
waitc
:=
make
(
chan
error
,
1
)
numStreams
:=
2
errC
:=
make
(
chan
error
,
numStreams
)
go
receiveGitalyResponse
(
stream
,
waitc
,
clientResponse
,
func
()
([]
byte
,
error
)
{
go
func
()
{
rr
:=
pbhelper
.
NewReceiveReader
(
func
()
([]
byte
,
error
)
{
response
,
err
:=
stream
.
Recv
()
return
response
.
GetData
(),
err
})
_
,
err
:=
io
.
Copy
(
clientResponse
,
rr
)
errC
<-
err
}()
_
,
sendErr
:=
io
.
Copy
(
receivePackWriter
{
stream
},
clientRequest
)
go
func
()
{
sw
:=
pbhelper
.
NewSendWriter
(
func
(
data
[]
byte
)
error
{
return
stream
.
Send
(
&
pb
.
PostReceivePackRequest
{
Data
:
data
})
})
_
,
err
:=
io
.
Copy
(
sw
,
clientRequest
)
stream
.
CloseSend
()
errC
<-
err
}()
if
recvErr
:=
<-
waitc
;
recvErr
!=
nil
{
return
recvErr
for
i
:=
0
;
i
<
numStreams
;
i
++
{
if
err
:=
<-
errC
;
err
!=
nil
{
return
err
}
if
sendErr
!=
nil
{
return
fmt
.
Errorf
(
"send: %v"
,
sendErr
)
}
return
nil
...
...
@@ -101,60 +100,32 @@ func (client *SmartHTTPClient) UploadPack(repo *pb.Repository, clientRequest io.
return
fmt
.
Errorf
(
"initial request: %v"
,
err
)
}
waitc
:=
make
(
chan
error
,
1
)
numStreams
:=
2
errC
:=
make
(
chan
error
,
numStreams
)
go
receiveGitalyResponse
(
stream
,
waitc
,
clientResponse
,
func
()
([]
byte
,
error
)
{
go
func
()
{
rr
:=
pbhelper
.
NewReceiveReader
(
func
()
([]
byte
,
error
)
{
response
,
err
:=
stream
.
Recv
()
return
response
.
GetData
(),
err
})
_
,
err
:=
io
.
Copy
(
clientResponse
,
rr
)
errC
<-
err
}()
_
,
sendErr
:=
io
.
Copy
(
uploadPackWriter
{
stream
},
clientRequest
)
go
func
()
{
sw
:=
pbhelper
.
NewSendWriter
(
func
(
data
[]
byte
)
error
{
return
stream
.
Send
(
&
pb
.
PostUploadPackRequest
{
Data
:
data
})
})
_
,
err
:=
io
.
Copy
(
sw
,
clientRequest
)
stream
.
CloseSend
()
if
recvErr
:=
<-
waitc
;
recvErr
!=
nil
{
return
recvErr
}
if
sendErr
!=
nil
{
return
fmt
.
Errorf
(
"send: %v"
,
sendErr
)
}
return
nil
}
func
receiveGitalyResponse
(
cs
grpc
.
ClientStream
,
waitc
chan
error
,
clientResponse
io
.
Writer
,
receiver
func
()
([]
byte
,
error
))
{
defer
func
()
{
close
(
waitc
)
cs
.
CloseSend
()
errC
<-
err
}()
for
{
data
,
err
:=
receiver
()
if
err
!=
nil
{
if
err
!=
io
.
EOF
{
waitc
<-
fmt
.
Errorf
(
"receive: %v"
,
err
)
}
return
}
if
_
,
err
:=
clientResponse
.
Write
(
data
);
err
!=
nil
{
waitc
<-
fmt
.
Errorf
(
"write: %v"
,
err
)
return
for
i
:=
0
;
i
<
numStreams
;
i
++
{
if
err
:=
<-
errC
;
err
!=
nil
{
return
err
}
}
}
func
(
rw
uploadPackWriter
)
Write
(
p
[]
byte
)
(
int
,
error
)
{
resp
:=
&
pb
.
PostUploadPackRequest
{
Data
:
p
}
if
err
:=
rw
.
Send
(
resp
);
err
!=
nil
{
return
0
,
err
}
return
len
(
p
),
nil
}
func
(
rw
receivePackWriter
)
Write
(
p
[]
byte
)
(
int
,
error
)
{
resp
:=
&
pb
.
PostReceivePackRequest
{
Data
:
p
}
if
err
:=
rw
.
Send
(
resp
);
err
!=
nil
{
return
0
,
err
}
return
len
(
p
),
nil
return
nil
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment