sequel 4.26.0 → 5.37.0

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 (692) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGELOG +405 -5656
  3. data/MIT-LICENSE +1 -1
  4. data/README.rdoc +232 -157
  5. data/bin/sequel +32 -9
  6. data/doc/advanced_associations.rdoc +252 -188
  7. data/doc/association_basics.rdoc +231 -273
  8. data/doc/bin_sequel.rdoc +5 -3
  9. data/doc/cheat_sheet.rdoc +75 -48
  10. data/doc/code_order.rdoc +28 -10
  11. data/doc/core_extensions.rdoc +104 -63
  12. data/doc/dataset_basics.rdoc +12 -21
  13. data/doc/dataset_filtering.rdoc +99 -86
  14. data/doc/extensions.rdoc +3 -10
  15. data/doc/mass_assignment.rdoc +74 -31
  16. data/doc/migration.rdoc +72 -46
  17. data/doc/model_dataset_method_design.rdoc +129 -0
  18. data/doc/model_hooks.rdoc +15 -25
  19. data/doc/model_plugins.rdoc +12 -12
  20. data/doc/mssql_stored_procedures.rdoc +3 -3
  21. data/doc/object_model.rdoc +59 -69
  22. data/doc/opening_databases.rdoc +84 -94
  23. data/doc/postgresql.rdoc +268 -38
  24. data/doc/prepared_statements.rdoc +29 -24
  25. data/doc/querying.rdoc +184 -164
  26. data/doc/reflection.rdoc +5 -6
  27. data/doc/release_notes/5.0.0.txt +159 -0
  28. data/doc/release_notes/5.1.0.txt +31 -0
  29. data/doc/release_notes/5.10.0.txt +84 -0
  30. data/doc/release_notes/5.11.0.txt +83 -0
  31. data/doc/release_notes/5.12.0.txt +141 -0
  32. data/doc/release_notes/5.13.0.txt +27 -0
  33. data/doc/release_notes/5.14.0.txt +63 -0
  34. data/doc/release_notes/5.15.0.txt +39 -0
  35. data/doc/release_notes/5.16.0.txt +110 -0
  36. data/doc/release_notes/5.17.0.txt +31 -0
  37. data/doc/release_notes/5.18.0.txt +69 -0
  38. data/doc/release_notes/5.19.0.txt +28 -0
  39. data/doc/release_notes/5.2.0.txt +33 -0
  40. data/doc/release_notes/5.20.0.txt +89 -0
  41. data/doc/release_notes/5.21.0.txt +87 -0
  42. data/doc/release_notes/5.22.0.txt +48 -0
  43. data/doc/release_notes/5.23.0.txt +56 -0
  44. data/doc/release_notes/5.24.0.txt +56 -0
  45. data/doc/release_notes/5.25.0.txt +32 -0
  46. data/doc/release_notes/5.26.0.txt +35 -0
  47. data/doc/release_notes/5.27.0.txt +21 -0
  48. data/doc/release_notes/5.28.0.txt +16 -0
  49. data/doc/release_notes/5.29.0.txt +22 -0
  50. data/doc/release_notes/5.3.0.txt +121 -0
  51. data/doc/release_notes/5.30.0.txt +20 -0
  52. data/doc/release_notes/5.31.0.txt +148 -0
  53. data/doc/release_notes/5.32.0.txt +46 -0
  54. data/doc/release_notes/5.33.0.txt +24 -0
  55. data/doc/release_notes/5.34.0.txt +40 -0
  56. data/doc/release_notes/5.35.0.txt +56 -0
  57. data/doc/release_notes/5.36.0.txt +60 -0
  58. data/doc/release_notes/5.37.0.txt +30 -0
  59. data/doc/release_notes/5.4.0.txt +80 -0
  60. data/doc/release_notes/5.5.0.txt +61 -0
  61. data/doc/release_notes/5.6.0.txt +31 -0
  62. data/doc/release_notes/5.7.0.txt +108 -0
  63. data/doc/release_notes/5.8.0.txt +170 -0
  64. data/doc/release_notes/5.9.0.txt +99 -0
  65. data/doc/schema_modification.rdoc +102 -77
  66. data/doc/security.rdoc +160 -87
  67. data/doc/sharding.rdoc +74 -47
  68. data/doc/sql.rdoc +135 -122
  69. data/doc/testing.rdoc +34 -18
  70. data/doc/thread_safety.rdoc +2 -4
  71. data/doc/transactions.rdoc +101 -19
  72. data/doc/validations.rdoc +64 -51
  73. data/doc/virtual_rows.rdoc +90 -109
  74. data/lib/sequel.rb +3 -1
  75. data/lib/sequel/adapters/ado.rb +154 -22
  76. data/lib/sequel/adapters/ado/access.rb +21 -21
  77. data/lib/sequel/adapters/ado/mssql.rb +8 -15
  78. data/lib/sequel/adapters/amalgalite.rb +17 -25
  79. data/lib/sequel/adapters/ibmdb.rb +52 -58
  80. data/lib/sequel/adapters/jdbc.rb +149 -127
  81. data/lib/sequel/adapters/jdbc/db2.rb +32 -40
  82. data/lib/sequel/adapters/jdbc/derby.rb +56 -58
  83. data/lib/sequel/adapters/jdbc/h2.rb +40 -30
  84. data/lib/sequel/adapters/jdbc/hsqldb.rb +22 -33
  85. data/lib/sequel/adapters/jdbc/jtds.rb +4 -10
  86. data/lib/sequel/adapters/jdbc/mssql.rb +6 -12
  87. data/lib/sequel/adapters/jdbc/mysql.rb +17 -18
  88. data/lib/sequel/adapters/jdbc/oracle.rb +25 -19
  89. data/lib/sequel/adapters/jdbc/postgresql.rb +90 -69
  90. data/lib/sequel/adapters/jdbc/sqlanywhere.rb +14 -24
  91. data/lib/sequel/adapters/jdbc/sqlite.rb +50 -12
  92. data/lib/sequel/adapters/jdbc/sqlserver.rb +36 -9
  93. data/lib/sequel/adapters/jdbc/transactions.rb +25 -39
  94. data/lib/sequel/adapters/mock.rb +104 -113
  95. data/lib/sequel/adapters/mysql.rb +42 -61
  96. data/lib/sequel/adapters/mysql2.rb +126 -35
  97. data/lib/sequel/adapters/odbc.rb +21 -28
  98. data/lib/sequel/adapters/odbc/db2.rb +3 -1
  99. data/lib/sequel/adapters/odbc/mssql.rb +11 -15
  100. data/lib/sequel/adapters/odbc/oracle.rb +11 -0
  101. data/lib/sequel/adapters/oracle.rb +62 -68
  102. data/lib/sequel/adapters/postgres.rb +257 -311
  103. data/lib/sequel/adapters/postgresql.rb +3 -1
  104. data/lib/sequel/adapters/shared/access.rb +75 -79
  105. data/lib/sequel/adapters/shared/db2.rb +96 -74
  106. data/lib/sequel/adapters/shared/mssql.rb +258 -213
  107. data/lib/sequel/adapters/shared/mysql.rb +284 -216
  108. data/lib/sequel/adapters/shared/oracle.rb +175 -60
  109. data/lib/sequel/adapters/shared/postgres.rb +829 -383
  110. data/lib/sequel/adapters/shared/sqlanywhere.rb +105 -127
  111. data/lib/sequel/adapters/shared/sqlite.rb +382 -159
  112. data/lib/sequel/adapters/sqlanywhere.rb +53 -38
  113. data/lib/sequel/adapters/sqlite.rb +111 -105
  114. data/lib/sequel/adapters/tinytds.rb +38 -46
  115. data/lib/sequel/adapters/utils/emulate_offset_with_reverse_and_count.rb +8 -9
  116. data/lib/sequel/adapters/utils/emulate_offset_with_row_number.rb +7 -5
  117. data/lib/sequel/adapters/utils/mysql_mysql2.rb +87 -0
  118. data/lib/sequel/adapters/utils/mysql_prepared_statements.rb +56 -0
  119. data/lib/sequel/adapters/utils/replace.rb +3 -4
  120. data/lib/sequel/adapters/utils/split_alter_table.rb +2 -0
  121. data/lib/sequel/adapters/utils/stored_procedures.rb +9 -22
  122. data/lib/sequel/adapters/utils/unmodified_identifiers.rb +28 -0
  123. data/lib/sequel/ast_transformer.rb +13 -89
  124. data/lib/sequel/connection_pool.rb +54 -26
  125. data/lib/sequel/connection_pool/sharded_single.rb +19 -12
  126. data/lib/sequel/connection_pool/sharded_threaded.rb +160 -111
  127. data/lib/sequel/connection_pool/single.rb +21 -12
  128. data/lib/sequel/connection_pool/threaded.rb +137 -119
  129. data/lib/sequel/core.rb +352 -320
  130. data/lib/sequel/database.rb +19 -2
  131. data/lib/sequel/database/connecting.rb +70 -55
  132. data/lib/sequel/database/dataset.rb +15 -5
  133. data/lib/sequel/database/dataset_defaults.rb +20 -102
  134. data/lib/sequel/database/features.rb +20 -4
  135. data/lib/sequel/database/logging.rb +25 -7
  136. data/lib/sequel/database/misc.rb +132 -118
  137. data/lib/sequel/database/query.rb +51 -28
  138. data/lib/sequel/database/schema_generator.rb +188 -75
  139. data/lib/sequel/database/schema_methods.rb +161 -92
  140. data/lib/sequel/database/transactions.rb +260 -58
  141. data/lib/sequel/dataset.rb +28 -12
  142. data/lib/sequel/dataset/actions.rb +354 -170
  143. data/lib/sequel/dataset/dataset_module.rb +46 -0
  144. data/lib/sequel/dataset/features.rb +81 -34
  145. data/lib/sequel/dataset/graph.rb +82 -58
  146. data/lib/sequel/dataset/misc.rb +139 -47
  147. data/lib/sequel/dataset/placeholder_literalizer.rb +66 -26
  148. data/lib/sequel/dataset/prepared_statements.rb +188 -85
  149. data/lib/sequel/dataset/query.rb +428 -214
  150. data/lib/sequel/dataset/sql.rb +446 -339
  151. data/lib/sequel/deprecated.rb +14 -2
  152. data/lib/sequel/exceptions.rb +48 -16
  153. data/lib/sequel/extensions/_model_constraint_validations.rb +16 -0
  154. data/lib/sequel/extensions/_model_pg_row.rb +43 -0
  155. data/lib/sequel/extensions/_pretty_table.rb +10 -9
  156. data/lib/sequel/extensions/any_not_empty.rb +45 -0
  157. data/lib/sequel/extensions/arbitrary_servers.rb +15 -11
  158. data/lib/sequel/extensions/auto_literal_strings.rb +74 -0
  159. data/lib/sequel/extensions/blank.rb +2 -0
  160. data/lib/sequel/extensions/caller_logging.rb +79 -0
  161. data/lib/sequel/extensions/columns_introspection.rb +9 -4
  162. data/lib/sequel/extensions/connection_expiration.rb +99 -0
  163. data/lib/sequel/extensions/connection_validator.rb +26 -13
  164. data/lib/sequel/extensions/constant_sql_override.rb +65 -0
  165. data/lib/sequel/extensions/constraint_validations.rb +93 -38
  166. data/lib/sequel/extensions/core_extensions.rb +45 -53
  167. data/lib/sequel/extensions/core_refinements.rb +44 -46
  168. data/lib/sequel/extensions/current_datetime_timestamp.rb +5 -4
  169. data/lib/sequel/extensions/dataset_source_alias.rb +4 -0
  170. data/lib/sequel/extensions/date_arithmetic.rb +42 -16
  171. data/lib/sequel/extensions/datetime_parse_to_time.rb +37 -0
  172. data/lib/sequel/extensions/duplicate_columns_handler.rb +94 -0
  173. data/lib/sequel/extensions/empty_array_consider_nulls.rb +7 -3
  174. data/lib/sequel/extensions/error_sql.rb +7 -3
  175. data/lib/sequel/extensions/escaped_like.rb +100 -0
  176. data/lib/sequel/extensions/eval_inspect.rb +14 -15
  177. data/lib/sequel/extensions/exclude_or_null.rb +68 -0
  178. data/lib/sequel/extensions/fiber_concurrency.rb +24 -0
  179. data/lib/sequel/extensions/freeze_datasets.rb +3 -0
  180. data/lib/sequel/extensions/from_block.rb +2 -31
  181. data/lib/sequel/extensions/graph_each.rb +19 -6
  182. data/lib/sequel/extensions/identifier_mangling.rb +180 -0
  183. data/lib/sequel/extensions/implicit_subquery.rb +48 -0
  184. data/lib/sequel/extensions/index_caching.rb +109 -0
  185. data/lib/sequel/extensions/inflector.rb +8 -4
  186. data/lib/sequel/extensions/integer64.rb +32 -0
  187. data/lib/sequel/extensions/looser_typecasting.rb +19 -9
  188. data/lib/sequel/extensions/migration.rb +132 -80
  189. data/lib/sequel/extensions/mssql_emulate_lateral_with_apply.rb +4 -0
  190. data/lib/sequel/extensions/named_timezones.rb +88 -23
  191. data/lib/sequel/extensions/no_auto_literal_strings.rb +4 -0
  192. data/lib/sequel/extensions/null_dataset.rb +12 -8
  193. data/lib/sequel/extensions/pagination.rb +35 -28
  194. data/lib/sequel/extensions/pg_array.rb +227 -316
  195. data/lib/sequel/extensions/pg_array_ops.rb +19 -7
  196. data/lib/sequel/extensions/pg_enum.rb +69 -24
  197. data/lib/sequel/extensions/pg_extended_date_support.rb +250 -0
  198. data/lib/sequel/extensions/pg_hstore.rb +50 -59
  199. data/lib/sequel/extensions/pg_hstore_ops.rb +9 -3
  200. data/lib/sequel/extensions/pg_inet.rb +34 -15
  201. data/lib/sequel/extensions/pg_inet_ops.rb +5 -1
  202. data/lib/sequel/extensions/pg_interval.rb +26 -26
  203. data/lib/sequel/extensions/pg_json.rb +422 -141
  204. data/lib/sequel/extensions/pg_json_ops.rb +248 -9
  205. data/lib/sequel/extensions/pg_loose_count.rb +5 -1
  206. data/lib/sequel/extensions/pg_range.rb +162 -146
  207. data/lib/sequel/extensions/pg_range_ops.rb +10 -5
  208. data/lib/sequel/extensions/pg_row.rb +53 -87
  209. data/lib/sequel/extensions/pg_row_ops.rb +36 -13
  210. data/lib/sequel/extensions/pg_static_cache_updater.rb +6 -2
  211. data/lib/sequel/extensions/pg_timestamptz.rb +28 -0
  212. data/lib/sequel/extensions/pretty_table.rb +4 -0
  213. data/lib/sequel/extensions/query.rb +12 -7
  214. data/lib/sequel/extensions/round_timestamps.rb +6 -9
  215. data/lib/sequel/extensions/run_transaction_hooks.rb +72 -0
  216. data/lib/sequel/extensions/s.rb +59 -0
  217. data/lib/sequel/extensions/schema_caching.rb +14 -1
  218. data/lib/sequel/extensions/schema_dumper.rb +83 -55
  219. data/lib/sequel/extensions/select_remove.rb +8 -4
  220. data/lib/sequel/extensions/sequel_4_dataset_methods.rb +85 -0
  221. data/lib/sequel/extensions/server_block.rb +50 -17
  222. data/lib/sequel/extensions/server_logging.rb +61 -0
  223. data/lib/sequel/extensions/split_array_nil.rb +8 -4
  224. data/lib/sequel/extensions/sql_comments.rb +96 -0
  225. data/lib/sequel/extensions/sql_expr.rb +4 -1
  226. data/lib/sequel/extensions/string_agg.rb +181 -0
  227. data/lib/sequel/extensions/string_date_time.rb +2 -0
  228. data/lib/sequel/extensions/symbol_aref.rb +53 -0
  229. data/lib/sequel/extensions/symbol_aref_refinement.rb +43 -0
  230. data/lib/sequel/extensions/symbol_as.rb +23 -0
  231. data/lib/sequel/extensions/symbol_as_refinement.rb +37 -0
  232. data/lib/sequel/extensions/synchronize_sql.rb +45 -0
  233. data/lib/sequel/extensions/thread_local_timezones.rb +4 -0
  234. data/lib/sequel/extensions/to_dot.rb +15 -5
  235. data/lib/sequel/extensions/virtual_row_method_block.rb +44 -0
  236. data/lib/sequel/model.rb +36 -126
  237. data/lib/sequel/model/associations.rb +850 -257
  238. data/lib/sequel/model/base.rb +652 -764
  239. data/lib/sequel/model/dataset_module.rb +13 -10
  240. data/lib/sequel/model/default_inflections.rb +3 -1
  241. data/lib/sequel/model/errors.rb +3 -3
  242. data/lib/sequel/model/exceptions.rb +12 -12
  243. data/lib/sequel/model/inflections.rb +8 -19
  244. data/lib/sequel/model/plugins.rb +111 -0
  245. data/lib/sequel/plugins/accessed_columns.rb +2 -0
  246. data/lib/sequel/plugins/active_model.rb +32 -7
  247. data/lib/sequel/plugins/after_initialize.rb +3 -1
  248. data/lib/sequel/plugins/association_dependencies.rb +27 -18
  249. data/lib/sequel/plugins/association_lazy_eager_option.rb +66 -0
  250. data/lib/sequel/plugins/association_multi_add_remove.rb +85 -0
  251. data/lib/sequel/plugins/association_pks.rb +181 -83
  252. data/lib/sequel/plugins/association_proxies.rb +33 -9
  253. data/lib/sequel/plugins/auto_validations.rb +58 -23
  254. data/lib/sequel/plugins/before_after_save.rb +8 -0
  255. data/lib/sequel/plugins/blacklist_security.rb +23 -12
  256. data/lib/sequel/plugins/boolean_readers.rb +9 -6
  257. data/lib/sequel/plugins/boolean_subsets.rb +64 -0
  258. data/lib/sequel/plugins/caching.rb +27 -16
  259. data/lib/sequel/plugins/class_table_inheritance.rb +192 -94
  260. data/lib/sequel/plugins/column_conflicts.rb +18 -3
  261. data/lib/sequel/plugins/column_select.rb +9 -5
  262. data/lib/sequel/plugins/columns_updated.rb +42 -0
  263. data/lib/sequel/plugins/composition.rb +36 -24
  264. data/lib/sequel/plugins/constraint_validations.rb +37 -16
  265. data/lib/sequel/plugins/csv_serializer.rb +58 -35
  266. data/lib/sequel/plugins/dataset_associations.rb +60 -18
  267. data/lib/sequel/plugins/def_dataset_method.rb +90 -0
  268. data/lib/sequel/plugins/defaults_setter.rb +74 -13
  269. data/lib/sequel/plugins/delay_add_association.rb +4 -1
  270. data/lib/sequel/plugins/dirty.rb +65 -24
  271. data/lib/sequel/plugins/eager_each.rb +27 -3
  272. data/lib/sequel/plugins/eager_graph_eager.rb +139 -0
  273. data/lib/sequel/plugins/empty_failure_backtraces.rb +38 -0
  274. data/lib/sequel/plugins/error_splitter.rb +19 -12
  275. data/lib/sequel/plugins/finder.rb +246 -0
  276. data/lib/sequel/plugins/forbid_lazy_load.rb +216 -0
  277. data/lib/sequel/plugins/force_encoding.rb +9 -12
  278. data/lib/sequel/plugins/hook_class_methods.rb +39 -54
  279. data/lib/sequel/plugins/input_transformer.rb +20 -10
  280. data/lib/sequel/plugins/insert_conflict.rb +72 -0
  281. data/lib/sequel/plugins/insert_returning_select.rb +4 -2
  282. data/lib/sequel/plugins/instance_filters.rb +12 -8
  283. data/lib/sequel/plugins/instance_hooks.rb +36 -17
  284. data/lib/sequel/plugins/instance_specific_default.rb +113 -0
  285. data/lib/sequel/plugins/inverted_subsets.rb +24 -13
  286. data/lib/sequel/plugins/json_serializer.rb +123 -47
  287. data/lib/sequel/plugins/lazy_attributes.rb +20 -14
  288. data/lib/sequel/plugins/list.rb +40 -26
  289. data/lib/sequel/plugins/many_through_many.rb +28 -12
  290. data/lib/sequel/plugins/modification_detection.rb +17 -5
  291. data/lib/sequel/plugins/mssql_optimistic_locking.rb +8 -5
  292. data/lib/sequel/plugins/nested_attributes.rb +55 -28
  293. data/lib/sequel/plugins/optimistic_locking.rb +5 -3
  294. data/lib/sequel/plugins/pg_array_associations.rb +52 -18
  295. data/lib/sequel/plugins/pg_auto_constraint_validations.rb +348 -0
  296. data/lib/sequel/plugins/pg_row.rb +7 -51
  297. data/lib/sequel/plugins/prepared_statements.rb +53 -72
  298. data/lib/sequel/plugins/prepared_statements_safe.rb +13 -5
  299. data/lib/sequel/plugins/rcte_tree.rb +43 -63
  300. data/lib/sequel/plugins/serialization.rb +37 -44
  301. data/lib/sequel/plugins/serialization_modification_detection.rb +3 -1
  302. data/lib/sequel/plugins/sharding.rb +17 -10
  303. data/lib/sequel/plugins/single_table_inheritance.rb +62 -28
  304. data/lib/sequel/plugins/singular_table_names.rb +2 -0
  305. data/lib/sequel/plugins/skip_create_refresh.rb +5 -3
  306. data/lib/sequel/plugins/skip_saving_columns.rb +108 -0
  307. data/lib/sequel/plugins/split_values.rb +13 -6
  308. data/lib/sequel/plugins/static_cache.rb +79 -53
  309. data/lib/sequel/plugins/static_cache_cache.rb +53 -0
  310. data/lib/sequel/plugins/string_stripper.rb +5 -3
  311. data/lib/sequel/plugins/subclasses.rb +20 -2
  312. data/lib/sequel/plugins/subset_conditions.rb +48 -0
  313. data/lib/sequel/plugins/table_select.rb +4 -2
  314. data/lib/sequel/plugins/tactical_eager_loading.rb +120 -6
  315. data/lib/sequel/plugins/throw_failures.rb +110 -0
  316. data/lib/sequel/plugins/timestamps.rb +22 -8
  317. data/lib/sequel/plugins/touch.rb +21 -8
  318. data/lib/sequel/plugins/tree.rb +57 -30
  319. data/lib/sequel/plugins/typecast_on_load.rb +14 -4
  320. data/lib/sequel/plugins/unlimited_update.rb +3 -7
  321. data/lib/sequel/plugins/update_or_create.rb +6 -4
  322. data/lib/sequel/plugins/update_primary_key.rb +3 -1
  323. data/lib/sequel/plugins/update_refresh.rb +28 -15
  324. data/lib/sequel/plugins/uuid.rb +70 -0
  325. data/lib/sequel/plugins/validate_associated.rb +20 -0
  326. data/lib/sequel/plugins/validation_class_methods.rb +40 -19
  327. data/lib/sequel/plugins/validation_contexts.rb +49 -0
  328. data/lib/sequel/plugins/validation_helpers.rb +49 -31
  329. data/lib/sequel/plugins/whitelist_security.rb +122 -0
  330. data/lib/sequel/plugins/xml_serializer.rb +31 -30
  331. data/lib/sequel/sql.rb +479 -329
  332. data/lib/sequel/timezones.rb +62 -32
  333. data/lib/sequel/version.rb +10 -3
  334. metadata +177 -477
  335. data/Rakefile +0 -165
  336. data/doc/active_record.rdoc +0 -912
  337. data/doc/release_notes/1.0.txt +0 -38
  338. data/doc/release_notes/1.1.txt +0 -143
  339. data/doc/release_notes/1.3.txt +0 -101
  340. data/doc/release_notes/1.4.0.txt +0 -53
  341. data/doc/release_notes/1.5.0.txt +0 -155
  342. data/doc/release_notes/2.0.0.txt +0 -298
  343. data/doc/release_notes/2.1.0.txt +0 -271
  344. data/doc/release_notes/2.10.0.txt +0 -328
  345. data/doc/release_notes/2.11.0.txt +0 -215
  346. data/doc/release_notes/2.12.0.txt +0 -534
  347. data/doc/release_notes/2.2.0.txt +0 -253
  348. data/doc/release_notes/2.3.0.txt +0 -88
  349. data/doc/release_notes/2.4.0.txt +0 -106
  350. data/doc/release_notes/2.5.0.txt +0 -137
  351. data/doc/release_notes/2.6.0.txt +0 -157
  352. data/doc/release_notes/2.7.0.txt +0 -166
  353. data/doc/release_notes/2.8.0.txt +0 -171
  354. data/doc/release_notes/2.9.0.txt +0 -97
  355. data/doc/release_notes/3.0.0.txt +0 -221
  356. data/doc/release_notes/3.1.0.txt +0 -406
  357. data/doc/release_notes/3.10.0.txt +0 -286
  358. data/doc/release_notes/3.11.0.txt +0 -254
  359. data/doc/release_notes/3.12.0.txt +0 -304
  360. data/doc/release_notes/3.13.0.txt +0 -210
  361. data/doc/release_notes/3.14.0.txt +0 -118
  362. data/doc/release_notes/3.15.0.txt +0 -78
  363. data/doc/release_notes/3.16.0.txt +0 -45
  364. data/doc/release_notes/3.17.0.txt +0 -58
  365. data/doc/release_notes/3.18.0.txt +0 -120
  366. data/doc/release_notes/3.19.0.txt +0 -67
  367. data/doc/release_notes/3.2.0.txt +0 -268
  368. data/doc/release_notes/3.20.0.txt +0 -41
  369. data/doc/release_notes/3.21.0.txt +0 -87
  370. data/doc/release_notes/3.22.0.txt +0 -39
  371. data/doc/release_notes/3.23.0.txt +0 -172
  372. data/doc/release_notes/3.24.0.txt +0 -420
  373. data/doc/release_notes/3.25.0.txt +0 -88
  374. data/doc/release_notes/3.26.0.txt +0 -88
  375. data/doc/release_notes/3.27.0.txt +0 -82
  376. data/doc/release_notes/3.28.0.txt +0 -304
  377. data/doc/release_notes/3.29.0.txt +0 -459
  378. data/doc/release_notes/3.3.0.txt +0 -192
  379. data/doc/release_notes/3.30.0.txt +0 -135
  380. data/doc/release_notes/3.31.0.txt +0 -146
  381. data/doc/release_notes/3.32.0.txt +0 -202
  382. data/doc/release_notes/3.33.0.txt +0 -157
  383. data/doc/release_notes/3.34.0.txt +0 -671
  384. data/doc/release_notes/3.35.0.txt +0 -144
  385. data/doc/release_notes/3.36.0.txt +0 -245
  386. data/doc/release_notes/3.37.0.txt +0 -338
  387. data/doc/release_notes/3.38.0.txt +0 -234
  388. data/doc/release_notes/3.39.0.txt +0 -237
  389. data/doc/release_notes/3.4.0.txt +0 -325
  390. data/doc/release_notes/3.40.0.txt +0 -73
  391. data/doc/release_notes/3.41.0.txt +0 -155
  392. data/doc/release_notes/3.42.0.txt +0 -74
  393. data/doc/release_notes/3.43.0.txt +0 -105
  394. data/doc/release_notes/3.44.0.txt +0 -152
  395. data/doc/release_notes/3.45.0.txt +0 -179
  396. data/doc/release_notes/3.46.0.txt +0 -122
  397. data/doc/release_notes/3.47.0.txt +0 -270
  398. data/doc/release_notes/3.48.0.txt +0 -477
  399. data/doc/release_notes/3.5.0.txt +0 -510
  400. data/doc/release_notes/3.6.0.txt +0 -366
  401. data/doc/release_notes/3.7.0.txt +0 -179
  402. data/doc/release_notes/3.8.0.txt +0 -151
  403. data/doc/release_notes/3.9.0.txt +0 -233
  404. data/doc/release_notes/4.0.0.txt +0 -262
  405. data/doc/release_notes/4.1.0.txt +0 -85
  406. data/doc/release_notes/4.10.0.txt +0 -226
  407. data/doc/release_notes/4.11.0.txt +0 -147
  408. data/doc/release_notes/4.12.0.txt +0 -105
  409. data/doc/release_notes/4.13.0.txt +0 -169
  410. data/doc/release_notes/4.14.0.txt +0 -68
  411. data/doc/release_notes/4.15.0.txt +0 -56
  412. data/doc/release_notes/4.16.0.txt +0 -36
  413. data/doc/release_notes/4.17.0.txt +0 -38
  414. data/doc/release_notes/4.18.0.txt +0 -36
  415. data/doc/release_notes/4.19.0.txt +0 -45
  416. data/doc/release_notes/4.2.0.txt +0 -129
  417. data/doc/release_notes/4.20.0.txt +0 -79
  418. data/doc/release_notes/4.21.0.txt +0 -94
  419. data/doc/release_notes/4.22.0.txt +0 -72
  420. data/doc/release_notes/4.23.0.txt +0 -65
  421. data/doc/release_notes/4.24.0.txt +0 -99
  422. data/doc/release_notes/4.25.0.txt +0 -181
  423. data/doc/release_notes/4.26.0.txt +0 -44
  424. data/doc/release_notes/4.3.0.txt +0 -40
  425. data/doc/release_notes/4.4.0.txt +0 -92
  426. data/doc/release_notes/4.5.0.txt +0 -34
  427. data/doc/release_notes/4.6.0.txt +0 -30
  428. data/doc/release_notes/4.7.0.txt +0 -103
  429. data/doc/release_notes/4.8.0.txt +0 -175
  430. data/doc/release_notes/4.9.0.txt +0 -190
  431. data/lib/sequel/adapters/cubrid.rb +0 -142
  432. data/lib/sequel/adapters/do.rb +0 -156
  433. data/lib/sequel/adapters/do/mysql.rb +0 -64
  434. data/lib/sequel/adapters/do/postgres.rb +0 -42
  435. data/lib/sequel/adapters/do/sqlite3.rb +0 -40
  436. data/lib/sequel/adapters/jdbc/as400.rb +0 -82
  437. data/lib/sequel/adapters/jdbc/cubrid.rb +0 -62
  438. data/lib/sequel/adapters/jdbc/firebirdsql.rb +0 -34
  439. data/lib/sequel/adapters/jdbc/informix-sqli.rb +0 -31
  440. data/lib/sequel/adapters/jdbc/jdbcprogress.rb +0 -31
  441. data/lib/sequel/adapters/odbc/progress.rb +0 -8
  442. data/lib/sequel/adapters/shared/cubrid.rb +0 -243
  443. data/lib/sequel/adapters/shared/firebird.rb +0 -245
  444. data/lib/sequel/adapters/shared/informix.rb +0 -52
  445. data/lib/sequel/adapters/shared/mysql_prepared_statements.rb +0 -150
  446. data/lib/sequel/adapters/shared/progress.rb +0 -38
  447. data/lib/sequel/adapters/swift.rb +0 -158
  448. data/lib/sequel/adapters/swift/mysql.rb +0 -47
  449. data/lib/sequel/adapters/swift/postgres.rb +0 -45
  450. data/lib/sequel/adapters/swift/sqlite.rb +0 -47
  451. data/lib/sequel/adapters/utils/pg_types.rb +0 -68
  452. data/lib/sequel/dataset/mutation.rb +0 -109
  453. data/lib/sequel/extensions/empty_array_ignore_nulls.rb +0 -3
  454. data/lib/sequel/extensions/filter_having.rb +0 -59
  455. data/lib/sequel/extensions/hash_aliases.rb +0 -45
  456. data/lib/sequel/extensions/meta_def.rb +0 -31
  457. data/lib/sequel/extensions/query_literals.rb +0 -80
  458. data/lib/sequel/extensions/ruby18_symbol_extensions.rb +0 -22
  459. data/lib/sequel/extensions/sequel_3_dataset_methods.rb +0 -118
  460. data/lib/sequel/extensions/set_overrides.rb +0 -72
  461. data/lib/sequel/no_core_ext.rb +0 -1
  462. data/lib/sequel/plugins/association_autoreloading.rb +0 -7
  463. data/lib/sequel/plugins/many_to_one_pk_lookup.rb +0 -7
  464. data/lib/sequel/plugins/pg_typecast_on_load.rb +0 -78
  465. data/lib/sequel/plugins/prepared_statements_associations.rb +0 -117
  466. data/lib/sequel/plugins/prepared_statements_with_pk.rb +0 -59
  467. data/lib/sequel/plugins/schema.rb +0 -80
  468. data/lib/sequel/plugins/scissors.rb +0 -33
  469. data/spec/adapters/db2_spec.rb +0 -160
  470. data/spec/adapters/firebird_spec.rb +0 -411
  471. data/spec/adapters/informix_spec.rb +0 -100
  472. data/spec/adapters/mssql_spec.rb +0 -706
  473. data/spec/adapters/mysql_spec.rb +0 -1287
  474. data/spec/adapters/oracle_spec.rb +0 -313
  475. data/spec/adapters/postgres_spec.rb +0 -3725
  476. data/spec/adapters/spec_helper.rb +0 -43
  477. data/spec/adapters/sqlanywhere_spec.rb +0 -170
  478. data/spec/adapters/sqlite_spec.rb +0 -653
  479. data/spec/bin_spec.rb +0 -254
  480. data/spec/core/connection_pool_spec.rb +0 -1016
  481. data/spec/core/database_spec.rb +0 -2531
  482. data/spec/core/dataset_spec.rb +0 -5098
  483. data/spec/core/deprecated_spec.rb +0 -70
  484. data/spec/core/expression_filters_spec.rb +0 -1243
  485. data/spec/core/mock_adapter_spec.rb +0 -462
  486. data/spec/core/object_graph_spec.rb +0 -303
  487. data/spec/core/placeholder_literalizer_spec.rb +0 -163
  488. data/spec/core/schema_generator_spec.rb +0 -179
  489. data/spec/core/schema_spec.rb +0 -1659
  490. data/spec/core/spec_helper.rb +0 -34
  491. data/spec/core/version_spec.rb +0 -7
  492. data/spec/core_extensions_spec.rb +0 -699
  493. data/spec/extensions/accessed_columns_spec.rb +0 -51
  494. data/spec/extensions/active_model_spec.rb +0 -123
  495. data/spec/extensions/after_initialize_spec.rb +0 -24
  496. data/spec/extensions/arbitrary_servers_spec.rb +0 -109
  497. data/spec/extensions/association_dependencies_spec.rb +0 -117
  498. data/spec/extensions/association_pks_spec.rb +0 -365
  499. data/spec/extensions/association_proxies_spec.rb +0 -86
  500. data/spec/extensions/auto_validations_spec.rb +0 -192
  501. data/spec/extensions/blacklist_security_spec.rb +0 -88
  502. data/spec/extensions/blank_spec.rb +0 -69
  503. data/spec/extensions/boolean_readers_spec.rb +0 -93
  504. data/spec/extensions/caching_spec.rb +0 -270
  505. data/spec/extensions/class_table_inheritance_spec.rb +0 -420
  506. data/spec/extensions/column_conflicts_spec.rb +0 -60
  507. data/spec/extensions/column_select_spec.rb +0 -108
  508. data/spec/extensions/columns_introspection_spec.rb +0 -91
  509. data/spec/extensions/composition_spec.rb +0 -242
  510. data/spec/extensions/connection_validator_spec.rb +0 -120
  511. data/spec/extensions/constraint_validations_plugin_spec.rb +0 -274
  512. data/spec/extensions/constraint_validations_spec.rb +0 -325
  513. data/spec/extensions/core_refinements_spec.rb +0 -519
  514. data/spec/extensions/csv_serializer_spec.rb +0 -173
  515. data/spec/extensions/current_datetime_timestamp_spec.rb +0 -27
  516. data/spec/extensions/dataset_associations_spec.rb +0 -311
  517. data/spec/extensions/dataset_source_alias_spec.rb +0 -51
  518. data/spec/extensions/date_arithmetic_spec.rb +0 -150
  519. data/spec/extensions/defaults_setter_spec.rb +0 -101
  520. data/spec/extensions/delay_add_association_spec.rb +0 -52
  521. data/spec/extensions/dirty_spec.rb +0 -180
  522. data/spec/extensions/eager_each_spec.rb +0 -42
  523. data/spec/extensions/empty_array_consider_nulls_spec.rb +0 -24
  524. data/spec/extensions/error_splitter_spec.rb +0 -18
  525. data/spec/extensions/error_sql_spec.rb +0 -20
  526. data/spec/extensions/eval_inspect_spec.rb +0 -73
  527. data/spec/extensions/filter_having_spec.rb +0 -40
  528. data/spec/extensions/force_encoding_spec.rb +0 -114
  529. data/spec/extensions/from_block_spec.rb +0 -21
  530. data/spec/extensions/graph_each_spec.rb +0 -109
  531. data/spec/extensions/hash_aliases_spec.rb +0 -24
  532. data/spec/extensions/hook_class_methods_spec.rb +0 -429
  533. data/spec/extensions/inflector_spec.rb +0 -183
  534. data/spec/extensions/input_transformer_spec.rb +0 -54
  535. data/spec/extensions/insert_returning_select_spec.rb +0 -46
  536. data/spec/extensions/instance_filters_spec.rb +0 -79
  537. data/spec/extensions/instance_hooks_spec.rb +0 -276
  538. data/spec/extensions/inverted_subsets_spec.rb +0 -33
  539. data/spec/extensions/json_serializer_spec.rb +0 -291
  540. data/spec/extensions/lazy_attributes_spec.rb +0 -170
  541. data/spec/extensions/list_spec.rb +0 -267
  542. data/spec/extensions/looser_typecasting_spec.rb +0 -43
  543. data/spec/extensions/many_through_many_spec.rb +0 -2172
  544. data/spec/extensions/meta_def_spec.rb +0 -21
  545. data/spec/extensions/migration_spec.rb +0 -712
  546. data/spec/extensions/modification_detection_spec.rb +0 -80
  547. data/spec/extensions/mssql_optimistic_locking_spec.rb +0 -91
  548. data/spec/extensions/named_timezones_spec.rb +0 -108
  549. data/spec/extensions/nested_attributes_spec.rb +0 -697
  550. data/spec/extensions/null_dataset_spec.rb +0 -85
  551. data/spec/extensions/optimistic_locking_spec.rb +0 -128
  552. data/spec/extensions/pagination_spec.rb +0 -118
  553. data/spec/extensions/pg_array_associations_spec.rb +0 -736
  554. data/spec/extensions/pg_array_ops_spec.rb +0 -143
  555. data/spec/extensions/pg_array_spec.rb +0 -395
  556. data/spec/extensions/pg_enum_spec.rb +0 -92
  557. data/spec/extensions/pg_hstore_ops_spec.rb +0 -236
  558. data/spec/extensions/pg_hstore_spec.rb +0 -206
  559. data/spec/extensions/pg_inet_ops_spec.rb +0 -101
  560. data/spec/extensions/pg_inet_spec.rb +0 -52
  561. data/spec/extensions/pg_interval_spec.rb +0 -76
  562. data/spec/extensions/pg_json_ops_spec.rb +0 -229
  563. data/spec/extensions/pg_json_spec.rb +0 -218
  564. data/spec/extensions/pg_loose_count_spec.rb +0 -17
  565. data/spec/extensions/pg_range_ops_spec.rb +0 -58
  566. data/spec/extensions/pg_range_spec.rb +0 -404
  567. data/spec/extensions/pg_row_ops_spec.rb +0 -60
  568. data/spec/extensions/pg_row_plugin_spec.rb +0 -62
  569. data/spec/extensions/pg_row_spec.rb +0 -360
  570. data/spec/extensions/pg_static_cache_updater_spec.rb +0 -92
  571. data/spec/extensions/pg_typecast_on_load_spec.rb +0 -63
  572. data/spec/extensions/prepared_statements_associations_spec.rb +0 -159
  573. data/spec/extensions/prepared_statements_safe_spec.rb +0 -61
  574. data/spec/extensions/prepared_statements_spec.rb +0 -103
  575. data/spec/extensions/prepared_statements_with_pk_spec.rb +0 -31
  576. data/spec/extensions/pretty_table_spec.rb +0 -92
  577. data/spec/extensions/query_literals_spec.rb +0 -183
  578. data/spec/extensions/query_spec.rb +0 -102
  579. data/spec/extensions/rcte_tree_spec.rb +0 -392
  580. data/spec/extensions/round_timestamps_spec.rb +0 -43
  581. data/spec/extensions/schema_caching_spec.rb +0 -41
  582. data/spec/extensions/schema_dumper_spec.rb +0 -789
  583. data/spec/extensions/schema_spec.rb +0 -117
  584. data/spec/extensions/scissors_spec.rb +0 -26
  585. data/spec/extensions/select_remove_spec.rb +0 -38
  586. data/spec/extensions/sequel_3_dataset_methods_spec.rb +0 -101
  587. data/spec/extensions/serialization_modification_detection_spec.rb +0 -98
  588. data/spec/extensions/serialization_spec.rb +0 -362
  589. data/spec/extensions/server_block_spec.rb +0 -90
  590. data/spec/extensions/set_overrides_spec.rb +0 -61
  591. data/spec/extensions/sharding_spec.rb +0 -198
  592. data/spec/extensions/shared_caching_spec.rb +0 -175
  593. data/spec/extensions/single_table_inheritance_spec.rb +0 -297
  594. data/spec/extensions/singular_table_names_spec.rb +0 -22
  595. data/spec/extensions/skip_create_refresh_spec.rb +0 -17
  596. data/spec/extensions/spec_helper.rb +0 -71
  597. data/spec/extensions/split_array_nil_spec.rb +0 -24
  598. data/spec/extensions/split_values_spec.rb +0 -22
  599. data/spec/extensions/sql_expr_spec.rb +0 -60
  600. data/spec/extensions/static_cache_spec.rb +0 -361
  601. data/spec/extensions/string_date_time_spec.rb +0 -95
  602. data/spec/extensions/string_stripper_spec.rb +0 -68
  603. data/spec/extensions/subclasses_spec.rb +0 -66
  604. data/spec/extensions/table_select_spec.rb +0 -71
  605. data/spec/extensions/tactical_eager_loading_spec.rb +0 -82
  606. data/spec/extensions/thread_local_timezones_spec.rb +0 -67
  607. data/spec/extensions/timestamps_spec.rb +0 -175
  608. data/spec/extensions/to_dot_spec.rb +0 -154
  609. data/spec/extensions/touch_spec.rb +0 -203
  610. data/spec/extensions/tree_spec.rb +0 -274
  611. data/spec/extensions/typecast_on_load_spec.rb +0 -80
  612. data/spec/extensions/unlimited_update_spec.rb +0 -20
  613. data/spec/extensions/update_or_create_spec.rb +0 -87
  614. data/spec/extensions/update_primary_key_spec.rb +0 -100
  615. data/spec/extensions/update_refresh_spec.rb +0 -53
  616. data/spec/extensions/validate_associated_spec.rb +0 -52
  617. data/spec/extensions/validation_class_methods_spec.rb +0 -1027
  618. data/spec/extensions/validation_helpers_spec.rb +0 -541
  619. data/spec/extensions/xml_serializer_spec.rb +0 -207
  620. data/spec/files/bad_down_migration/001_create_alt_basic.rb +0 -4
  621. data/spec/files/bad_down_migration/002_create_alt_advanced.rb +0 -4
  622. data/spec/files/bad_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  623. data/spec/files/bad_timestamped_migrations/1273253851_create_nodes.rb +0 -9
  624. data/spec/files/bad_timestamped_migrations/1273253853_3_create_users.rb +0 -3
  625. data/spec/files/bad_up_migration/001_create_alt_basic.rb +0 -4
  626. data/spec/files/bad_up_migration/002_create_alt_advanced.rb +0 -3
  627. data/spec/files/convert_to_timestamp_migrations/001_create_sessions.rb +0 -9
  628. data/spec/files/convert_to_timestamp_migrations/002_create_nodes.rb +0 -9
  629. data/spec/files/convert_to_timestamp_migrations/003_3_create_users.rb +0 -4
  630. data/spec/files/convert_to_timestamp_migrations/1273253850_create_artists.rb +0 -9
  631. data/spec/files/convert_to_timestamp_migrations/1273253852_create_albums.rb +0 -9
  632. data/spec/files/duplicate_integer_migrations/001_create_alt_advanced.rb +0 -4
  633. data/spec/files/duplicate_integer_migrations/001_create_alt_basic.rb +0 -4
  634. data/spec/files/duplicate_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  635. data/spec/files/duplicate_timestamped_migrations/1273253853_create_nodes.rb +0 -9
  636. data/spec/files/duplicate_timestamped_migrations/1273253853_create_users.rb +0 -4
  637. data/spec/files/integer_migrations/001_create_sessions.rb +0 -9
  638. data/spec/files/integer_migrations/002_create_nodes.rb +0 -9
  639. data/spec/files/integer_migrations/003_3_create_users.rb +0 -4
  640. data/spec/files/interleaved_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  641. data/spec/files/interleaved_timestamped_migrations/1273253850_create_artists.rb +0 -9
  642. data/spec/files/interleaved_timestamped_migrations/1273253851_create_nodes.rb +0 -9
  643. data/spec/files/interleaved_timestamped_migrations/1273253852_create_albums.rb +0 -9
  644. data/spec/files/interleaved_timestamped_migrations/1273253853_3_create_users.rb +0 -4
  645. data/spec/files/missing_integer_migrations/001_create_alt_basic.rb +0 -4
  646. data/spec/files/missing_integer_migrations/003_create_alt_advanced.rb +0 -4
  647. data/spec/files/missing_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  648. data/spec/files/missing_timestamped_migrations/1273253853_3_create_users.rb +0 -4
  649. data/spec/files/reversible_migrations/001_reversible.rb +0 -5
  650. data/spec/files/reversible_migrations/002_reversible.rb +0 -5
  651. data/spec/files/reversible_migrations/003_reversible.rb +0 -5
  652. data/spec/files/reversible_migrations/004_reversible.rb +0 -5
  653. data/spec/files/reversible_migrations/005_reversible.rb +0 -10
  654. data/spec/files/timestamped_migrations/1273253849_create_sessions.rb +0 -9
  655. data/spec/files/timestamped_migrations/1273253851_create_nodes.rb +0 -9
  656. data/spec/files/timestamped_migrations/1273253853_3_create_users.rb +0 -4
  657. data/spec/files/transaction_specified_migrations/001_create_alt_basic.rb +0 -4
  658. data/spec/files/transaction_specified_migrations/002_create_basic.rb +0 -4
  659. data/spec/files/transaction_unspecified_migrations/001_create_alt_basic.rb +0 -3
  660. data/spec/files/transaction_unspecified_migrations/002_create_basic.rb +0 -3
  661. data/spec/files/uppercase_timestamped_migrations/1273253849_CREATE_SESSIONS.RB +0 -9
  662. data/spec/files/uppercase_timestamped_migrations/1273253851_CREATE_NODES.RB +0 -9
  663. data/spec/files/uppercase_timestamped_migrations/1273253853_3_CREATE_USERS.RB +0 -4
  664. data/spec/guards_helper.rb +0 -55
  665. data/spec/integration/associations_test.rb +0 -2454
  666. data/spec/integration/database_test.rb +0 -113
  667. data/spec/integration/dataset_test.rb +0 -1808
  668. data/spec/integration/eager_loader_test.rb +0 -687
  669. data/spec/integration/migrator_test.rb +0 -240
  670. data/spec/integration/model_test.rb +0 -226
  671. data/spec/integration/plugin_test.rb +0 -2240
  672. data/spec/integration/prepared_statement_test.rb +0 -467
  673. data/spec/integration/schema_test.rb +0 -817
  674. data/spec/integration/spec_helper.rb +0 -48
  675. data/spec/integration/timezone_test.rb +0 -86
  676. data/spec/integration/transaction_test.rb +0 -374
  677. data/spec/integration/type_test.rb +0 -133
  678. data/spec/model/association_reflection_spec.rb +0 -525
  679. data/spec/model/associations_spec.rb +0 -4426
  680. data/spec/model/base_spec.rb +0 -759
  681. data/spec/model/class_dataset_methods_spec.rb +0 -146
  682. data/spec/model/dataset_methods_spec.rb +0 -149
  683. data/spec/model/eager_loading_spec.rb +0 -2137
  684. data/spec/model/hooks_spec.rb +0 -604
  685. data/spec/model/inflector_spec.rb +0 -26
  686. data/spec/model/model_spec.rb +0 -982
  687. data/spec/model/plugins_spec.rb +0 -299
  688. data/spec/model/record_spec.rb +0 -2147
  689. data/spec/model/spec_helper.rb +0 -46
  690. data/spec/model/validations_spec.rb +0 -193
  691. data/spec/sequel_coverage.rb +0 -15
  692. data/spec/spec_config.rb +0 -10
