mongo 2.1.0.beta → 2.1.0.rc0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (253) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +0 -0
  3. data.tar.gz.sig +0 -0
  4. data/Rakefile +2 -2
  5. data/lib/mongo.rb +2 -3
  6. data/lib/mongo/address.rb +7 -5
  7. data/lib/mongo/address/unix.rb +2 -2
  8. data/lib/mongo/auth/ldap/conversation.rb +6 -2
  9. data/lib/mongo/auth/scram/conversation.rb +8 -2
  10. data/lib/mongo/auth/user/view.rb +21 -0
  11. data/lib/mongo/bulk_write.rb +155 -23
  12. data/lib/mongo/bulk_write/combineable.rb +51 -0
  13. data/lib/mongo/bulk_write/ordered_combiner.rb +55 -0
  14. data/lib/mongo/bulk_write/result.rb +61 -8
  15. data/lib/mongo/bulk_write/result_combiner.rb +117 -0
  16. data/lib/mongo/bulk_write/transformable.rb +117 -0
  17. data/lib/mongo/bulk_write/unordered_combiner.rb +52 -0
  18. data/lib/mongo/bulk_write/validatable.rb +62 -0
  19. data/lib/mongo/client.rb +7 -3
  20. data/lib/mongo/cluster.rb +3 -3
  21. data/lib/mongo/cluster/topology/replica_set.rb +8 -6
  22. data/lib/mongo/cluster/topology/unknown.rb +5 -2
  23. data/lib/mongo/collection.rb +75 -4
  24. data/lib/mongo/collection/view.rb +1 -2
  25. data/lib/mongo/collection/view/aggregation.rb +13 -8
  26. data/lib/mongo/collection/view/immutable.rb +6 -6
  27. data/lib/mongo/collection/view/iterable.rb +13 -4
  28. data/lib/mongo/collection/view/map_reduce.rb +22 -17
  29. data/lib/mongo/collection/view/readable.rb +121 -70
  30. data/lib/mongo/cursor.rb +5 -1
  31. data/lib/mongo/database.rb +3 -3
  32. data/lib/mongo/database/view.rb +1 -1
  33. data/lib/mongo/error.rb +7 -0
  34. data/lib/mongo/{bulk_write/unordered_bulk_write.rb → error/closed_stream.rb} +12 -21
  35. data/lib/mongo/{bulk_write/ordered_bulk_write.rb → error/extra_file_chunk.rb} +13 -27
  36. data/lib/mongo/error/file_not_found.rb +37 -0
  37. data/lib/mongo/error/invalid_file.rb +2 -2
  38. data/lib/mongo/error/invalid_file_revision.rb +37 -0
  39. data/lib/mongo/error/invalid_uri.rb +5 -4
  40. data/lib/mongo/error/missing_file_chunk.rb +38 -0
  41. data/lib/mongo/error/operation_failure.rb +1 -1
  42. data/lib/mongo/error/unchangeable_collection_option.rb +38 -0
  43. data/lib/mongo/error/unexpected_chunk_length.rb +39 -0
  44. data/lib/mongo/grid.rb +2 -1
  45. data/lib/mongo/grid/file.rb +12 -9
  46. data/lib/mongo/grid/file/chunk.rb +6 -6
  47. data/lib/mongo/grid/file/{metadata.rb → info.rb} +41 -39
  48. data/lib/mongo/grid/fs_bucket.rb +441 -0
  49. data/lib/mongo/grid/stream.rb +64 -0
  50. data/lib/mongo/grid/stream/read.rb +208 -0
  51. data/lib/mongo/grid/stream/write.rb +187 -0
  52. data/lib/mongo/index/view.rb +1 -1
  53. data/lib/mongo/loggable.rb +34 -57
  54. data/lib/mongo/logger.rb +16 -78
  55. data/lib/mongo/monitoring.rb +1 -5
  56. data/lib/mongo/monitoring/command_log_subscriber.rb +35 -17
  57. data/lib/mongo/monitoring/event/command_succeeded.rb +20 -1
  58. data/lib/mongo/monitoring/publishable.rb +22 -12
  59. data/lib/mongo/operation.rb +3 -6
  60. data/lib/mongo/operation/commands.rb +24 -0
  61. data/lib/mongo/operation/{aggregate.rb → commands/aggregate.rb} +3 -41
  62. data/lib/mongo/operation/{aggregate → commands/aggregate}/result.rb +0 -0
  63. data/lib/mongo/operation/commands/collections_info.rb +66 -0
  64. data/lib/mongo/operation/{command.rb → commands/command.rb} +2 -18
  65. data/lib/mongo/operation/commands/indexes.rb +70 -0
  66. data/lib/mongo/operation/commands/list_collections.rb +54 -0
  67. data/lib/mongo/operation/commands/list_collections/result.rb +112 -0
  68. data/lib/mongo/operation/commands/list_indexes.rb +56 -0
  69. data/lib/mongo/operation/commands/list_indexes/result.rb +115 -0
  70. data/lib/mongo/operation/{map_reduce.rb → commands/map_reduce.rb} +3 -41
  71. data/lib/mongo/operation/{map_reduce → commands/map_reduce}/result.rb +0 -0
  72. data/lib/mongo/operation/{parallel_scan.rb → commands/parallel_scan.rb} +3 -23
  73. data/lib/mongo/operation/{parallel_scan → commands/parallel_scan}/result.rb +0 -0
  74. data/lib/mongo/operation/commands/user_query.rb +69 -0
  75. data/lib/mongo/operation/commands/users_info.rb +53 -0
  76. data/lib/mongo/operation/commands/users_info/result.rb +36 -0
  77. data/lib/mongo/operation/executable.rb +4 -68
  78. data/lib/mongo/operation/kill_cursors.rb +3 -3
  79. data/lib/mongo/operation/read.rb +0 -4
  80. data/lib/mongo/operation/read/get_more.rb +2 -22
  81. data/lib/mongo/operation/read/query.rb +2 -21
  82. data/lib/mongo/operation/{read_preferrable.rb → read_preference.rb} +3 -2
  83. data/lib/mongo/operation/specifiable.rb +24 -0
  84. data/lib/mongo/operation/write.rb +2 -0
  85. data/lib/mongo/operation/write/bulk.rb +6 -3
  86. data/lib/mongo/operation/write/bulk/bulkable.rb +82 -0
  87. data/lib/mongo/operation/write/bulk/delete.rb +71 -0
  88. data/lib/mongo/operation/write/bulk/delete/result.rb +74 -0
  89. data/lib/mongo/operation/write/bulk/insert.rb +96 -0
  90. data/lib/mongo/operation/write/bulk/insert/result.rb +129 -0
  91. data/lib/mongo/operation/write/bulk/legacy_mergable.rb +87 -0
  92. data/lib/mongo/operation/write/bulk/mergable.rb +71 -0
  93. data/lib/mongo/operation/write/bulk/update.rb +81 -0
  94. data/lib/mongo/operation/write/bulk/update/result.rb +174 -0
  95. data/lib/mongo/operation/write/command/create_index.rb +0 -1
  96. data/lib/mongo/operation/write/command/create_user.rb +0 -1
  97. data/lib/mongo/operation/write/command/delete.rb +0 -1
  98. data/lib/mongo/operation/write/command/drop_index.rb +0 -1
  99. data/lib/mongo/operation/write/command/insert.rb +0 -1
  100. data/lib/mongo/operation/write/command/remove_user.rb +0 -1
  101. data/lib/mongo/operation/write/command/update.rb +0 -1
  102. data/lib/mongo/operation/write/command/update_user.rb +0 -1
  103. data/lib/mongo/operation/write/command/writable.rb +13 -18
  104. data/lib/mongo/operation/write/create_index.rb +4 -27
  105. data/lib/mongo/operation/write/create_user.rb +4 -30
  106. data/lib/mongo/operation/write/delete.rb +5 -28
  107. data/lib/mongo/operation/write/drop_index.rb +3 -3
  108. data/lib/mongo/operation/write/gle.rb +48 -0
  109. data/lib/mongo/operation/write/idable.rb +5 -0
  110. data/lib/mongo/operation/write/insert.rb +2 -24
  111. data/lib/mongo/operation/write/remove_user.rb +4 -27
  112. data/lib/mongo/operation/write/update.rb +4 -32
  113. data/lib/mongo/operation/write/update_user.rb +4 -30
  114. data/lib/mongo/operation/write/write_command_enabled.rb +53 -0
  115. data/lib/mongo/options/mapper.rb +4 -2
  116. data/lib/mongo/protocol/delete.rb +68 -3
  117. data/lib/mongo/protocol/get_more.rb +54 -2
  118. data/lib/mongo/protocol/insert.rb +59 -1
  119. data/lib/mongo/protocol/kill_cursors.rb +53 -4
  120. data/lib/mongo/protocol/message.rb +12 -12
  121. data/lib/mongo/protocol/query.rb +139 -65
  122. data/lib/mongo/protocol/reply.rb +69 -1
  123. data/lib/mongo/protocol/update.rb +70 -1
  124. data/lib/mongo/server/connection.rb +11 -3
  125. data/lib/mongo/server/description.rb +29 -0
  126. data/lib/mongo/server/description/features.rb +2 -1
  127. data/lib/mongo/server/monitor.rb +2 -2
  128. data/lib/mongo/server_selector.rb +14 -10
  129. data/lib/mongo/server_selector/selectable.rb +24 -22
  130. data/lib/mongo/socket.rb +6 -3
  131. data/lib/mongo/socket/tcp.rb +2 -2
  132. data/lib/mongo/socket/unix.rb +5 -8
  133. data/lib/mongo/uri.rb +243 -139
  134. data/lib/mongo/version.rb +1 -1
  135. data/spec/mongo/address/unix_spec.rb +1 -1
  136. data/spec/mongo/address_spec.rb +25 -0
  137. data/spec/mongo/auth/ldap/conversation_spec.rb +43 -0
  138. data/spec/mongo/auth/user/view_spec.rb +26 -1
  139. data/spec/mongo/bulk_write/ordered_combiner_spec.rb +271 -0
  140. data/spec/mongo/bulk_write/unordered_combiner_spec.rb +239 -0
  141. data/spec/mongo/bulk_write_spec.rb +332 -166
  142. data/spec/mongo/client_spec.rb +25 -0
  143. data/spec/mongo/cluster/topology/replica_set_spec.rb +2 -0
  144. data/spec/mongo/collection/view/aggregation_spec.rb +65 -0
  145. data/spec/mongo/collection/view/immutable_spec.rb +103 -0
  146. data/spec/mongo/collection/view/map_reduce_spec.rb +98 -3
  147. data/spec/mongo/collection/view/readable_spec.rb +17 -30
  148. data/spec/mongo/collection/view_spec.rb +233 -7
  149. data/spec/mongo/collection_spec.rb +360 -18
  150. data/spec/mongo/command_monitoring_spec.rb +51 -0
  151. data/spec/mongo/connection_string_spec.rb +137 -0
  152. data/spec/mongo/database_spec.rb +27 -11
  153. data/spec/mongo/grid/file/chunk_spec.rb +5 -5
  154. data/spec/mongo/grid/file/{metadata_spec.rb → info_spec.rb} +29 -17
  155. data/spec/mongo/grid/file_spec.rb +8 -8
  156. data/spec/mongo/grid/fs_bucket_spec.rb +1020 -0
  157. data/spec/mongo/grid/stream/read_spec.rb +275 -0
  158. data/spec/mongo/grid/stream/write_spec.rb +440 -0
  159. data/spec/mongo/grid/stream_spec.rb +48 -0
  160. data/spec/mongo/gridfs_spec.rb +50 -0
  161. data/spec/mongo/logger_spec.rb +0 -40
  162. data/spec/mongo/monitoring/command_log_subscriber_spec.rb +76 -0
  163. data/spec/mongo/operation/{aggregate_spec.rb → commands/aggregate_spec.rb} +0 -42
  164. data/spec/mongo/operation/{read → commands}/collections_info_spec.rb +1 -1
  165. data/spec/mongo/operation/{command_spec.rb → commands/command_spec.rb} +0 -0
  166. data/spec/mongo/operation/{read → commands}/indexes_spec.rb +1 -1
  167. data/spec/mongo/operation/{map_reduce_spec.rb → commands/map_reduce_spec.rb} +0 -18
  168. data/spec/mongo/operation/kill_cursors_spec.rb +1 -1
  169. data/spec/mongo/operation/{read_preferrable_spec.rb → read_preference_spec.rb} +11 -11
  170. data/spec/mongo/operation/write/bulk/{bulk_delete_spec.rb → delete_spec.rb} +1 -12
  171. data/spec/mongo/operation/write/bulk/{bulk_insert_spec.rb → insert_spec.rb} +1 -12
  172. data/spec/mongo/operation/write/bulk/{bulk_update_spec.rb → update_spec.rb} +1 -12
  173. data/spec/mongo/operation/write/insert_spec.rb +0 -11
  174. data/spec/mongo/protocol/kill_cursors_spec.rb +5 -3
  175. data/spec/mongo/server/description_spec.rb +42 -0
  176. data/spec/mongo/server/monitor_spec.rb +21 -0
  177. data/spec/mongo/server_discovery_and_monitoring_spec.rb +1 -0
  178. data/spec/mongo/server_selection_spec.rb +3 -3
  179. data/spec/mongo/server_selector/nearest_spec.rb +34 -27
  180. data/spec/mongo/server_selector/primary_preferred_spec.rb +31 -30
  181. data/spec/mongo/server_selector/primary_spec.rb +14 -13
  182. data/spec/mongo/server_selector/secondary_preferred_spec.rb +27 -26
  183. data/spec/mongo/server_selector/secondary_spec.rb +23 -22
  184. data/spec/mongo/server_selector_spec.rb +87 -24
  185. data/spec/mongo/socket/unix_spec.rb +52 -0
  186. data/spec/mongo/uri_spec.rb +251 -39
  187. data/spec/spec_helper.rb +11 -4
  188. data/spec/support/authorization.rb +4 -5
  189. data/spec/support/command_monitoring.rb +365 -0
  190. data/spec/support/command_monitoring/bulkWrite.yml +73 -0
  191. data/spec/support/command_monitoring/command.yml +42 -0
  192. data/spec/support/command_monitoring/deleteMany.yml +55 -0
  193. data/spec/support/command_monitoring/deleteOne.yml +55 -0
  194. data/spec/support/command_monitoring/find.yml +219 -0
  195. data/spec/support/command_monitoring/insertMany.yml +81 -0
  196. data/spec/support/command_monitoring/insertOne.yml +51 -0
  197. data/spec/support/command_monitoring/updateMany.yml +67 -0
  198. data/spec/support/command_monitoring/updateOne.yml +95 -0
  199. data/spec/support/connection_string.rb +228 -0
  200. data/spec/support/connection_string_tests/invalid-uris.yml +193 -0
  201. data/spec/support/connection_string_tests/valid-auth.yml +256 -0
  202. data/spec/support/connection_string_tests/valid-host_identifiers.yml +121 -0
  203. data/spec/support/connection_string_tests/valid-options.yml +30 -0
  204. data/spec/support/connection_string_tests/valid-unix_socket-absolute.yml +197 -0
  205. data/spec/support/connection_string_tests/valid-unix_socket-relative.yml +213 -0
  206. data/spec/support/connection_string_tests/valid-warnings.yml +55 -0
  207. data/spec/support/crud.rb +3 -1
  208. data/spec/support/crud/read.rb +14 -10
  209. data/spec/support/crud/write.rb +36 -9
  210. data/spec/support/gridfs.rb +637 -0
  211. data/spec/support/gridfs_tests/delete.yml +157 -0
  212. data/spec/support/gridfs_tests/download.yml +210 -0
  213. data/spec/support/gridfs_tests/download_by_name.yml +113 -0
  214. data/spec/support/gridfs_tests/upload.yml +158 -0
  215. data/spec/support/sdam/rs/equal_electionids.yml +1 -2
  216. data/spec/support/sdam/rs/new_primary_new_electionid.yml +0 -3
  217. data/spec/support/sdam/rs/primary_mismatched_me.yml +37 -0
  218. data/spec/support/sdam/rs/primary_to_no_primary_mismatched_me.yml +75 -0
  219. data/spec/support/sdam/rs/secondary_mismatched_me.yml +37 -0
  220. data/spec/support/sdam/single/direct_connection_rsarbiter.yml +1 -1
  221. data/spec/support/sdam/single/direct_connection_rsprimary.yml +1 -1
  222. data/spec/support/sdam/single/direct_connection_rssecondary.yml +1 -1
  223. data/spec/support/sdam/single/direct_connection_slave.yml +1 -1
  224. data/spec/support/sdam/single/direct_connection_standalone.yml +1 -1
  225. data/spec/support/sdam/single/not_ok_response.yml +0 -1
  226. data/spec/support/server_discovery_and_monitoring.rb +3 -1
  227. data/spec/support/server_selection.rb +3 -1
  228. data/spec/support/shared/bulk_write.rb +192 -0
  229. data/spec/support/shared/server_selector.rb +21 -12
  230. metadata +147 -57
  231. metadata.gz.sig +0 -0
  232. data/lib/mongo/bulk_write/bulk_writable.rb +0 -252
  233. data/lib/mongo/bulk_write/deletable.rb +0 -57
  234. data/lib/mongo/bulk_write/insertable.rb +0 -49
  235. data/lib/mongo/bulk_write/replacable.rb +0 -58
  236. data/lib/mongo/bulk_write/updatable.rb +0 -69
  237. data/lib/mongo/grid/fs.rb +0 -146
  238. data/lib/mongo/operation/list_collections/result.rb +0 -114
  239. data/lib/mongo/operation/list_indexes/result.rb +0 -118
  240. data/lib/mongo/operation/read/collections_info.rb +0 -68
  241. data/lib/mongo/operation/read/indexes.rb +0 -69
  242. data/lib/mongo/operation/read/list_collections.rb +0 -76
  243. data/lib/mongo/operation/read/list_indexes.rb +0 -78
  244. data/lib/mongo/operation/write/bulk/bulk_delete.rb +0 -145
  245. data/lib/mongo/operation/write/bulk/bulk_delete/result.rb +0 -75
  246. data/lib/mongo/operation/write/bulk/bulk_insert.rb +0 -132
  247. data/lib/mongo/operation/write/bulk/bulk_insert/result.rb +0 -130
  248. data/lib/mongo/operation/write/bulk/bulk_mergable.rb +0 -67
  249. data/lib/mongo/operation/write/bulk/bulk_update.rb +0 -154
  250. data/lib/mongo/operation/write/bulk/bulk_update/result.rb +0 -174
  251. data/lib/mongo/operation/write/bulk/legacy_bulk_mergable.rb +0 -83
  252. data/spec/mongo/grid/fs_spec.rb +0 -160
  253. data/spec/mongo/loggable_spec.rb +0 -63
