bson 4.14.1 → 5.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- checksums.yaml.gz.sig +0 -0
- data/README.md +4 -4
- data/Rakefile +5 -0
- data/ext/bson/bson-native.h +12 -4
- data/ext/bson/extconf.rb +8 -3
- data/ext/bson/init.c +11 -11
- data/ext/bson/read.c +21 -6
- data/ext/bson/util.c +168 -16
- data/ext/bson/write.c +30 -39
- data/lib/bson/active_support.rb +1 -0
- data/lib/bson/array.rb +57 -31
- data/lib/bson/big_decimal.rb +16 -6
- data/lib/bson/binary.rb +255 -128
- data/lib/bson/boolean.rb +1 -0
- data/lib/bson/code.rb +9 -11
- data/lib/bson/code_with_scope.rb +8 -10
- data/lib/bson/config.rb +1 -27
- data/lib/bson/date.rb +2 -1
- data/lib/bson/date_time.rb +2 -1
- data/lib/bson/db_pointer.rb +11 -12
- data/lib/bson/dbref.rb +11 -9
- data/lib/bson/decimal128/builder.rb +9 -8
- data/lib/bson/decimal128.rb +33 -109
- data/lib/bson/document.rb +1 -0
- data/lib/bson/environment.rb +1 -0
- data/lib/bson/error/bson_decode_error.rb +11 -0
- data/lib/bson/error/ext_json_parse_error.rb +11 -0
- data/lib/bson/error/illegal_key.rb +23 -0
- data/lib/bson/error/invalid_binary_type.rb +37 -0
- data/lib/bson/error/invalid_dbref_argument.rb +12 -0
- data/lib/bson/error/invalid_decimal128_argument.rb +25 -0
- data/lib/bson/error/invalid_decimal128_range.rb +27 -0
- data/lib/bson/error/invalid_decimal128_string.rb +26 -0
- data/lib/bson/error/invalid_key.rb +24 -0
- data/lib/bson/error/invalid_object_id.rb +11 -0
- data/lib/bson/error/invalid_regexp_pattern.rb +13 -0
- data/lib/bson/error/unrepresentable_precision.rb +19 -0
- data/lib/bson/error/unserializable_class.rb +13 -0
- data/lib/bson/error/unsupported_binary_subtype.rb +12 -0
- data/lib/bson/error/unsupported_type.rb +11 -0
- data/lib/bson/error.rb +16 -28
- data/lib/bson/ext_json.rb +1 -0
- data/lib/bson/false_class.rb +2 -1
- data/lib/bson/float.rb +2 -1
- data/lib/bson/hash.rb +127 -72
- data/lib/bson/int32.rb +16 -4
- data/lib/bson/int64.rb +16 -4
- data/lib/bson/integer.rb +3 -4
- data/lib/bson/json.rb +1 -0
- data/lib/bson/max_key.rb +7 -9
- data/lib/bson/min_key.rb +7 -9
- data/lib/bson/nil_class.rb +1 -0
- data/lib/bson/object.rb +5 -25
- data/lib/bson/object_id.rb +75 -121
- data/lib/bson/open_struct.rb +3 -2
- data/lib/bson/regexp.rb +35 -64
- data/lib/bson/registry.rb +2 -6
- data/lib/bson/specialized.rb +2 -1
- data/lib/bson/string.rb +4 -27
- data/lib/bson/symbol.rb +22 -19
- data/lib/bson/time.rb +2 -1
- data/lib/bson/time_with_zone.rb +13 -1
- data/lib/bson/timestamp.rb +2 -1
- data/lib/bson/true_class.rb +2 -1
- data/lib/bson/undefined.rb +14 -0
- data/lib/bson/version.rb +2 -1
- data/lib/bson.rb +3 -2
- data/spec/bson/array_spec.rb +19 -60
- data/spec/bson/big_decimal_spec.rb +16 -4
- data/spec/bson/binary_spec.rb +83 -74
- data/spec/bson/binary_uuid_spec.rb +1 -0
- data/spec/bson/boolean_spec.rb +1 -0
- data/spec/bson/byte_buffer_read_spec.rb +1 -0
- data/spec/bson/byte_buffer_spec.rb +1 -0
- data/spec/bson/byte_buffer_write_spec.rb +1 -0
- data/spec/bson/code_spec.rb +5 -3
- data/spec/bson/code_with_scope_spec.rb +5 -3
- data/spec/bson/config_spec.rb +1 -35
- data/spec/bson/date_spec.rb +1 -0
- data/spec/bson/date_time_spec.rb +1 -0
- data/spec/bson/dbref_legacy_spec.rb +20 -3
- data/spec/bson/dbref_spec.rb +9 -9
- data/spec/bson/decimal128_spec.rb +249 -14
- data/spec/bson/document_as_spec.rb +1 -0
- data/spec/bson/document_spec.rb +1 -1
- data/spec/bson/ext_json_parse_spec.rb +1 -0
- data/spec/bson/false_class_spec.rb +8 -0
- data/spec/bson/float_spec.rb +8 -3
- data/spec/bson/hash_as_spec.rb +1 -0
- data/spec/bson/hash_spec.rb +87 -75
- data/spec/bson/int32_spec.rb +21 -6
- data/spec/bson/int64_spec.rb +21 -6
- data/spec/bson/integer_spec.rb +45 -13
- data/spec/bson/json_spec.rb +1 -0
- data/spec/bson/max_key_spec.rb +5 -3
- data/spec/bson/min_key_spec.rb +5 -3
- data/spec/bson/nil_class_spec.rb +1 -0
- data/spec/bson/object_id_spec.rb +43 -4
- data/spec/bson/object_spec.rb +2 -1
- data/spec/bson/open_struct_spec.rb +14 -71
- data/spec/bson/raw_spec.rb +9 -15
- data/spec/bson/regexp_spec.rb +4 -3
- data/spec/bson/registry_spec.rb +2 -1
- data/spec/bson/string_spec.rb +13 -38
- data/spec/bson/symbol_raw_spec.rb +25 -0
- data/spec/bson/symbol_spec.rb +15 -18
- data/spec/bson/time_spec.rb +1 -0
- data/spec/bson/time_with_zone_spec.rb +1 -0
- data/spec/bson/timestamp_spec.rb +1 -0
- data/spec/bson/true_class_spec.rb +8 -0
- data/spec/bson/undefined_spec.rb +27 -0
- data/spec/bson_spec.rb +1 -0
- data/spec/runners/common_driver.rb +6 -5
- data/spec/runners/corpus.rb +6 -0
- data/spec/runners/corpus_legacy.rb +1 -0
- data/spec/shared/lib/mrss/constraints.rb +8 -16
- data/spec/shared/lib/mrss/docker_runner.rb +30 -3
- data/spec/shared/lib/mrss/eg_config_utils.rb +51 -0
- data/spec/shared/lib/mrss/event_subscriber.rb +15 -5
- data/spec/shared/lib/mrss/lite_constraints.rb +48 -1
- data/spec/shared/lib/mrss/server_version_registry.rb +16 -23
- data/spec/shared/lib/mrss/session_registry.rb +69 -0
- data/spec/shared/lib/mrss/session_registry_legacy.rb +60 -0
- data/spec/shared/lib/mrss/utils.rb +28 -6
- data/spec/shared/share/Dockerfile.erb +68 -85
- data/spec/shared/shlib/config.sh +27 -0
- data/spec/shared/shlib/server.sh +73 -24
- data/spec/shared/shlib/set_env.sh +39 -1
- data/spec/spec_helper.rb +1 -0
- data/spec/spec_tests/common_driver_spec.rb +9 -4
- data/spec/spec_tests/corpus_legacy_spec.rb +1 -0
- data/spec/spec_tests/corpus_spec.rb +13 -3
- data/spec/spec_tests/data/corpus/binary.json +5 -0
- data/spec/spec_tests/data/corpus/code.json +13 -13
- data/spec/spec_tests/data/corpus/decimal128-4.json +48 -0
- data/spec/spec_tests/data/corpus/decimal128-6.json +12 -0
- data/spec/spec_tests/data/corpus/decimal128-7.json +4 -0
- data/spec/spec_tests/data/corpus/document.json +20 -0
- data/spec/spec_tests/data/corpus/symbol.json +7 -7
- data/spec/spec_tests/data/corpus/top.json +18 -3
- data/spec/support/shared_examples.rb +28 -5
- data/spec/support/spec_config.rb +1 -0
- data/spec/support/utils.rb +49 -1
- data.tar.gz.sig +0 -0
- metadata +167 -143
- metadata.gz.sig +0 -0
data/lib/bson/error.rb
CHANGED
@@ -1,34 +1,22 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
# rubocop:todo all
|
2
3
|
module BSON
|
3
4
|
# Base exception class for all BSON-related errors.
|
4
|
-
#
|
5
|
-
# @note Many existing exceptions raised by bson-ruby do not derive from
|
6
|
-
# this base class. This will change in the next major version (5.0).
|
7
5
|
class Error < StandardError
|
8
|
-
|
9
|
-
# Exception raised when Extended JSON parsing fails.
|
10
|
-
class ExtJSONParseError < Error
|
11
|
-
end
|
12
|
-
|
13
|
-
# Exception raised when decoding BSON and the data contains an
|
14
|
-
# unsupported binary subtype.
|
15
|
-
class UnsupportedBinarySubtype < Error
|
16
|
-
end
|
17
|
-
|
18
|
-
# Exception raised when BSON decoding fails.
|
19
|
-
class BSONDecodeError < Error
|
20
|
-
end
|
21
|
-
|
22
|
-
# Exception raised when serializing an Array or Hash to BSON and an
|
23
|
-
# array or hash element is of a class that does not define how to serialize
|
24
|
-
# itself to BSON.
|
25
|
-
class UnserializableClass < Error
|
26
|
-
end
|
27
|
-
|
28
|
-
# Exception raised when there is an invalid argument passed into the
|
29
|
-
# constructor of regexp object. This includes when the argument contains
|
30
|
-
# a null byte.
|
31
|
-
class InvalidRegexpPattern < Error
|
32
|
-
end
|
33
6
|
end
|
34
7
|
end
|
8
|
+
|
9
|
+
require 'bson/error/bson_decode_error'
|
10
|
+
require 'bson/error/ext_json_parse_error'
|
11
|
+
require 'bson/error/invalid_binary_type'
|
12
|
+
require 'bson/error/invalid_dbref_argument'
|
13
|
+
require 'bson/error/invalid_decimal128_argument'
|
14
|
+
require 'bson/error/invalid_decimal128_range'
|
15
|
+
require 'bson/error/invalid_decimal128_string'
|
16
|
+
require 'bson/error/invalid_key'
|
17
|
+
require 'bson/error/invalid_object_id'
|
18
|
+
require 'bson/error/invalid_regexp_pattern'
|
19
|
+
require 'bson/error/unrepresentable_precision'
|
20
|
+
require 'bson/error/unserializable_class'
|
21
|
+
require 'bson/error/unsupported_binary_subtype'
|
22
|
+
require 'bson/error/unsupported_type'
|
data/lib/bson/ext_json.rb
CHANGED
data/lib/bson/false_class.rb
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
# rubocop:todo all
|
2
3
|
# Copyright (C) 2009-2020 MongoDB Inc.
|
3
4
|
#
|
4
5
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
@@ -50,7 +51,7 @@ module BSON
|
|
50
51
|
# @see http://bsonspec.org/#/specification
|
51
52
|
#
|
52
53
|
# @since 2.0.0
|
53
|
-
def to_bson(buffer = ByteBuffer.new
|
54
|
+
def to_bson(buffer = ByteBuffer.new)
|
54
55
|
buffer.put_byte(FALSE_BYTE)
|
55
56
|
end
|
56
57
|
end
|
data/lib/bson/float.rb
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
# rubocop:todo all
|
2
3
|
# Copyright (C) 2009-2020 MongoDB Inc.
|
3
4
|
#
|
4
5
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
@@ -43,7 +44,7 @@ module BSON
|
|
43
44
|
# @see http://bsonspec.org/#/specification
|
44
45
|
#
|
45
46
|
# @since 2.0.0
|
46
|
-
def to_bson(buffer = ByteBuffer.new
|
47
|
+
def to_bson(buffer = ByteBuffer.new)
|
47
48
|
buffer.put_double(self)
|
48
49
|
end
|
49
50
|
|
data/lib/bson/hash.rb
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
|
2
3
|
# Copyright (C) 2009-2020 MongoDB Inc.
|
3
4
|
#
|
4
5
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
@@ -13,19 +14,14 @@
|
|
13
14
|
# See the License for the specific language governing permissions and
|
14
15
|
# limitations under the License.
|
15
16
|
|
17
|
+
# The top-level BSON module.
|
16
18
|
module BSON
|
17
|
-
|
18
19
|
# Injects behaviour for encoding and decoding hashes to
|
19
20
|
# and from raw bytes as specified by the BSON spec.
|
20
21
|
#
|
21
22
|
# @see http://bsonspec.org/#/specification
|
22
|
-
#
|
23
|
-
# @since 2.0.0
|
24
23
|
module Hash
|
25
|
-
|
26
24
|
# A hash, also called an embedded document, is type 0x03 in the BSON spec.
|
27
|
-
#
|
28
|
-
# @since 2.0.0
|
29
25
|
BSON_TYPE = ::String.new(3.chr, encoding: BINARY).freeze
|
30
26
|
|
31
27
|
# Get the hash as encoded BSON.
|
@@ -36,33 +32,13 @@ module BSON
|
|
36
32
|
# @return [ BSON::ByteBuffer ] The buffer with the encoded object.
|
37
33
|
#
|
38
34
|
# @see http://bsonspec.org/#/specification
|
39
|
-
|
40
|
-
|
41
|
-
|
35
|
+
def to_bson(buffer = ByteBuffer.new)
|
36
|
+
# If the native buffer version has an optimized version, we'll call
|
37
|
+
# it directly. Otherwise, we'll serialize the hash the hard way.
|
42
38
|
if buffer.respond_to?(:put_hash)
|
43
|
-
buffer.put_hash(self
|
39
|
+
buffer.put_hash(self)
|
44
40
|
else
|
45
|
-
|
46
|
-
buffer.put_int32(0)
|
47
|
-
each do |field, value|
|
48
|
-
unless value.respond_to?(:bson_type)
|
49
|
-
raise Error::UnserializableClass, "Hash value for key '#{field}' does not define its BSON serialized type: #{value}"
|
50
|
-
end
|
51
|
-
buffer.put_byte(value.bson_type)
|
52
|
-
key = field.to_bson_key(validating_keys)
|
53
|
-
begin
|
54
|
-
buffer.put_cstring(key)
|
55
|
-
rescue ArgumentError => e
|
56
|
-
raise ArgumentError, "Error serializing key #{key}: #{e.class}: #{e}"
|
57
|
-
rescue EncodingError => e
|
58
|
-
# Note this may convert exception class from a subclass of
|
59
|
-
# EncodingError to EncodingError itself
|
60
|
-
raise EncodingError, "Error serializing key #{key}: #{e.class}: #{e}"
|
61
|
-
end
|
62
|
-
value.to_bson(buffer, validating_keys)
|
63
|
-
end
|
64
|
-
buffer.put_byte(NULL_BYTE)
|
65
|
-
buffer.replace_int32(position, buffer.length - position)
|
41
|
+
serialize_to_buffer(buffer)
|
66
42
|
end
|
67
43
|
end
|
68
44
|
|
@@ -72,8 +48,6 @@ module BSON
|
|
72
48
|
# hash.to_bson_normalized_value
|
73
49
|
#
|
74
50
|
# @return [ BSON::Document ] The normalized hash.
|
75
|
-
#
|
76
|
-
# @since 3.0.0
|
77
51
|
def to_bson_normalized_value
|
78
52
|
Document.new(self)
|
79
53
|
end
|
@@ -92,10 +66,67 @@ module BSON
|
|
92
66
|
transform_values { |value| value.as_extended_json(**options) }
|
93
67
|
end
|
94
68
|
|
95
|
-
|
69
|
+
private
|
70
|
+
|
71
|
+
# Serialize this hash instance to the given buffer.
|
72
|
+
#
|
73
|
+
# @param [ ByteBuf ] buffer The buffer to receive the serialized hash.
|
74
|
+
def serialize_to_buffer(buffer)
|
75
|
+
position = buffer.length
|
76
|
+
buffer.put_int32(0)
|
77
|
+
serialize_key_value_pairs(buffer)
|
78
|
+
buffer.put_byte(NULL_BYTE)
|
79
|
+
buffer.replace_int32(position, buffer.length - position)
|
80
|
+
end
|
81
|
+
|
82
|
+
# Serialize the key/value pairs in this hash instance to the given
|
83
|
+
# buffer.
|
84
|
+
#
|
85
|
+
# @param [ ByteBuf ] buffer The buffer to received the serialized
|
86
|
+
# key/value pairs.
|
87
|
+
#
|
88
|
+
# @raise [ Error::UnserializableClass ] if a value cannot be serialized
|
89
|
+
def serialize_key_value_pairs(buffer)
|
90
|
+
each do |field, value|
|
91
|
+
unless value.respond_to?(:bson_type)
|
92
|
+
raise Error::UnserializableClass,
|
93
|
+
"Hash value for key '#{field}' does not define its BSON serialized type: #{value}"
|
94
|
+
end
|
95
|
+
|
96
|
+
buffer.put_byte(value.bson_type)
|
97
|
+
key = field.to_bson_key
|
98
|
+
serialize_key(buffer, key)
|
99
|
+
value.to_bson(buffer)
|
100
|
+
end
|
101
|
+
end
|
102
|
+
|
103
|
+
# Serialize the key/value pairs in this hash instance to the given
|
104
|
+
# buffer.
|
105
|
+
#
|
106
|
+
# @param [ ByteBuf ] buffer The buffer to received the serialized
|
107
|
+
# key/value pairs.
|
108
|
+
#
|
109
|
+
# @raise [ ArgumentError ] if the string cannot be serialized
|
110
|
+
# @raise [ EncodingError ] if the string is not a valid encoding
|
111
|
+
def serialize_key(buffer, key)
|
112
|
+
buffer.put_cstring(key)
|
113
|
+
rescue ArgumentError => e
|
114
|
+
raise ArgumentError, "Error serializing key #{key}: #{e.class}: #{e}"
|
115
|
+
rescue EncodingError => e
|
116
|
+
# Note this may convert exception class from a subclass of
|
117
|
+
# EncodingError to EncodingError itself
|
118
|
+
raise EncodingError, "Error serializing key #{key}: #{e.class}: #{e}"
|
119
|
+
end
|
96
120
|
|
121
|
+
# The methods to augment the Hash class with (class-level methods).
|
122
|
+
module ClassMethods
|
97
123
|
# Deserialize the hash from BSON.
|
98
124
|
#
|
125
|
+
# @note If the argument cannot be parsed, an exception will be raised
|
126
|
+
# and the argument will be left in an undefined state. The caller
|
127
|
+
# must explicitly call `rewind` on the buffer before trying to parse
|
128
|
+
# it again.
|
129
|
+
#
|
99
130
|
# @param [ ByteBuffer ] buffer The byte buffer.
|
100
131
|
#
|
101
132
|
# @option options [ nil | :bson ] :mode Decoding mode to use.
|
@@ -103,55 +134,79 @@ module BSON
|
|
103
134
|
# @return [ Hash ] The decoded hash.
|
104
135
|
#
|
105
136
|
# @see http://bsonspec.org/#/specification
|
106
|
-
#
|
107
|
-
# @since 2.0.0
|
108
137
|
def from_bson(buffer, **options)
|
109
138
|
if buffer.respond_to?(:get_hash)
|
110
139
|
buffer.get_hash(**options)
|
111
140
|
else
|
112
|
-
hash =
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
141
|
+
hash = parse_hash_from_buffer(buffer, **options)
|
142
|
+
maybe_dbref(hash)
|
143
|
+
end
|
144
|
+
end
|
145
|
+
|
146
|
+
private
|
147
|
+
|
148
|
+
# If the hash looks like a DBRef, try and decode it as such. If
|
149
|
+
# is turns out to be invalid--or if it doesn't look like a DBRef
|
150
|
+
# to begin with--return the hash itself.
|
151
|
+
#
|
152
|
+
# @param [ Hash ] hash the hash to try and decode
|
153
|
+
#
|
154
|
+
# @return [ DBRef | Hash ] the result of decoding the hash
|
155
|
+
def maybe_dbref(hash)
|
156
|
+
return DBRef.new(hash) if hash['$ref'] && hash['$id']
|
157
|
+
|
158
|
+
hash
|
159
|
+
rescue Error::InvalidDBRefArgument
|
160
|
+
hash
|
161
|
+
end
|
162
|
+
|
163
|
+
# Given a byte buffer, extract and return a hash from it.
|
164
|
+
#
|
165
|
+
# @param [ ByteBuf ] buffer the buffer to read data from
|
166
|
+
# @param [ Hash ] options the keyword arguments
|
167
|
+
#
|
168
|
+
# @return [ Hash ] the hash parsed from the buffer
|
169
|
+
def parse_hash_from_buffer(buffer, **options)
|
170
|
+
hash = Document.allocate
|
171
|
+
start_position = buffer.read_position
|
172
|
+
expected_byte_size = buffer.get_int32
|
173
|
+
|
174
|
+
parse_hash_contents(hash, buffer, **options)
|
175
|
+
|
176
|
+
actual_byte_size = buffer.read_position - start_position
|
177
|
+
return hash unless actual_byte_size != expected_byte_size
|
178
|
+
|
179
|
+
raise Error::BSONDecodeError,
|
180
|
+
"Expected hash to take #{expected_byte_size} bytes but it took #{actual_byte_size} bytes"
|
181
|
+
end
|
182
|
+
|
183
|
+
# Given an empty hash and a byte buffer, parse the key/value pairs from
|
184
|
+
# the buffer and populate the hash with them.
|
185
|
+
#
|
186
|
+
# @param [ Hash ] hash the hash to populate
|
187
|
+
# @param [ ByteBuf ] buffer the buffer to read data from
|
188
|
+
# @param [ Hash ] options the keyword arguments
|
189
|
+
def parse_hash_contents(hash, buffer, **options)
|
190
|
+
while (type = buffer.get_byte) != NULL_BYTE
|
191
|
+
field = buffer.get_cstring
|
192
|
+
cls = BSON::Registry.get(type, field)
|
193
|
+
value = if options.empty?
|
194
|
+
# Compatibility with the older Ruby driver versions which define
|
195
|
+
# a DBRef class with from_bson accepting a single argument.
|
196
|
+
cls.from_bson(buffer)
|
197
|
+
else
|
198
|
+
cls.from_bson(buffer, **options)
|
199
|
+
end
|
200
|
+
hash.store(field, value)
|
142
201
|
end
|
143
202
|
end
|
144
203
|
end
|
145
204
|
|
146
205
|
# Register this type when the module is loaded.
|
147
|
-
#
|
148
|
-
# @since 2.0.0
|
149
206
|
Registry.register(BSON_TYPE, ::Hash)
|
150
207
|
end
|
151
208
|
|
152
209
|
# Enrich the core Hash class with this module.
|
153
|
-
|
154
|
-
|
155
|
-
::Hash.send(:include, Hash)
|
156
|
-
::Hash.send(:extend, Hash::ClassMethods)
|
210
|
+
::Hash.include Hash
|
211
|
+
::Hash.extend Hash::ClassMethods
|
157
212
|
end
|
data/lib/bson/int32.rb
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
# rubocop:todo all
|
2
3
|
# Copyright (C) 2009-2020 MongoDB Inc.
|
3
4
|
#
|
4
5
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
@@ -21,6 +22,7 @@ module BSON
|
|
21
22
|
#
|
22
23
|
# @since 2.0.0
|
23
24
|
class Int32
|
25
|
+
include JSON
|
24
26
|
|
25
27
|
# A boolean is type 0x08 in the BSON spec.
|
26
28
|
#
|
@@ -86,7 +88,7 @@ module BSON
|
|
86
88
|
# @see http://bsonspec.org/#/specification
|
87
89
|
#
|
88
90
|
# @since 4.2.0
|
89
|
-
def to_bson(buffer = ByteBuffer.new
|
91
|
+
def to_bson(buffer = ByteBuffer.new)
|
90
92
|
buffer.put_int32(value)
|
91
93
|
end
|
92
94
|
|
@@ -95,12 +97,10 @@ module BSON
|
|
95
97
|
# @example Convert the integer to a BSON key string.
|
96
98
|
# int.to_bson_key
|
97
99
|
#
|
98
|
-
# @param [ true, false ] validating_keys If BSON should validate the key.
|
99
|
-
#
|
100
100
|
# @return [ String ] The string key.
|
101
101
|
#
|
102
102
|
# @since 4.2.0
|
103
|
-
def to_bson_key
|
103
|
+
def to_bson_key
|
104
104
|
value
|
105
105
|
end
|
106
106
|
|
@@ -118,6 +118,18 @@ module BSON
|
|
118
118
|
alias :eql? :==
|
119
119
|
alias :=== :==
|
120
120
|
|
121
|
+
# Return a string representation of the Int32 for use in
|
122
|
+
# application-level JSON serialization. This method is intentionally
|
123
|
+
# different from #as_extended_json.
|
124
|
+
#
|
125
|
+
# @example Get the Int32 as a JSON-serializable object.
|
126
|
+
# int32.as_json
|
127
|
+
#
|
128
|
+
# @return [ Integer ] The Int32 as an Integer.
|
129
|
+
def as_json(**options)
|
130
|
+
value
|
131
|
+
end
|
132
|
+
|
121
133
|
# Converts this object to a representation directly serializable to
|
122
134
|
# Extended JSON (https://github.com/mongodb/specifications/blob/master/source/extended-json.rst).
|
123
135
|
#
|
data/lib/bson/int64.rb
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
# rubocop:todo all
|
2
3
|
# Copyright (C) 2009-2020 MongoDB Inc.
|
3
4
|
#
|
4
5
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
@@ -21,6 +22,7 @@ module BSON
|
|
21
22
|
#
|
22
23
|
# @since 2.0.0
|
23
24
|
class Int64
|
25
|
+
include JSON
|
24
26
|
|
25
27
|
# A boolean is type 0x08 in the BSON spec.
|
26
28
|
#
|
@@ -86,7 +88,7 @@ module BSON
|
|
86
88
|
# @see http://bsonspec.org/#/specification
|
87
89
|
#
|
88
90
|
# @since 4.2.0
|
89
|
-
def to_bson(buffer = ByteBuffer.new
|
91
|
+
def to_bson(buffer = ByteBuffer.new)
|
90
92
|
buffer.put_int64(value)
|
91
93
|
end
|
92
94
|
|
@@ -95,12 +97,10 @@ module BSON
|
|
95
97
|
# @example Convert the integer to a BSON key string.
|
96
98
|
# int.to_bson_key
|
97
99
|
#
|
98
|
-
# @param [ true, false ] validating_keys If BSON should validate the key.
|
99
|
-
#
|
100
100
|
# @return [ String ] The string key.
|
101
101
|
#
|
102
102
|
# @since 4.2.0
|
103
|
-
def to_bson_key
|
103
|
+
def to_bson_key
|
104
104
|
value
|
105
105
|
end
|
106
106
|
|
@@ -118,6 +118,18 @@ module BSON
|
|
118
118
|
alias :eql? :==
|
119
119
|
alias :=== :==
|
120
120
|
|
121
|
+
# Return a string representation of the Int64 for use in
|
122
|
+
# application-level JSON serialization. This method is intentionally
|
123
|
+
# different from #as_extended_json.
|
124
|
+
#
|
125
|
+
# @example Get the Int64 as a JSON-serializable object.
|
126
|
+
# int64.as_json
|
127
|
+
#
|
128
|
+
# @return [ Integer ] The Int64 as an Integer.
|
129
|
+
def as_json(**options)
|
130
|
+
value
|
131
|
+
end
|
132
|
+
|
121
133
|
# Converts this object to a representation directly serializable to
|
122
134
|
# Extended JSON (https://github.com/mongodb/specifications/blob/master/source/extended-json.rst).
|
123
135
|
#
|
data/lib/bson/integer.rb
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
# rubocop:todo all
|
2
3
|
# Copyright (C) 2009-2020 MongoDB Inc.
|
3
4
|
#
|
4
5
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
@@ -104,7 +105,7 @@ module BSON
|
|
104
105
|
# @see http://bsonspec.org/#/specification
|
105
106
|
#
|
106
107
|
# @since 2.0.0
|
107
|
-
def to_bson(buffer = ByteBuffer.new
|
108
|
+
def to_bson(buffer = ByteBuffer.new)
|
108
109
|
if bson_int32?
|
109
110
|
buffer.put_int32(self)
|
110
111
|
elsif bson_int64?
|
@@ -151,12 +152,10 @@ module BSON
|
|
151
152
|
# @example Convert the integer to a BSON key string.
|
152
153
|
# 1.to_bson_key
|
153
154
|
#
|
154
|
-
# @param [ true, false ] validating_keys If BSON should validate the key.
|
155
|
-
#
|
156
155
|
# @return [ String ] The string key.
|
157
156
|
#
|
158
157
|
# @since 2.0.0
|
159
|
-
def to_bson_key
|
158
|
+
def to_bson_key
|
160
159
|
self
|
161
160
|
end
|
162
161
|
|
data/lib/bson/json.rb
CHANGED
data/lib/bson/max_key.rb
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
# rubocop:todo all
|
2
3
|
# Copyright (C) 2009-2020 MongoDB Inc.
|
3
4
|
#
|
4
5
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
@@ -51,16 +52,13 @@ module BSON
|
|
51
52
|
GREATER
|
52
53
|
end
|
53
54
|
|
54
|
-
#
|
55
|
+
# Return a representation of the object for use in
|
56
|
+
# application-level JSON serialization. Since BSON::MaxKey
|
57
|
+
# is used exclusively in BSON-related contexts, this
|
58
|
+
# method returns the canonical Extended JSON representation.
|
55
59
|
#
|
56
|
-
# @
|
57
|
-
|
58
|
-
#
|
59
|
-
# @return [ Hash ] The max key as a JSON hash.
|
60
|
-
#
|
61
|
-
# @since 2.0.0
|
62
|
-
# @deprecated Use as_extended_json instead.
|
63
|
-
def as_json(*args)
|
60
|
+
# @return [ Hash ] The extended json representation.
|
61
|
+
def as_json(*_args)
|
64
62
|
as_extended_json
|
65
63
|
end
|
66
64
|
|
data/lib/bson/min_key.rb
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
# rubocop:todo all
|
2
3
|
# Copyright (C) 2009-2020 MongoDB Inc.
|
3
4
|
#
|
4
5
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
@@ -51,16 +52,13 @@ module BSON
|
|
51
52
|
LESSER
|
52
53
|
end
|
53
54
|
|
54
|
-
#
|
55
|
+
# Return a representation of the object for use in
|
56
|
+
# application-level JSON serialization. Since BSON::MinKey
|
57
|
+
# is used exclusively in BSON-related contexts, this
|
58
|
+
# method returns the canonical Extended JSON representation.
|
55
59
|
#
|
56
|
-
# @
|
57
|
-
|
58
|
-
#
|
59
|
-
# @return [ Hash ] The min key as a JSON hash.
|
60
|
-
#
|
61
|
-
# @since 2.0.0
|
62
|
-
# @deprecated Use as_extended_json instead.
|
63
|
-
def as_json(*args)
|
60
|
+
# @return [ Hash ] The extended json representation.
|
61
|
+
def as_json(*_args)
|
64
62
|
as_extended_json
|
65
63
|
end
|
66
64
|
|
data/lib/bson/nil_class.rb
CHANGED
data/lib/bson/object.rb
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
# rubocop:todo all
|
2
3
|
# Copyright (C) 2009-2020 MongoDB Inc.
|
3
4
|
#
|
4
5
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
@@ -27,13 +28,13 @@ module BSON
|
|
27
28
|
# @example Convert the object to a BSON key.
|
28
29
|
# object.to_bson_key
|
29
30
|
#
|
30
|
-
# @raise [ InvalidKey ] Always raises an exception.
|
31
|
+
# @raise [ BSON::Error::InvalidKey ] Always raises an exception.
|
31
32
|
#
|
32
33
|
# @see http://bsonspec.org/#/specification
|
33
34
|
#
|
34
35
|
# @since 2.2.4
|
35
|
-
def to_bson_key
|
36
|
-
raise InvalidKey.new(self)
|
36
|
+
def to_bson_key
|
37
|
+
raise Error::InvalidKey.new(self)
|
37
38
|
end
|
38
39
|
|
39
40
|
# Converts the object to a normalized key in a BSON document.
|
@@ -79,33 +80,12 @@ module BSON
|
|
79
80
|
# Subclasses should override this method to provide custom serialization
|
80
81
|
# to Extended JSON.
|
81
82
|
#
|
82
|
-
# @option options [ true | false ] :relaxed Whether to produce relaxed
|
83
|
-
# extended JSON representation.
|
84
|
-
#
|
85
83
|
# @return [ Object ] The extended json representation.
|
86
|
-
def as_extended_json(**
|
84
|
+
def as_extended_json(**_options)
|
87
85
|
self
|
88
86
|
end
|
89
87
|
end
|
90
88
|
|
91
|
-
# Raised when trying to serialize an object into a key.
|
92
|
-
#
|
93
|
-
# @since 2.2.4
|
94
|
-
class InvalidKey < RuntimeError
|
95
|
-
|
96
|
-
# Instantiate the exception.
|
97
|
-
#
|
98
|
-
# @example Instantiate the exception.
|
99
|
-
# BSON::Object::InvalidKey.new(object)
|
100
|
-
#
|
101
|
-
# @param [ Object ] object The object that was meant for the key.
|
102
|
-
#
|
103
|
-
# @since 2.2.4
|
104
|
-
def initialize(object)
|
105
|
-
super("#{object.class} instances are not allowed as keys in a BSON document.")
|
106
|
-
end
|
107
|
-
end
|
108
|
-
|
109
89
|
# Enrich the core Object class with this module.
|
110
90
|
#
|
111
91
|
# @since 2.2.4
|