@@ -1,7 +1,9 @@
1
+ # frozen-string-literal: true
2
+
1
3
  module Sequel
2
4
  module Plugins
3
- # The validation_helpers plugin contains instance method equivalents for most of the legacy
4
- # class-level validations. The names and APIs are different, though. Example:
5
+ # The validation_helpers plugin contains validate_* methods designed to be called inside Model#validate
6
+ # to perform validations:
5
7
  #
6
8
  # Sequel::Model.plugin :validation_helpers
7
9
  # class Album < Sequel::Model
@@ -17,9 +19,7 @@ module Sequel
17
19
  # atts :: Single attribute symbol or an array of attribute symbols specifying the
18
20
  # attribute(s) to validate.
19
21
  # Options:
20
- # :allow_blank :: Whether to skip the validation if the value is blank. You should
21
- # make sure all objects respond to blank if you use this option, which you can do by:
22
- # Sequel.extension :blank
22
+ # :allow_blank :: Whether to skip the validation if the value is blank.
23
23
  # :allow_missing :: Whether to skip the validation if the attribute isn't a key in the
24
24
  # values hash. This is different from allow_nil, because Sequel only sends the attributes
25
25
  # in the values when doing an insert or update. If the attribute is not present, Sequel
@@ -38,17 +38,24 @@ module Sequel
38
38
  # that argument is passed as an argument to the proc.
