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
a43b2e94
Commit
a43b2e94
authored
Dec 16, 2016
by
Jacob Vosmaer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Put multipart rewrite work in functions
parent
c28f06f7
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
82 additions
and
54 deletions
+82
-54
internal/upload/rewrite.go
internal/upload/rewrite.go
+82
-54
No files found.
internal/upload/rewrite.go
View file @
a43b2e94
...
...
@@ -37,6 +37,13 @@ var (
)
)
type
rewriter
struct
{
writer
*
multipart
.
Writer
tempPath
string
filter
MultipartFormProcessor
directories
[]
string
}
func
init
()
{
prometheus
.
MustRegister
(
multipartUploadRequests
)
prometheus
.
MustRegister
(
multipartFileUploadBytes
)
...
...
@@ -56,10 +63,14 @@ func rewriteFormFilesFromMultipart(r *http.Request, writer *multipart.Writer, te
multipartUploadRequests
.
Inc
()
var
directories
[]
string
rew
:=
&
rewriter
{
writer
:
writer
,
tempPath
:
tempPath
,
filter
:
filter
,
}
cleanup
=
func
()
{
for
_
,
dir
:=
range
directories
{
for
_
,
dir
:=
range
rew
.
directories
{
os
.
RemoveAll
(
dir
)
}
}
...
...
@@ -83,60 +94,77 @@ func rewriteFormFilesFromMultipart(r *http.Request, writer *multipart.Writer, te
}
// Copy form field
if
filename
:=
p
.
FileName
();
filename
!=
""
{
if
p
.
FileName
()
!=
""
{
err
=
rew
.
handleFilePart
(
name
,
p
)
}
else
{
err
=
rew
.
copyPart
(
name
,
p
)
}
if
err
!=
nil
{
return
cleanup
,
err
}
}
return
cleanup
,
nil
}
func
(
rew
*
rewriter
)
handleFilePart
(
name
string
,
p
*
multipart
.
Part
)
error
{
multipartFiles
.
Inc
()
filename
:=
p
.
FileName
()
if
strings
.
Contains
(
filename
,
"/"
)
||
filename
==
"."
||
filename
==
".."
{
return
cleanup
,
fmt
.
Errorf
(
"illegal filename: %q"
,
filename
)
return
fmt
.
Errorf
(
"illegal filename: %q"
,
filename
)
}
// Create temporary directory where the uploaded file will be stored
if
err
:=
os
.
MkdirAll
(
tempPath
,
0700
);
err
!=
nil
{
return
cleanup
,
fmt
.
Errorf
(
"mkdir for tempfile: %v"
,
err
)
if
err
:=
os
.
MkdirAll
(
rew
.
tempPath
,
0700
);
err
!=
nil
{
return
fmt
.
Errorf
(
"mkdir for tempfile: %v"
,
err
)
}
tempDir
,
err
:=
ioutil
.
TempDir
(
tempPath
,
"multipart-"
)
tempDir
,
err
:=
ioutil
.
TempDir
(
rew
.
tempPath
,
"multipart-"
)
if
err
!=
nil
{
return
cleanup
,
fmt
.
Errorf
(
"create tempdir: %v"
,
err
)
return
fmt
.
Errorf
(
"create tempdir: %v"
,
err
)
}
directories
=
append
(
directories
,
tempDir
)
rew
.
directories
=
append
(
rew
.
directories
,
tempDir
)
file
,
err
:=
os
.
OpenFile
(
path
.
Join
(
tempDir
,
filename
),
os
.
O_WRONLY
|
os
.
O_CREATE
,
0600
)
if
err
!=
nil
{
return
cleanup
,
fmt
.
Errorf
(
"rewriteFormFilesFromMultipart: temp file: %v"
,
err
)
return
fmt
.
Errorf
(
"rewriteFormFilesFromMultipart: temp file: %v"
,
err
)
}
defer
file
.
Close
()
// Add file entry
writer
.
WriteField
(
name
+
".path"
,
file
.
Name
())
writer
.
WriteField
(
name
+
".name"
,
filename
)
rew
.
writer
.
WriteField
(
name
+
".path"
,
file
.
Name
())
rew
.
writer
.
WriteField
(
name
+
".name"
,
filename
)
written
,
err
:=
io
.
Copy
(
file
,
p
)
if
err
!=
nil
{
return
cleanup
,
fmt
.
Errorf
(
"copy from multipart to tempfile: %v"
,
err
)
return
fmt
.
Errorf
(
"copy from multipart to tempfile: %v"
,
err
)
}
multipartFileUploadBytes
.
Add
(
float64
(
written
))
file
.
Close
()
if
err
:=
filter
.
ProcessFile
(
name
,
file
.
Name
(),
writer
);
err
!=
nil
{
return
cleanup
,
err
}
}
else
{
np
,
err
:=
writer
.
CreatePart
(
p
.
Header
)
if
err
!=
nil
{
return
cleanup
,
fmt
.
Errorf
(
"create multipart field: %v"
,
err
)
if
err
:=
rew
.
filter
.
ProcessFile
(
name
,
file
.
Name
(),
rew
.
writer
);
err
!=
nil
{
return
err
}
_
,
err
=
io
.
Copy
(
np
,
p
)
return
nil
}
func
(
rew
*
rewriter
)
copyPart
(
name
string
,
p
*
multipart
.
Part
)
error
{
np
,
err
:=
rew
.
writer
.
CreatePart
(
p
.
Header
)
if
err
!=
nil
{
return
cleanup
,
fmt
.
Errorf
(
"duplic
ate multipart field: %v"
,
err
)
return
fmt
.
Errorf
(
"cre
ate multipart field: %v"
,
err
)
}
if
err
:=
filter
.
ProcessField
(
name
,
writer
);
err
!=
nil
{
return
cleanup
,
fmt
.
Errorf
(
"process multipart field: %v"
,
err
)
}
if
_
,
err
:=
io
.
Copy
(
np
,
p
);
err
!=
nil
{
return
fmt
.
Errorf
(
"duplicate multipart field: %v"
,
err
)
}
if
err
:=
rew
.
filter
.
ProcessField
(
name
,
rew
.
writer
);
err
!=
nil
{
return
fmt
.
Errorf
(
"process multipart field: %v"
,
err
)
}
return
cleanup
,
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