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
18339264
Commit
18339264
authored
Nov 20, 2020
by
Alessio Caiazza
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Sticky EOF
parent
900f2dc9
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
24 additions
and
34 deletions
+24
-34
internal/upload/exif/exif.go
internal/upload/exif/exif.go
+22
-32
internal/upload/rewrite.go
internal/upload/rewrite.go
+2
-2
No files found.
internal/upload/exif/exif.go
View file @
18339264
...
...
@@ -6,7 +6,6 @@ import (
"errors"
"fmt"
"io"
"os"
"os/exec"
"regexp"
...
...
@@ -20,15 +19,11 @@ type cleaner struct {
cmd
*
exec
.
Cmd
stdout
io
.
Reader
stderr
bytes
.
Buffer
waitDone
chan
struct
{}
waitErr
error
eof
bool
}
func
NewCleaner
(
ctx
context
.
Context
,
stdin
io
.
Reader
)
(
io
.
Reader
,
error
)
{
c
:=
&
cleaner
{
ctx
:
ctx
,
waitDone
:
make
(
chan
struct
{}),
}
func
NewCleaner
(
ctx
context
.
Context
,
stdin
io
.
Reader
)
(
io
.
ReadCloser
,
error
)
{
c
:=
&
cleaner
{
ctx
:
ctx
}
if
err
:=
c
.
startProcessing
(
stdin
);
err
!=
nil
{
return
nil
,
err
...
...
@@ -37,28 +32,32 @@ func NewCleaner(ctx context.Context, stdin io.Reader) (io.Reader, error) {
return
c
,
nil
}
func
(
c
*
cleaner
)
Close
()
error
{
if
c
.
cmd
==
nil
{
return
nil
}
return
c
.
cmd
.
Wait
()
}
func
(
c
*
cleaner
)
Read
(
p
[]
byte
)
(
int
,
error
)
{
if
c
.
eof
{
return
0
,
io
.
EOF
}
n
,
err
:=
c
.
stdout
.
Read
(
p
)
if
err
==
io
.
EOF
{
if
waitErr
:=
c
.
w
ait
();
waitErr
!=
nil
{
if
waitErr
:=
c
.
cmd
.
W
ait
();
waitErr
!=
nil
{
log
.
WithContextFields
(
c
.
ctx
,
log
.
Fields
{
"command"
:
c
.
cmd
.
Args
,
"stderr"
:
c
.
stderr
.
String
(),
"error"
:
waitErr
.
Error
(),
})
.
Print
(
"exiftool command failed"
)
return
n
,
ErrRemovingExif
}
}
// Calling c.cmd.Wait() will close the stdout pipe, any attempt to read from it will fail with an os.PathError.
// see: https://gitlab.com/gitlab-org/gitlab-workhorse/-/issues/233
if
_
,
ok
:=
err
.
(
*
os
.
PathError
);
ok
{
select
{
case
<-
c
.
waitDone
:
return
n
,
io
.
EOF
default
:
return
n
,
err
}
c
.
eof
=
true
}
return
n
,
err
...
...
@@ -97,19 +96,10 @@ func (c *cleaner) startProcessing(stdin io.Reader) error {
if
err
=
c
.
cmd
.
Start
();
err
!=
nil
{
return
fmt
.
Errorf
(
"start %v: %v"
,
c
.
cmd
.
Args
,
err
)
}
go
func
()
{
c
.
waitErr
=
c
.
cmd
.
Wait
()
close
(
c
.
waitDone
)
}()
return
nil
}
func
(
c
*
cleaner
)
wait
()
error
{
<-
c
.
waitDone
return
c
.
waitErr
}
func
IsExifFile
(
filename
string
)
bool
{
filenameMatch
:=
regexp
.
MustCompile
(
`(?i)\.(jpg|jpeg|tiff)$`
)
...
...
internal/upload/rewrite.go
View file @
18339264
...
...
@@ -174,12 +174,12 @@ func handleExifUpload(ctx context.Context, r io.Reader, filename string) (io.Rea
"filename"
:
filename
,
})
.
Print
(
"running exiftool to remove any metadata"
)
r
,
err
:=
exif
.
NewCleaner
(
ctx
,
r
)
cleane
r
,
err
:=
exif
.
NewCleaner
(
ctx
,
r
)
if
err
!=
nil
{
return
nil
,
err
}
return
ioutil
.
NopCloser
(
r
)
,
nil
return
cleaner
,
nil
}
func
handleLsifUpload
(
ctx
context
.
Context
,
reader
io
.
Reader
,
tempPath
,
filename
string
,
preauth
*
api
.
Response
)
(
io
.
ReadCloser
,
error
)
{
...
...
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