39
39
  #
40
40
  # The default validation options for all models can be modified by
41
- # changing the values of the Sequel::Plugins::ValidationHelpers::DEFAULT_OPTIONS hash. You
42
- # change change the default options on a per model basis
43
- # by overriding a private instance method default_validation_helpers_options.
44
- #
41
+ # overridding the Model#default_validation_helpers_options private method.
45
42
  # By changing the default options, you can setup internationalization of the
46
43
  # error messages. For example, you would modify the default options:
47
44
  #
48
- # Sequel::Plugins::ValidationHelpers::DEFAULT_OPTIONS.merge!(
49
- # :exact_length=>{:message=>lambda{|exact| I18n.t("errors.exact_length", :exact => exact)}},
50
- # :integer=>{:message=>lambda{I18n.t("errors.integer")}}
51
- # )
45
+ # class Sequel::Model
46
+ # private
47
+ #
48
+ # def default_validation_helpers_options(type)
49
+ # case type
50
+ # when :exact_length
51
+ # {message: lambda{|exact| I18n.t("errors.exact_length", exact: exact)}}
52
+ # when :integer
53
+ # {message: lambda{I18n.t("errors.integer")}}
54
+ # else
55
+ # super
56
+ # end
57
+ # end
58
+ # end
52
59
  #
