Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
P
protobuf
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
protobuf
Commits
0b5111db
Commit
0b5111db
authored
Mar 08, 2019
by
bmoyles0117
Committed by
Paul Yang
Mar 08, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Raise error for JSON overflow encoding in Ruby (#5752) (#5861)
* add check for overflow * de-nestify * break long lines
parent
582743bf
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
92 additions
and
4 deletions
+92
-4
Rakefile
ruby/Rakefile
+2
-2
encode_decode.c
ruby/ext/google/protobuf_c/encode_decode.c
+5
-0
basic_test.proto
ruby/tests/basic_test.proto
+13
-2
basic_test_proto2.proto
ruby/tests/basic_test_proto2.proto
+11
-0
common_tests.rb
ruby/tests/common_tests.rb
+61
-0
No files found.
ruby/Rakefile
View file @
0b5111db
...
@@ -118,11 +118,11 @@ file "tests/test_ruby_package_proto2.rb" => "tests/test_ruby_package_proto2.prot
...
@@ -118,11 +118,11 @@ file "tests/test_ruby_package_proto2.rb" => "tests/test_ruby_package_proto2.prot
end
end
file
"tests/basic_test.rb"
=>
"tests/basic_test.proto"
do
|
file_task
|
file
"tests/basic_test.rb"
=>
"tests/basic_test.proto"
do
|
file_task
|
sh
"../src/protoc --ruby_out=. tests/basic_test.proto"
sh
"../src/protoc -
I../src -I. -
-ruby_out=. tests/basic_test.proto"
end
end
file
"tests/basic_test_proto2.rb"
=>
"tests/basic_test_proto2.proto"
do
|
file_task
|
file
"tests/basic_test_proto2.rb"
=>
"tests/basic_test_proto2.proto"
do
|
file_task
|
sh
"../src/protoc --ruby_out=. tests/basic_test_proto2.proto"
sh
"../src/protoc -
I../src -I. -
-ruby_out=. tests/basic_test_proto2.proto"
end
end
task
:genproto
=>
genproto_output
task
:genproto
=>
genproto_output
...
...
ruby/ext/google/protobuf_c/encode_decode.c
View file @
0b5111db
...
@@ -1061,6 +1061,11 @@ static void put_ruby_value(VALUE value,
...
@@ -1061,6 +1061,11 @@ static void put_ruby_value(VALUE value,
upb_sink
*
sink
,
upb_sink
*
sink
,
bool
emit_defaults
,
bool
emit_defaults
,
bool
is_json
)
{
bool
is_json
)
{
if
(
depth
>
ENCODE_MAX_NESTING
)
{
rb_raise
(
rb_eRuntimeError
,
"Maximum recursion depth exceeded during encoding."
);
}
upb_selector_t
sel
=
0
;
upb_selector_t
sel
=
0
;
if
(
upb_fielddef_isprimitive
(
f
))
{
if
(
upb_fielddef_isprimitive
(
f
))
{
sel
=
getsel
(
f
,
upb_handlers_getprimitivehandlertype
(
f
));
sel
=
getsel
(
f
,
upb_handlers_getprimitivehandlertype
(
f
));
...
...
ruby/tests/basic_test.proto
View file @
0b5111db
...
@@ -2,6 +2,8 @@ syntax = "proto3";
...
@@ -2,6 +2,8 @@ syntax = "proto3";
package
basic_test
;
package
basic_test
;
import
"google/protobuf/struct.proto"
;
message
Foo
{
message
Foo
{
Bar
bar
=
1
;
Bar
bar
=
1
;
repeated
Baz
baz
=
2
;
repeated
Baz
baz
=
2
;
...
@@ -106,4 +108,14 @@ message Outer {
...
@@ -106,4 +108,14 @@ message Outer {
}
}
message
Inner
{
message
Inner
{
}
}
\ No newline at end of file
message
MyRepeatedStruct
{
repeated
MyStruct
structs
=
1
;
}
message
MyStruct
{
string
string
=
1
;
google.protobuf.Struct
struct
=
2
;
}
ruby/tests/basic_test_proto2.proto
View file @
0b5111db
...
@@ -2,6 +2,8 @@ syntax = "proto2";
...
@@ -2,6 +2,8 @@ syntax = "proto2";
package
basic_test_proto2
;
package
basic_test_proto2
;
import
"google/protobuf/struct.proto"
;
message
Foo
{
message
Foo
{
optional
Bar
bar
=
1
;
optional
Bar
bar
=
1
;
repeated
Baz
baz
=
2
;
repeated
Baz
baz
=
2
;
...
@@ -115,3 +117,12 @@ message OneofMessage {
...
@@ -115,3 +117,12 @@ message OneofMessage {
TestEnum
d
=
4
;
TestEnum
d
=
4
;
}
}
}
}
message
MyRepeatedStruct
{
repeated
MyStruct
structs
=
1
;
}
message
MyStruct
{
optional
string
string
=
1
;
optional
google.protobuf.Struct
struct
=
2
;
}
ruby/tests/common_tests.rb
View file @
0b5111db
...
@@ -1114,6 +1114,67 @@ module CommonTests
...
@@ -1114,6 +1114,67 @@ module CommonTests
assert
JSON
.
parse
(
actual
,
:symbolize_names
=>
true
)
==
expected
assert
JSON
.
parse
(
actual
,
:symbolize_names
=>
true
)
==
expected
end
end
def
value_from_ruby
(
value
)
ret
=
Google
::
Protobuf
::
Value
.
new
case
value
when
String
ret
.
string_value
=
value
when
Google
::
Protobuf
::
Struct
ret
.
struct_value
=
value
when
Hash
ret
.
struct_value
=
struct_from_ruby
(
value
)
when
Google
::
Protobuf
::
ListValue
ret
.
list_value
=
value
when
Array
ret
.
list_value
=
list_from_ruby
(
value
)
else
@log
.
error
"Unknown type:
#{
value
.
class
}
"
raise
Google
::
Protobuf
::
Error
,
"Unknown type:
#{
value
.
class
}
"
end
ret
end
def
list_from_ruby
(
arr
)
ret
=
Google
::
Protobuf
::
ListValue
.
new
arr
.
each
do
|
v
|
ret
.
values
<<
value_from_ruby
(
v
)
end
ret
end
def
struct_from_ruby
(
hash
)
ret
=
Google
::
Protobuf
::
Struct
.
new
hash
.
each
do
|
k
,
v
|
ret
.
fields
[
k
]
||=
value_from_ruby
(
v
)
end
ret
end
def
test_deep_json
# will not overflow
json
=
'{"a":{"a":{"a":{"a":{"a":{"a":{"a":{"a":{"a":{"a":{"a":'
\
'{"a":{"a":{"a":{"a":{}}}}}}}}}}}}}}}}'
struct
=
struct_from_ruby
(
JSON
.
parse
(
json
))
assert_equal
json
,
struct
.
to_json
encoded
=
proto_module
::
MyRepeatedStruct
.
encode
(
proto_module
::
MyRepeatedStruct
.
new
(
structs:
[
proto_module
::
MyStruct
.
new
(
struct:
struct
)]))
assert_equal
json
,
proto_module
::
MyRepeatedStruct
.
decode
(
encoded
).
structs
[
0
].
struct
.
to_json
# will overflow
json
=
'{"a":{"a":{"a":[{"a":{"a":[{"a":[{"a":{"a":[{"a":[{"a":'
\
'{"a":[{"a":[{"a":{"a":{"a":[{"a":"a"}]}}}]}]}}]}]}}]}]}}]}}}'
struct
=
struct_from_ruby
(
JSON
.
parse
(
json
))
assert_equal
json
,
struct
.
to_json
assert_raise
(
RuntimeError
,
"Maximum recursion depth exceeded during encoding"
)
do
proto_module
::
MyRepeatedStruct
.
encode
(
proto_module
::
MyRepeatedStruct
.
new
(
structs:
[
proto_module
::
MyStruct
.
new
(
struct:
struct
)]))
end
end
def
test_comparison_with_arbitrary_object
def
test_comparison_with_arbitrary_object
assert
proto_module
::
TestMessage
.
new
!=
nil
assert
proto_module
::
TestMessage
.
new
!=
nil
end
end
...
...
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