@@ -0,0 +1,129 @@
1
+ # Copyright (C) 2014-2015 MongoDB, Inc.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+
15
+ module Mongo
16
+ module Operation
17
+ module Write
18
+ module Bulk
19
+ class Insert
20
+
21
+ # Defines custom behaviour of results when inserting.
22
+ #
23
+ # @since 2.0.0
24
+ class Result < Operation::Result
25
+ include Mergable
26
+
27
+ # Get the ids of the inserted documents.
28
+ #
29
+ # @since 2.0.0
30
+ attr_reader :inserted_ids
31
+
32
+ # Initialize a new result.
33
+ #
34
+ # @example Instantiate the result.
35
+ # Result.new(replies, inserted_ids)
36
+ #
37
+ # @param [ Protocol::Reply ] replies The wire protocol replies.
38
+ # @param [ Array<Object> ] ids The ids of the inserted documents.
39
+ #
40
+ # @since 2.0.0
41
+ def initialize(replies, ids)
42
+ @replies = replies.is_a?(Protocol::Reply) ? [ replies ] : replies
43
+ @inserted_ids = ids
44
+ end
45
+
46
+ # Gets the number of documents inserted.
47
+ #
48
+ # @example Get the number of documents inserted.
49
+ # result.n_inserted
50
+ #
51
+ # @return [ Integer ] The number of documents inserted.
52
+ #
53
+ # @since 2.0.0
54
+ def n_inserted
55
+ written_count
56
+ end
57
+
58
+ # Gets the id of the document inserted.
59
+ #
60
+ # @example Get id of the document inserted.
61
+ # result.inserted_id
62
+ #
63
+ # @return [ Object ] The id of the document inserted.
64
+ #
65
+ # @since 2.0.0
66
+ def inserted_id
67
+ inserted_ids.first
68
+ end
69
+ end
70
+
71
+ # Defines custom behaviour of results when inserting.
72
+ # For server versions < 2.5.5 (that don't use write commands).
73
+ #
74
+ # @since 2.0.0
75
+ class LegacyResult < Operation::Result
76
+ include LegacyMergable
77
+
78
+ # Get the ids of the inserted documents.
79
+ #
80
+ # @since 2.0.0
81
+ attr_reader :inserted_ids
82
+
83
+ # Initialize a new result.
84
+ #
85
+ # @example Instantiate the result.
86
+ # Result.new(replies, inserted_ids)
87
+ #
88
+ # @param [ Protocol::Reply ] replies The wire protocol replies.
89
+ # @param [ Array<Object> ] ids The ids of the inserted documents.
90
+ #
91
+ # @since 2.0.0
92
+ def initialize(replies, ids)
93
+ @replies = replies.is_a?(Protocol::Reply) ? [ replies ] : replies
94
+ @inserted_ids = ids
95
+ end
96
+
97
+ # Gets the number of documents inserted.
98
+ #
99
+ # @example Get the number of documents inserted.
100
+ # result.n_inserted
101
+ #
102
+ # @return [ Integer ] The number of documents inserted.
103
+ #
104
+ # @since 2.0.0
105
+ def n_inserted
106
+ return 0 unless acknowledged?
107
+ @replies.reduce(0) do |n, reply|
108
+ n += 1 unless reply_write_errors?(reply)
109
+ n
110
+ end
111
+ end
112
+
113
+ # Gets the id of the document inserted.
114
+ #
115
+ # @example Get id of the document inserted.
116
+ # result.inserted_id
117
+ #
118
+ # @return [ Object ] The id of the document inserted.
119
+ #
120
+ # @since 2.0.0
121
+ def inserted_id
122
+ inserted_ids.first
123
+ end
124
+ end
125
+ end
126
+ end
127
+ end
128
+ end
129
+ end
@@ -0,0 +1,87 @@
1
+ # Copyright (C) 2014-2015 MongoDB, Inc.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+
15
+ module Mongo
16
+ module Operation
17
+ module Write
18
+ module Bulk
19
+
20
+ # This module contains common functionality for merging results from
21
+ # writes during a bulk operation. Used for server versions < 2.6.
22
+ #
23
+ # @since 2.0.0
24
+ module LegacyMergable
25
+
26
+ # Aggregate the write errors returned from this result.
27
+ #
28
+ # @example Aggregate the write errors.
29
+ # result.aggregate_write_errors(0)
30
+ #
31
+ # @param [ Integer ] count The number of documents already executed.
32
+ #
33
+ # @return [ Array ] The aggregate write errors.
34
+ #
35
+ # @since 2.0.0
36
+ def aggregate_write_errors(count)
37
+ @replies.each_with_index.reduce(nil) do |errors, (reply, i)|
38
+ if reply_write_errors?(reply)
39
+ errors ||= []
40
+ errors << { 'errmsg' => reply.documents.first[Error::ERROR],
41
+ 'index' => count + i,
42
+ 'code' => reply.documents.first[Error::CODE] }
43
+ end
44
+ errors
45
+ end
46
+ end
47
+
48
+ # Aggregate the write concern errors returned from this result.
49
+ #
50
+ # @example Aggregate the write concern errors.
51
+ # result.aggregate_write_concern_errors(4)
52
+ #
53
+ # @param [ Integer ] count The number of documents already executed.
54
+ #
55
+ # @return [ Array ] The aggregate write concern errors.
56
+ #
57
+ # @since 2.0.0
58
+ def aggregate_write_concern_errors(count)
59
+ @replies.each_with_index.reduce(nil) do |errors, (reply, i)|
60
+ if error = reply_write_errors?(reply)
61
+ errors ||= []
62
+ if note = reply.documents.first['wnote'] || reply.documents.first['jnote']
63
+ code = reply.documents.first['code'] || Error::BAD_VALUE
64
+ error_string = "#{code}: #{note}"
65
+ elsif error == 'timeout'
66
+ code = reply.documents.first['code'] || Error::UNKNOWN_ERROR
67
+ error_string = "#{code}: #{error}"
68
+ end
69
+ errors << { 'errmsg' => error_string,
70
+ 'index' => count + i,
71
+ 'code' => code } if error_string
72
+ end
73
+ errors
74
+ end
75
+ end
76
+
77
+ private
78
+
79
+ def reply_write_errors?(reply)
80
+ reply.documents.first[Error::ERROR] ||
81
+ reply.documents.first[Error::ERRMSG]
82
+ end
83
+ end
84
+ end
85
+ end
86
+ end
87
+ end
@@ -0,0 +1,71 @@
1
+ # Copyright (C) 2014-2015 MongoDB, Inc.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+
15
+ module Mongo
16
+ module Operation
17
+ module Write
18
+ module Bulk
19
+
20
+ # This module contains common functionality for merging results from
21
+ # write commands during a bulk operation. Used for server versions >= 2.6.
22
+ #
23
+ # @since 2.0.0
24
+ module Mergable
25
+
26
+ # Aggregate the write errors returned from this result.
27
+ #
28
+ # @example Aggregate the write errors.
29
+ # result.aggregate_write_errors(0)
30
+ #
31
+ # @param [ Integer ] count The number of documents already executed.
32
+ #
33
+ # @return [ Array ] The aggregate write errors.
34
+ #
35
+ # @since 2.0.0
36
+ def aggregate_write_errors(count)
37
+ @replies.reduce(nil) do |errors, reply|
38
+ if write_errors = reply.documents.first[Error::WRITE_ERRORS]
39
+ wes = write_errors.collect do |we|
40
+ we.merge!('index' => count + we['index'])
41
+ end
42
+ (errors || []) << wes if wes
43
+ end
44
+ end
45
+ end
46
+
47
+ # Aggregate the write concern errors returned from this result.
48
+ #
49
+ # @example Aggregate the write concern errors.
50
+ # result.aggregate_write_concern_errors(100)
51
+ #
52
+ # @param [ Integer ] count The number of documents already executed.
53
+ #
54
+ # @return [ Array ] The aggregate write concern errors.
55
+ #
56
+ # @since 2.0.0
57
+ def aggregate_write_concern_errors(count)
58
+ @replies.each_with_index.reduce(nil) do |errors, (reply, i)|
59
+ if write_concern_errors = reply.documents.first[Error::WRITE_CONCERN_ERRORS]
60
+ (errors || []) << write_concern_errors.reduce(nil) do |errs, wce|
61
+ wce.merge!('index' => count + wce['index'])
62
+ (errs || []) << write_concern_error
63
+ end
64
+ end
65
+ end
66
+ end
67
+ end
68
+ end
69
+ end
70
+ end
71
+ end
@@ -0,0 +1,81 @@
1
+ # Copyright (C) 2014-2015 MongoDB, Inc.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+
15
+ require 'mongo/operation/write/bulk/update/result'
16
+
17
+ module Mongo
18
+ module Operation
19
+ module Write
20
+ module Bulk
21
+
22
+ # A MongoDB bulk update operation.
23
+ #
24
+ # @note If the server version is >= 2.5.5, a write command operation
25
+ # will be created and sent instead.
26
+ #
27
+ # @example Create the update operation.
28
+ # Write::BulkUpdate.new({
29
+ # :updates => [
30
+ # {
31
+ # :q => { :foo => 1 },
32
+ # :u => { :$set => { :bar => 1 }},
33
+ # :multi => true,
34
+ # :upsert => false
35
+ # }
36
+ # ],
37
+ # :db_name => 'test',
38
+ # :coll_name => 'test_coll',
39
+ # :write_concern => write_concern,
40
+ # :ordered => false
41
+ # })
42
+ #
43
+ # Initialization:
44
+ # param [ Hash ] spec The specifications for the update.
45
+ #
46
+ # option spec :updates [ Array ] The update documents.
47
+ # option spec :db_name [ String ] The name of the database on which
48
+ # the query should be run.
49
+ # option spec :coll_name [ String ] The name of the collection on which
50
+ # the query should be run.
51
+ # option spec :write_concern [ Mongo::WriteConcern ] The write concern.
52
+ # option spec :ordered [ true, false ] Whether the operations should be
53
+ # executed in order.
54
+ # option spec :options [ Hash ] Options for the command, if it ends up being a
55
+ # write command.
56
+ #
57
+ # @since 2.0.0
58
+ class Update
59
+ include Bulkable
60
+ include Specifiable
61
+
62
+ private
63
+
64
+ def execute_write_command(context)
65
+ Result.new(Command::Update.new(spec).execute(context))
66
+ end
67
+
68
+
69
+ def messages
70
+ updates.collect do |u|
71
+ opts = { :flags => [] }
72
+ opts[:flags] << :multi_update if !!u[:multi]
73
+ opts[:flags] << :upsert if !!u[:upsert]
74
+ Protocol::Update.new(db_name, coll_name, u[:q], u[:u], opts)
75
+ end
76
+ end
77
+ end
78
+ end
79
+ end
80
+ end
81
+ end
@@ -0,0 +1,174 @@
1
+ # Copyright (C) 2014-2015 MongoDB, Inc.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+
15
+ module Mongo
16
+ module Operation
17
+ module Write
18
+ module Bulk
19
+ class Update
20
+
21
+ # Defines custom behaviour of results when updating.
22
+ #
23
+ # @since 2.0.0
24
+ class Result < Operation::Result
25
+ include Mergable
26
+
27
+ # The number of modified docs field in the result.
28
+ #
29
+ # @since 2.0.0
30
+ MODIFIED = 'nModified'.freeze
31
+
32
+ # The upserted docs field in the result.
33
+ #
34
+ # @since 2.0.0
35
+ UPSERTED = 'upserted'.freeze
36
+
37
+ # Gets the number of documents upserted.
38
+ #
39
+ # @example Get the upserted count.
40
+ # result.n_upserted
41
+ #
42
+ # @return [ Integer ] The number of documents upserted.
43
+ #
44
+ # @since 2.0.0
45
+ def n_upserted
46
+ return 0 unless acknowledged?
47
+ @replies.reduce(0) do |n, reply|
48
+ if upsert?(reply)
49
+ n += 1
50
+ else
51
+ n += 0
52
+ end
53
+ end
54
+ end
55
+
56
+ # Gets the number of documents matched.
57
+ #
58
+ # @example Get the matched count.
59
+ # result.n_matched
60
+ #
61
+ # @return [ Integer ] The number of documents matched.
62
+ #
63
+ # @since 2.0.0
64
+ def n_matched
65
+ return 0 unless acknowledged?
66
+ @replies.reduce(0) do |n, reply|
67
+ if upsert?(reply)
68
+ n += 0
69
+ else
70
+ n += reply.documents.first[N]
71
+ end
72
+ end
73
+ end
74
+
75
+ # Gets the number of documents modified.
76
+ #
77
+ # @example Get the modified count.
78
+ # result.n_modified
79
+ #
80
+ # @return [ Integer ] The number of documents modified.
81
+ #
82
+ # @since 2.0.0
83
+ def n_modified
84
+ return 0 unless acknowledged?
85
+ @replies.reduce(0) do |n, reply|
86
+ n += reply.documents.first[MODIFIED] || 0
87
+ end
88
+ end
89
+
90
+ # Get the upserted documents.
91
+ #
92
+ # @example Get upserted documents.
93
+ # result.upserted
94
+ #
95
+ # @return [ Array<BSON::Document> ] The upserted document info
96
+ #
97
+ # @since 2.1.0
98
+ def upserted
99
+ reply.documents.first[UPSERTED] || []
100
+ end
101
+
102
+ private
103
+
104
+ def upsert?(reply)
105
+ upserted.any?
106
+ end
107
+ end
108
+
109
+ # Defines custom behaviour of results when updating.
110
+ # For server versions < 2.5.5 (that don't use write commands).
111
+ #
112
+ # @since 2.0.0
113
+ class LegacyResult < Operation::Result
114
+ include LegacyMergable
115
+
116
+ # The updated existing field in the result.
117
+ #
118
+ # @since 2.0.0
119
+ UPDATED_EXISTING = 'updatedExisting'.freeze
120
+
121
+ # Gets the number of documents upserted.
122
+ #
123
+ # @example Get the upserted count.
124
+ # result.n_upserted
125
+ #
126
+ # @return [ Integer ] The number of documents upserted.
127
+ #
128
+ # @since 2.0.0
129
+ def n_upserted
130
+ return 0 unless acknowledged?
131
+ @replies.reduce(0) do |n, reply|
132
+ if upsert?(reply)
133
+ n += reply.documents.first[N]
134
+ else
135
+ n
136
+ end
137
+ end
138
+ end
139
+
140
+ # Gets the number of documents matched.
141
+ #
142
+ # @example Get the matched count.
143
+ # result.n_matched
144
+ #
145
+ # @return [ Integer ] The number of documents matched.
146
+ #
147
+ # @since 2.0.0
148
+ def n_matched
149
+ return 0 unless acknowledged?
150
+ @replies.reduce(0) do |n, reply|
151
+ if upsert?(reply)
152
+ n
153
+ else
154
+ n += reply.documents.first[N]
155
+ end
156
+ end
157
+ end
158
+ alias :n_modified :n_matched
159
+
160
+ private
161
+
162
+ def upsert?(reply)
163
+ !updated_existing?(reply) && reply.documents.first[N] == 1
164
+ end
165
+
166
+ def updated_existing?(reply)
167
+ reply.documents.first[UPDATED_EXISTING]
168
+ end
169
+ end
170
+ end
171
+ end
172
+ end
173
+ end
174
+ end