53
60
  # and then use something like this in your yaml translation file:
54
61
  #
@@ -61,20 +68,16 @@ module Sequel
61
68
  # you need to override the method. Here's an example:
62
69
  #
63
70
  # class Sequel::Model::Errors
64
- # ATTRIBUTE_JOINER = I18n.t('errors.joiner').freeze
65
71
  # def full_messages
66
72
  # inject([]) do |m, kv|
67
73
  # att, errors = *kv
68
74
  # att.is_a?(Array) ? Array(att).map!{|v| I18n.t("attributes.#{v}")} : att = I18n.t("attributes.#{att}")
69
- # errors.each {|e| m << (e.is_a?(LiteralString) ? e : "#{Array(att).join(ATTRIBUTE_JOINER)} #{e}")}
75
+ # errors.each {|e| m << (e.is_a?(LiteralString) ? e : "#{Array(att).join(I18n.t('errors.joiner'))} #{e}")}
70
76
  # m
71
77
  # end
72
78
  # end
73
79
  # end
74
80
  module ValidationHelpers
75
- # Default validation options used by Sequel. Can be modified to change the error
76
- # messages for all models (e.g. for internationalization), or to set certain
77
- # default options for validations (e.g. :allow_nil=>true for all validates_format).
78
81
  DEFAULT_OPTIONS = {
79
82
  :exact_length=>{:message=>lambda{|exact| "is not #{exact} characters"}},
80
83
  :format=>{:message=>lambda{|with| 'is invalid'}},
@@ -85,10 +88,12 @@ module Sequel
85
88
  :min_length=>{:message=>lambda{|min| "is shorter than #{min} characters"}},
86
89
  :not_null=>{:message=>lambda{"is not present"}},
87
90
  :numeric=>{:message=>lambda{"is not a number"}},
91
+ :operator=>{:message=>lambda{|operator, rhs| "is not #{operator} #{rhs}"}},
88
92
  :type=>{:message=>lambda{|klass| klass.is_a?(Array) ? "is not a valid #{klass.join(" or ").downcase}" : "is not a valid #{klass.to_s.downcase}"}},
89
93
  :presence=>{:message=>lambda{"is not present"}},
90
94
  :unique=>{:message=>lambda{'is already taken'}}
91
- }
95
+ }.freeze
96
+ DEFAULT_OPTIONS.each_value(&:freeze)
92
97
 
