Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
caddy
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
0
Merge Requests
0
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
Łukasz Nowak
caddy
Commits
40b52fb0
Commit
40b52fb0
authored
7 years ago
by
Matt Holt
Committed by
GitHub
7 years ago
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1775 from tw4452852/roller_parse
log,error: fix roller parser issue
parents
f1dd9f2b
91150bb7
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
52 additions
and
19 deletions
+52
-19
caddyhttp/errors/setup.go
caddyhttp/errors/setup.go
+7
-5
caddyhttp/errors/setup_test.go
caddyhttp/errors/setup_test.go
+12
-1
caddyhttp/httpserver/roller.go
caddyhttp/httpserver/roller.go
+22
-6
caddyhttp/log/setup.go
caddyhttp/log/setup.go
+2
-5
caddyhttp/log/setup_test.go
caddyhttp/log/setup_test.go
+9
-2
No files found.
caddyhttp/errors/setup.go
View file @
40b52fb0
...
...
@@ -44,18 +44,20 @@ func errorsParse(c *caddy.Controller) (*ErrorHandler, error) {
for
c
.
NextBlock
()
{
what
:=
c
.
Val
()
if
!
c
.
NextArg
()
{
return
c
.
ArgErr
()
}
where
:=
c
.
Val
()
where
:=
c
.
RemainingArgs
()
if
httpserver
.
IsLogRollerSubdirective
(
what
)
{
var
err
error
err
=
httpserver
.
ParseRoller
(
handler
.
Log
.
Roller
,
what
,
where
)
err
=
httpserver
.
ParseRoller
(
handler
.
Log
.
Roller
,
what
,
where
...
)
if
err
!=
nil
{
return
err
}
}
else
{
if
len
(
where
)
!=
1
{
return
c
.
ArgErr
()
}
where
:=
where
[
0
]
// Error page; ensure it exists
if
!
filepath
.
IsAbs
(
where
)
{
where
=
filepath
.
Join
(
cfg
.
Root
,
where
)
...
...
This diff is collapsed.
Click to expand it.
caddyhttp/errors/setup_test.go
View file @
40b52fb0
...
...
@@ -85,7 +85,12 @@ func TestErrorsParse(t *testing.T) {
Roller
:
httpserver
.
DefaultLogRoller
(),
},
}},
{
`errors errors.txt { rotate_size 2 rotate_age 10 rotate_keep 3 rotate_compress }`
,
false
,
ErrorHandler
{
{
`errors errors.txt {
rotate_size 2
rotate_age 10
rotate_keep 3
rotate_compress
}`
,
false
,
ErrorHandler
{
ErrorPages
:
map
[
int
]
string
{},
Log
:
&
httpserver
.
Logger
{
Output
:
"errors.txt"
,
Roller
:
&
httpserver
.
LogRoller
{
...
...
@@ -144,6 +149,12 @@ func TestErrorsParse(t *testing.T) {
},
Log
:
&
httpserver
.
Logger
{},
}},
{
`errors errors.txt { rotate_size 2 rotate_age 10 rotate_keep 3 rotate_compress }`
,
true
,
ErrorHandler
{
ErrorPages
:
map
[
int
]
string
{},
Log
:
&
httpserver
.
Logger
{}}},
{
`errors errors.txt {
rotate_compress invalid
}`
,
true
,
ErrorHandler
{
ErrorPages
:
map
[
int
]
string
{},
Log
:
&
httpserver
.
Logger
{}}},
// Next two test cases is the detection of duplicate status codes
{
`errors {
503 503.html
...
...
This diff is collapsed.
Click to expand it.
caddyhttp/httpserver/roller.go
View file @
40b52fb0
package
httpserver
import
(
"errors"
"io"
"path/filepath"
"strconv"
...
...
@@ -54,17 +55,32 @@ func IsLogRollerSubdirective(subdir string) bool {
subdir
==
directiveRotateCompress
}
var
invalidRollerParameterErr
=
errors
.
New
(
"invalid roller parameter"
)
// ParseRoller parses roller contents out of c.
func
ParseRoller
(
l
*
LogRoller
,
what
string
,
where
string
)
error
{
func
ParseRoller
(
l
*
LogRoller
,
what
string
,
where
...
string
)
error
{
if
l
==
nil
{
l
=
DefaultLogRoller
()
}
var
value
int
var
err
error
value
,
err
=
strconv
.
Atoi
(
where
)
if
what
!=
directiveRotateCompress
&&
err
!=
nil
{
return
err
// rotate_compress doesn't accept any parameters.
// others only accept one parameter
if
(
what
==
directiveRotateCompress
&&
len
(
where
)
!=
0
)
||
(
what
!=
directiveRotateCompress
&&
len
(
where
)
!=
1
)
{
return
invalidRollerParameterErr
}
var
(
value
int
err
error
)
if
what
!=
directiveRotateCompress
{
value
,
err
=
strconv
.
Atoi
(
where
[
0
])
if
err
!=
nil
{
return
err
}
}
switch
what
{
case
directiveRotateSize
:
l
.
MaxSize
=
value
...
...
This diff is collapsed.
Click to expand it.
caddyhttp/log/setup.go
View file @
40b52fb0
...
...
@@ -38,17 +38,14 @@ func logParse(c *caddy.Controller) ([]*Rule, error) {
for
c
.
NextBlock
()
{
what
:=
c
.
Val
()
if
!
c
.
NextArg
()
{
return
nil
,
c
.
ArgErr
()
}
where
:=
c
.
Val
()
where
:=
c
.
RemainingArgs
()
// only support roller related options inside a block
if
!
httpserver
.
IsLogRollerSubdirective
(
what
)
{
return
nil
,
c
.
ArgErr
()
}
if
err
:=
httpserver
.
ParseRoller
(
logRoller
,
what
,
where
);
err
!=
nil
{
if
err
:=
httpserver
.
ParseRoller
(
logRoller
,
what
,
where
...
);
err
!=
nil
{
return
nil
,
err
}
}
...
...
This diff is collapsed.
Click to expand it.
caddyhttp/log/setup_test.go
View file @
40b52fb0
...
...
@@ -194,7 +194,12 @@ func TestLogParse(t *testing.T) {
Format
:
"{when}"
,
}},
}}},
{
`log access.log { rotate_size 2 rotate_age 10 rotate_keep 3 }`
,
false
,
[]
Rule
{{
{
`log access.log {
rotate_size 2
rotate_age 10
rotate_keep 3
rotate_compress
}`
,
false
,
[]
Rule
{{
PathScope
:
"/"
,
Entries
:
[]
*
Entry
{{
Log
:
&
httpserver
.
Logger
{
...
...
@@ -203,7 +208,7 @@ func TestLogParse(t *testing.T) {
MaxSize
:
2
,
MaxAge
:
10
,
MaxBackups
:
3
,
Compress
:
fals
e
,
Compress
:
tru
e
,
LocalTime
:
true
,
}},
Format
:
DefaultLogFormat
,
...
...
@@ -226,6 +231,8 @@ func TestLogParse(t *testing.T) {
Format
:
"{when}"
,
}},
}}},
{
`log access.log { rotate_size 2 rotate_age 10 rotate_keep 3 }`
,
true
,
nil
},
{
`log access.log { rotate_compress invalid }`
,
true
,
nil
},
{
`log access.log { rotate_size }`
,
true
,
nil
},
{
`log access.log { invalid_option 1 }`
,
true
,
nil
},
{
`log / acccess.log "{remote} - [{when}] "{method} {port}" {scheme} {mitm} "`
,
true
,
nil
},
...
...
This diff is collapsed.
Click to expand it.
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