93
98
  module InstanceMethods
94
99
  # Check that the attribute values are the given exact length.
@@ -103,7 +108,7 @@ module Sequel
103
108
 
104
109
  # Check attribute value(s) is included in the given set.
105
110
  def validates_includes(set, atts, opts=OPTS)
106
- validatable_attributes_for_type(:includes, atts, opts){|a,v,m| validation_error_message(m, set) unless set.send(set.respond_to?(:cover?) ? :cover? : :include?, v)}
111
+ validatable_attributes_for_type(:includes, atts, opts){|a,v,m| validation_error_message(m, set) unless set.public_send(set.respond_to?(:cover?) ? :cover? : :include?, v)}
107
112
  end
108
113
 
109
114
  # Check attribute value(s) string representation is a valid integer.
@@ -120,7 +125,7 @@ module Sequel
120
125
 
121
126
  # Check that the attribute values length is in the specified range.
122
127
  def validates_length_range(range, atts, opts=OPTS)
123
- validatable_attributes_for_type(:length_range, atts, opts){|a,v,m| validation_error_message(m, range) if v.nil? || !range.send(range.respond_to?(:cover?) ? :cover? : :include?, v.length)}
128
+ validatable_attributes_for_type(:length_range, atts, opts){|a,v,m| validation_error_message(m, range) if v.nil? || !range.cover?(v.length)}
124
129
  end
125
130
 
126
131
  # Check that the attribute values are not longer than the given max length.
@@ -128,7 +133,13 @@ module Sequel
128
133
  # Accepts a :nil_message option that is the error message to use when the
129
134
  # value is nil instead of being too long.
130
135
  def validates_max_length(max, atts, opts=OPTS)
131
- validatable_attributes_for_type(:max_length, atts, opts){|a,v,m| v ? validation_error_message(m, max) : validation_error_message(opts[:nil_message] || DEFAULT_OPTIONS[:max_length][:nil_message]) if v.nil? || v.length > max}
136
+ validatable_attributes_for_type(:max_length, atts, opts) do |a,v,m|
137
+ if v.nil?
138
+ validation_error_message(opts[:nil_message] || default_validation_helpers_options(:max_length)[:nil_message])
139
+ elsif v.length > max
140
+ validation_error_message(m, max)
141
+ end
142
+ end
132
143
  end
133
144
 
134
145
  # Check that the attribute values are not shorter than the given min length.
@@ -153,6 +164,12 @@ module Sequel
153
164
  end
154
165
  end
155
166
 
167
+ # Check attribute value(s) against a specified value and operation, e.g.
168
+ # validates_operator(:>, 3, :value) validates that value > 3.
169
+ def validates_operator(operator, rhs, atts, opts=OPTS)
170
+ validatable_attributes_for_type(:operator, atts, opts){|a,v,m| validation_error_message(m, operator, rhs) if v.nil? || !v.public_send(operator, rhs)}
171
+ end
172
+
156
173
  # Validates for all of the model columns (or just the given columns)
157
174
  # that the column value is an instance of the expected class based on
158
175
  # the column's schema type.
@@ -195,7 +212,7 @@ module Sequel
195
212
  # must be unique. So if you are doing a soft delete of records, in which
196
213
  # the name must be unique, but only for active records:
197
214
  #
198
- # validates_unique(:name){|ds| ds.filter(:active)}
215
+ # validates_unique(:name){|ds| ds.where(:active)}
199
216
  #
200
217
  # You should also add a unique index in the
201
218
  # database, as this suffers from a fairly obvious race condition.
@@ -208,18 +225,18 @@ module Sequel
208
225
  # model's dataset.
209
226
  # :message :: The message to use (default: 'is already taken')
210
227
  # :only_if_modified :: Only check the uniqueness if the object is new or
211
- # one of the columns has been modified.
228
+ # one of the columns has been modified, true by default.
212
229
  # :where :: A callable object where call takes three arguments, a dataset,
213
230
  # the current object, and an array of columns, and should return
214
231
  # a modified dataset that is filtered to include only rows with
215
232
  # the same values as the current object for each column in the array.
216
233
  #
217
- # If you want to to a case insensitive uniqueness validation on a database that
234
+ # If you want to do a case insensitive uniqueness validation on a database that
218
235
  # is case sensitive by default, you can use:
219
236
  #
220
- # validates_unique :column, :where=>(proc do |ds, obj, cols|
237
+ # validates_unique :column, where:(lambda do |ds, obj, cols|
221
238
  # ds.where(cols.map do |c|
222
- # v = obj.send(c)
239
+ # v = obj.public_send(c)
223
240
  # v = v.downcase if v
224
241
  # [Sequel.function(:lower, c), v]
225
242
  # end)
@@ -227,7 +244,7 @@ module Sequel
227
244
  def validates_unique(*atts)
228
245
  opts = default_validation_helpers_options(:unique)
229
246
  if atts.last.is_a?(Hash)
230
- opts = Hash[opts].merge!(atts.pop)
247
+ opts = opts.merge(atts.pop)
231
248
  end
232
249
  message = validation_error_message(opts[:message])
233
250
  from_values = opts[:from] == :values
@@ -235,7 +252,8 @@ module Sequel
235
252
  atts.each do |a|
236
253
  arr = Array(a)
237
254
  next if arr.any?{|x| errors.on(x)}
238
- next if opts[:only_if_modified] && !new? && !arr.any?{|x| changed_columns.include?(x)}
255
+ cc = changed_columns
256
+ next if opts.fetch(:only_if_modified, true) && !new? && !arr.any?{|x| cc.include?(x)}
239
257
  ds = opts[:dataset] || model.dataset
240
258
  ds = if where
241
259
  where.call(ds, self, arr)
@@ -274,7 +292,7 @@ module Sequel
274
292
  next if am && !values.has_key?(a)
275
293
  v = from_values ? values[a] : get_column_value(a)
276
294
  next if an && v.nil?
277
- next if ab && v.respond_to?(:blank?) && v.blank?
295
+ next if ab && model.db.send(:blank_object?, v)
278
296
  if message = yield(a, v, m)
279
297
  errors.add(a, message)
280
298
  end
@@ -284,7 +302,7 @@ module Sequel
284
302
  # Merge the given options with the default options for the given type
285
303
  # and call validatable_attributes with the merged options.
286
304
  def validatable_attributes_for_type(type, atts, opts, &block)
287
- validatable_attributes(atts, Hash[default_validation_helpers_options(type)].merge!(opts), &block)
305
+ validatable_attributes(atts, default_validation_helpers_options(type).merge(opts), &block)
288
306
  end
289
307
 
290
308
  # The validation error message to use, as a string. If message
@@ -0,0 +1,122 @@
1
+ # frozen-string-literal: true
2
+
3
+ module Sequel
4
+ module Plugins
5
+ # The whitelist_security plugin contains whitelist-based support for
6
+ # mass assignment, explicitly specifying which columns to allow mass assignment for,
7
+ # disallowing mass assignment for columns not listed. This exists mostly for backwards
8
+ # compatibility, it's best to use Sequel::Model#set_fields and Sequel::Model#update_fields
9
+ # to decide which fields to allow on a per-call basis.
10
+ #
11
+ # Usage:
12
+ #
13
+ # # Make all model subclasses support allowed_columns
14
+ # Sequel::Model.plugin :whitelist_security
15
+ #
16
+ # # Make the Album class support allowed_columns
17
+ # Album.plugin :whitelist_security
18
+ module WhitelistSecurity
19
+ module ClassMethods
20
+ # Which columns should be the only columns allowed in a call to a mass assignment method (e.g. set)
21
+ # (default: not set, so all columns not otherwise restricted are allowed).
22
+ attr_reader :allowed_columns
23
+
24
+ Plugins.inherited_instance_variables(self, :@allowed_columns=>:dup)
25
+
26
+ # Freeze allowed columns when freezing model class.
27
+ def freeze
28
+ @allowed_columns.freeze
29
+ super
30
+ end
31
+
32
+ # Set the columns to allow when using mass assignment (e.g. +set+). Using this means that
33
+ # any columns not listed here will not be modified. If you have any virtual
34
+ # setter methods (methods that end in =) that you want to be used during
35
+ # mass assignment, they need to be listed here as well (without the =).
36
+ #
37
+ # It may be better to use +set_fields+ which lets you specify
38
+ # the allowed fields per call.
39
+ #
40
+ # Artist.set_allowed_columns(:name, :hometown)
41
+ # Artist.set(name: 'Bob', hometown: 'Sactown') # No Error
42
+ # Artist.set(name: 'Bob', records_sold: 30000) # Error
43
+ def set_allowed_columns(*cols)
44
+ clear_setter_methods_cache
45
+ @allowed_columns = cols
46
+ end
47
+
48
+ private
49
+
50
+ # If allowed_columns is set, only allow those columns.
51
+ def get_setter_methods
52
+ if allowed_columns
53
+ allowed_columns.map{|x| "#{x}="}
54
+ else
55
+ super
56
+ end
57
+ end
58
+ end
59
+
60
+ module InstanceMethods
61
+ # Set all values using the entries in the hash, ignoring any setting of
62
+ # allowed_columns in the model.
63
+ #
64
+ # Artist.set_allowed_columns(:num_albums)
65
+ # artist.set_all(name: 'Jim')
66
+ # artist.name # => 'Jim'
67
+ def set_all(hash)
68
+ set_restricted(hash, :all)
69
+ end
70
+
71
+ # Set the values using the entries in the hash, only if the key
72
+ # is included in only. It may be a better idea to use +set_fields+
73
+ # instead of this method.
74
+ #
75
+ # artist.set_only({name: 'Jim'}, :name)
76
+ # artist.name # => 'Jim'
77
+ #
78
+ # artist.set_only({hometown: 'LA'}, :name) # Raise Error
79
+ def set_only(hash, *only)
80
+ set_restricted(hash, only.flatten)
81
+ end
82
+
83
+ # Update all values using the entries in the hash, ignoring any setting of
84
+ # +allowed_columns+ in the model.
85
+ #
86
+ # Artist.set_allowed_columns(:num_albums)
87
+ # artist.update_all(name: 'Jim') # UPDATE artists SET name = 'Jim' WHERE (id = 1)
88
+ def update_all(hash)
89
+ update_restricted(hash, :all)
90
+ end
91
+
92
+ # Update the values using the entries in the hash, only if the key
93
+ # is included in only. It may be a better idea to use +update_fields+
94
+ # instead of this method.
95
+ #
96
+ # artist.update_only({name: 'Jim'}, :name)
97
+ # # UPDATE artists SET name = 'Jim' WHERE (id = 1)
98
+ #
99
+ # artist.update_only({hometown: 'LA'}, :name) # Raise Error
100
+ def update_only(hash, *only)
101
+ update_restricted(hash, only.flatten)
102
+ end
103
+
104
+ private
105
+
106
+ # If allowed_columns is set and set/update is called, only allow those columns.
107
+ def setter_methods(type)
108
+ if type == :default && model.allowed_columns
109
+ model.setter_methods
110
+ elsif type.is_a?(Array)
111
+ type.map{|x| "#{x}="}
112
+ elsif type == :all && primary_key && model.restrict_primary_key?
113
+ super + Array(primary_key).map{|x| "#{x}="}
114
+ else
115
+ super
116
+ end
117
+ end
118
+ end
119
+ end
120
+ end
121
+ end
122
+
@@ -1,3 +1,5 @@
1
+ # frozen-string-literal: true
2
+
1
3
  require 'nokogiri'
2
4
 
3
5
  module Sequel
@@ -21,15 +23,15 @@ module Sequel
21
23
  #
22
24
  # You can provide options to control the XML output:
23
25
  #
24
- # puts album.to_xml(:only=>:name)
25
- # puts album.to_xml(:except=>[:id, :artist_id])
26
+ # puts album.to_xml(only: :name)
27
+ # puts album.to_xml(except: [:id, :artist_id])
26
28
  # # Output:
27
29
  # # <?xml version="1.0"?>
28
30
  # # <album>
29
31
  # # <name>RF</name>
30
32
  # # </album>
31
33
  #
32
- # album.to_xml(:include=>:artist)
34
+ # album.to_xml(include: :artist)
33
35
  # # Output:
34
36
  # # <?xml version="1.0"?>
35
37
  # # <album>
@@ -45,7 +47,7 @@ module Sequel
45
47
  # You can use a hash value with <tt>:include</tt> to pass options
46
48
  # to associations:
47
49
  #
48
- # album.to_xml(:include=>{:artist=>{:only=>:name}})
50
+ # album.to_xml(include: {artist: {only: :name}})
49
51
  # # Output:
50
52
  # # <?xml version="1.0"?>
51
53
  # # <album>
@@ -61,12 +63,12 @@ module Sequel
61
63
  # of which return all objects in the dataset:
62
64
  #
63
65
  # Album.to_xml
64
- # Album.filter(:artist_id=>1).to_xml(:include=>:tags)
66
+ # Album.where(artist_id: 1).to_xml(include: :tags)
65
67
  #
66
68
  # If you have an existing array of model instances you want to convert to
67
69
  # XML, you can call the class to_xml method with the :array option:
68
70
  #
69
- # Album.to_xml(:array=>[Album[1], Album[2]])
71
+ # Album.to_xml(array: [Album[1], Album[2]])
70
72
  #
71
73
  # In addition to creating XML, this plugin also enables Sequel::Model
72
74
  # classes to create instances directly from XML using the from_xml class
@@ -78,7 +80,7 @@ module Sequel
78
80
  # The array_from_xml class method exists to parse arrays of model instances
79
81
  # from xml:
80
82
  #
81
- # xml = Album.filter(:artist_id=>1).to_xml
83
+ # xml = Album.where(artist_id: 1).to_xml
82
84
  # albums = Album.array_from_xml(xml)
83
85
  #
84
86
  # These does not necessarily round trip, since doing so would let users
@@ -87,7 +89,7 @@ module Sequel
87
89
  # fields, you can use the :fields option, which will call set_fields with
88
90
  # the given fields:
89
91
  #
90
- # Album.from_xml(album.to_xml, :fields=>%w'id name')
92
+ # Album.from_xml(album.to_xml, fields: %w'id name')
91
93
  #
92
94
  # If you want to update an existing instance, you can use the from_xml
93
95
  # instance method:
@@ -97,11 +99,11 @@ module Sequel
97
99
  # Both of these allow creation of cached associated objects, if you provide
98
100
  # the :associations option:
99
101
  #
100
- # album.from_xml(xml, :associations=>:artist)
102
+ # album.from_xml(xml, associations: :artist)
101
103
  #
102
104
  # You can even provide options when setting up the associated objects:
103
105
  #
104
- # album.from_xml(xml, :associations=>{:artist=>{:fields=>%w'id name', :associations=>:tags}})
106
+ # album.from_xml(xml, associations: {artist: {fields: %w'id name', associations: :tags}})
105
107
  #
106
108
  # Usage:
107
109
  #
@@ -113,17 +115,17 @@ module Sequel
113
115
  module XmlSerializer
114
116
  module ClassMethods
115
117
  # Proc that camelizes the input string, used for the :camelize option
116
- CAMELIZE = proc(&:camelize)
118
+ CAMELIZE = :camelize.to_proc
117
119
 
118
120
  # Proc that dasherizes the input string, used for the :dasherize option
119
- DASHERIZE = proc(&:dasherize)
121
+ DASHERIZE = :dasherize.to_proc
120
122
 
121
123
  # Proc that returns the input string as is, used if
122
124
  # no :name_proc, :dasherize, or :camelize option is used.
123
125
  IDENTITY = proc{|s| s}
124
126
 
125
127
  # Proc that underscores the input string, used for the :underscore option
126
- UNDERSCORE = proc(&:underscore)
128
+ UNDERSCORE = :underscore.to_proc
127
129
 
128
130
  # Return an array of instances of this class based on
129
131
  # the provided XML.
@@ -135,28 +137,27 @@ module Sequel
135
137
  node.children.reject{|c| c.is_a?(Nokogiri::XML::Text)}.map{|c| from_xml_node(c, opts)}
136
138
  end
137
139
 
138
- # Return an instance of this class based on the provided
139
- # XML.
140
+ # Return an instance of this class based on the provided XML.
140
141
  def from_xml(xml, opts=OPTS)
141
142
  from_xml_node(Nokogiri::XML(xml).children.first, opts)
142
143
  end
143
144
 
144
145
  # Return an instance of this class based on the given
145
146
  # XML node, which should be Nokogiri::XML::Node instance.
146
- # This should probably not be used directly by user code.
147
+ # This should not be used directly by user code.
147
148
  def from_xml_node(parent, opts=OPTS)
148
149
  new.from_xml_node(parent, opts)
149
150
  end
150
151
 
151
152
  # Return an appropriate Nokogiri::XML::Builder instance
152
- # used to create the XML. This should probably not be used
153
+ # used to create the XML. This should not be used
153
154
  # directly by user code.
154
155
  def xml_builder(opts=OPTS)
155
156
  if opts[:builder]
156
157
  opts[:builder]
157
158
  else
158
159
  builder_opts = if opts[:builder_opts]
159
- opts[:builder_opts]
160
+ Hash[opts[:builder_opts]]
160
161
  else
161
162
  {}
162
163
  end
@@ -167,7 +168,7 @@ module Sequel
167
168
 
168
169
  # Return a proc (or any other object that responds to []),
169
170
  # used for formatting XML tag names when serializing to XML.
170
- # This should probably not be used directly by user code.
171
+ # This should not be used directly by user code.
171
172
  def xml_deserialize_name_proc(opts=OPTS)
172
173
  if opts[:name_proc]
173
174
  opts[:name_proc]
@@ -180,7 +181,7 @@ module Sequel
180
181
 
181
182
  # Return a proc (or any other object that responds to []),
182
183
  # used for formatting XML tag names when serializing to XML.
183
- # This should probably not be used directly by user code.
184
+ # This should not be used directly by user code.
184
185
  def xml_serialize_name_proc(opts=OPTS)
185
186
  pr = if opts[:name_proc]
186
187
  opts[:name_proc]
@@ -232,10 +233,10 @@ module Sequel
232
233
  if assocs = opts[:associations]
233
234
  assocs = case assocs
234
235
  when Symbol
235
- {assocs=>{}}
236
+ {assocs=>OPTS}
236
237
  when Array
237
238
  assocs_tmp = {}
238
- assocs.each{|v| assocs_tmp[v] = {}}
239
+ assocs.each{|v| assocs_tmp[v] = OPTS}
239
240
  assocs_tmp
240
241
  when Hash
241
242
  assocs
@@ -341,17 +342,17 @@ module Sequel
341
342
 
342
343
  name_proc = model.xml_serialize_name_proc(opts)
343
344
  x = model.xml_builder(opts)
344
- x.send(name_proc[opts.fetch(:root_name, model.send(:underscore, model.name).gsub('/', '__')).to_s]) do |x1|
345
+ x.public_send(name_proc[opts.fetch(:root_name, model.send(:underscore, model.name).gsub('/', '__')).to_s]) do |x1|
345
346
  cols.each do |c|
346
347
  attrs = {}
347
348
  if types
348
- attrs[:type] = db_schema.fetch(c, {})[:type]
349
+ attrs[:type] = db_schema.fetch(c, OPTS)[:type]
349
350
  end
350
351
  v = vals[c]
351
352
  if v.nil?
352
353
  attrs[:nil] = ''
353
354
  end
354
- x1.send(name_proc[c.to_s], v, attrs)
355
+ x1.public_send(name_proc[c.to_s], v, attrs)
355
356
  end
356
357
  if inc.is_a?(Hash)
357
358
  inc.each{|k, v| to_xml_include(x1, k, v)}
@@ -369,15 +370,15 @@ module Sequel
369
370
  # the xml.
370
371
  def to_xml_include(node, i, opts=OPTS)
371
372
  name_proc = model.xml_serialize_name_proc(opts)
372
- objs = send(i)
373
+ objs = public_send(i)
373
374
  if objs.is_a?(Array) && objs.all?{|x| x.is_a?(Sequel::Model)}
374
- node.send(name_proc[i.to_s]) do |x2|
375
+ node.public_send(name_proc[i.to_s]) do |x2|
375
376
  objs.each{|obj| obj.to_xml(opts.merge(:builder=>x2))}
376
377
  end
377
378
  elsif objs.is_a?(Sequel::Model)
378
379
  objs.to_xml(opts.merge(:builder=>node, :root_name=>i))
379
380
  else
380
- node.send(name_proc[i.to_s], objs)
381
+ node.public_send(name_proc[i.to_s], objs)
381
382
  end
382
383
  end
383
384
  end
@@ -388,7 +389,7 @@ module Sequel
388
389
  # as well as the :array_root_name option for specifying the name of
389
390
  # the root node that contains the nodes for all of the instances.
390
391
  def to_xml(opts=OPTS)
391
- raise(Sequel::Error, "Dataset#to_xml") unless row_proc
392
+ raise(Sequel::Error, "Dataset#to_xml") unless row_proc || @opts[:eager_graph]
392
393
  x = model.xml_builder(opts)
393
394
  name_proc = model.xml_serialize_name_proc(opts)
394
395
  array = if opts[:array]
@@ -397,7 +398,7 @@ module Sequel
397
398
  else
398
399
  all
399
400
  end
400
- x.send(name_proc[opts.fetch(:array_root_name, model.send(:pluralize, model.send(:underscore, model.name))).to_s]) do |x1|
401
+ x.public_send(name_proc[opts.fetch(:array_root_name, model.send(:pluralize, model.send(:underscore, model.name))).to_s]) do |x1|
401
402
  array.each do |obj|
402
403
  obj.to_xml(opts.merge(:builder=>x1))
403
404
  end