servus 0.3.0 → 0.4.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 (132) hide show
  1. checksums.yaml +4 -4
  2. data/lib/generators/servus/event_handler/event_handler_generator.rb +1 -1
  3. data/lib/generators/servus/guard/guard_generator.rb +1 -1
  4. data/lib/generators/servus/guard/templates/guard.rb.erb +5 -3
  5. data/lib/generators/servus/service/service_generator.rb +1 -1
  6. data/lib/servus/base.rb +46 -3
  7. data/lib/servus/config.rb +71 -3
  8. data/lib/servus/events/bus.rb +29 -0
  9. data/lib/servus/events/emitter.rb +15 -0
  10. data/lib/servus/guard.rb +7 -6
  11. data/lib/servus/guards/falsey_guard.rb +3 -3
  12. data/lib/servus/guards/presence_guard.rb +4 -4
  13. data/lib/servus/guards/state_guard.rb +4 -5
  14. data/lib/servus/guards/truthy_guard.rb +3 -3
  15. data/lib/servus/helpers/controller_helpers.rb +40 -0
  16. data/lib/servus/support/errors.rb +16 -0
  17. data/lib/servus/support/lockdown.rb +94 -0
  18. data/lib/servus/support/logger.rb +16 -0
  19. data/lib/servus/support/validator.rb +65 -34
  20. data/lib/servus/testing/example_builders.rb +52 -0
  21. data/lib/servus/testing/matchers.rb +99 -0
  22. data/lib/servus/version.rb +1 -1
  23. data/lib/servus.rb +1 -0
  24. metadata +7 -111
  25. data/.claude/commands/check-docs.md +0 -1
  26. data/.claude/commands/consistency-check.md +0 -1
  27. data/.claude/commands/fine-tooth-comb.md +0 -1
  28. data/.claude/commands/red-green-refactor.md +0 -5
  29. data/.claude/settings.json +0 -24
  30. data/.rspec +0 -3
  31. data/.rubocop.yml +0 -27
  32. data/.yardopts +0 -6
  33. data/CHANGELOG.md +0 -169
  34. data/CLAUDE.md +0 -10
  35. data/IDEAS.md +0 -5
  36. data/LICENSE.txt +0 -21
  37. data/READme.md +0 -856
  38. data/Rakefile +0 -45
  39. data/docs/core/1_overview.md +0 -81
  40. data/docs/core/2_architecture.md +0 -120
  41. data/docs/core/3_service_objects.md +0 -154
  42. data/docs/features/1_schema_validation.md +0 -161
  43. data/docs/features/2_error_handling.md +0 -129
  44. data/docs/features/3_async_execution.md +0 -81
  45. data/docs/features/4_logging.md +0 -64
  46. data/docs/features/5_event_bus.md +0 -244
  47. data/docs/features/6_guards.md +0 -356
  48. data/docs/features/7_lazy_resolvers.md +0 -238
  49. data/docs/features/guards_naming_convention.md +0 -540
  50. data/docs/guides/1_common_patterns.md +0 -90
  51. data/docs/guides/2_migration_guide.md +0 -225
  52. data/docs/integration/1_configuration.md +0 -154
  53. data/docs/integration/2_testing.md +0 -304
  54. data/docs/integration/3_rails_integration.md +0 -99
  55. data/docs/yard/Servus/Base.html +0 -1645
  56. data/docs/yard/Servus/Config.html +0 -582
  57. data/docs/yard/Servus/Extensions/Async/Call.html +0 -400
  58. data/docs/yard/Servus/Extensions/Async/Errors/AsyncError.html +0 -140
  59. data/docs/yard/Servus/Extensions/Async/Errors/JobEnqueueError.html +0 -154
  60. data/docs/yard/Servus/Extensions/Async/Errors/ServiceNotFoundError.html +0 -154
  61. data/docs/yard/Servus/Extensions/Async/Errors.html +0 -128
  62. data/docs/yard/Servus/Extensions/Async/Ext.html +0 -119
  63. data/docs/yard/Servus/Extensions/Async/Job.html +0 -310
  64. data/docs/yard/Servus/Extensions/Async.html +0 -141
  65. data/docs/yard/Servus/Extensions.html +0 -117
  66. data/docs/yard/Servus/Generators/ServiceGenerator.html +0 -261
  67. data/docs/yard/Servus/Generators.html +0 -115
  68. data/docs/yard/Servus/Helpers/ControllerHelpers.html +0 -457
  69. data/docs/yard/Servus/Helpers.html +0 -115
  70. data/docs/yard/Servus/Railtie.html +0 -134
  71. data/docs/yard/Servus/Support/Errors/AuthenticationError.html +0 -287
  72. data/docs/yard/Servus/Support/Errors/BadRequestError.html +0 -283
  73. data/docs/yard/Servus/Support/Errors/ForbiddenError.html +0 -284
  74. data/docs/yard/Servus/Support/Errors/InternalServerError.html +0 -283
  75. data/docs/yard/Servus/Support/Errors/NotFoundError.html +0 -284
  76. data/docs/yard/Servus/Support/Errors/ServiceError.html +0 -489
  77. data/docs/yard/Servus/Support/Errors/ServiceUnavailableError.html +0 -290
  78. data/docs/yard/Servus/Support/Errors/UnauthorizedError.html +0 -200
  79. data/docs/yard/Servus/Support/Errors/UnprocessableEntityError.html +0 -288
  80. data/docs/yard/Servus/Support/Errors/ValidationError.html +0 -200
  81. data/docs/yard/Servus/Support/Errors.html +0 -140
  82. data/docs/yard/Servus/Support/Logger.html +0 -856
  83. data/docs/yard/Servus/Support/Rescuer/BlockContext.html +0 -585
  84. data/docs/yard/Servus/Support/Rescuer/CallOverride.html +0 -257
  85. data/docs/yard/Servus/Support/Rescuer/ClassMethods.html +0 -343
  86. data/docs/yard/Servus/Support/Rescuer.html +0 -267
  87. data/docs/yard/Servus/Support/Response.html +0 -574
  88. data/docs/yard/Servus/Support/Validator.html +0 -1150
  89. data/docs/yard/Servus/Support.html +0 -119
  90. data/docs/yard/Servus/Testing/ExampleBuilders.html +0 -523
  91. data/docs/yard/Servus/Testing/ExampleExtractor.html +0 -578
  92. data/docs/yard/Servus/Testing.html +0 -142
  93. data/docs/yard/Servus.html +0 -343
  94. data/docs/yard/_index.html +0 -535
  95. data/docs/yard/class_list.html +0 -54
  96. data/docs/yard/css/common.css +0 -1
  97. data/docs/yard/css/full_list.css +0 -58
  98. data/docs/yard/css/style.css +0 -503
  99. data/docs/yard/file.1_common_patterns.html +0 -154
  100. data/docs/yard/file.1_configuration.html +0 -115
  101. data/docs/yard/file.1_overview.html +0 -142
  102. data/docs/yard/file.1_schema_validation.html +0 -188
  103. data/docs/yard/file.2_architecture.html +0 -157
  104. data/docs/yard/file.2_error_handling.html +0 -190
  105. data/docs/yard/file.2_migration_guide.html +0 -242
  106. data/docs/yard/file.2_testing.html +0 -227
  107. data/docs/yard/file.3_async_execution.html +0 -145
  108. data/docs/yard/file.3_rails_integration.html +0 -160
  109. data/docs/yard/file.3_service_objects.html +0 -191
  110. data/docs/yard/file.4_logging.html +0 -135
  111. data/docs/yard/file.ErrorHandling.html +0 -190
  112. data/docs/yard/file.READme.html +0 -674
  113. data/docs/yard/file.architecture.html +0 -157
  114. data/docs/yard/file.async_execution.html +0 -145
  115. data/docs/yard/file.common_patterns.html +0 -154
  116. data/docs/yard/file.configuration.html +0 -115
  117. data/docs/yard/file.error_handling.html +0 -190
  118. data/docs/yard/file.logging.html +0 -135
  119. data/docs/yard/file.migration_guide.html +0 -242
  120. data/docs/yard/file.overview.html +0 -142
  121. data/docs/yard/file.rails_integration.html +0 -160
  122. data/docs/yard/file.schema_validation.html +0 -188
  123. data/docs/yard/file.service_objects.html +0 -191
  124. data/docs/yard/file.testing.html +0 -227
  125. data/docs/yard/file_list.html +0 -119
  126. data/docs/yard/frames.html +0 -22
  127. data/docs/yard/index.html +0 -674
  128. data/docs/yard/js/app.js +0 -344
  129. data/docs/yard/js/full_list.js +0 -242
  130. data/docs/yard/js/jquery.js +0 -4
  131. data/docs/yard/method_list.html +0 -542
  132. data/docs/yard/top-level-namespace.html +0 -110
@@ -1,856 +0,0 @@
1
- <!DOCTYPE html>
2
- <html>
3
- <head>
4
- <meta charset="utf-8">
5
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
6
- <title>
7
- Class: Servus::Support::Logger
8
-
9
- &mdash; Servus | Service Object Framework
10
-
11
- </title>
12
-
13
- <link rel="stylesheet" href="../../css/style.css" type="text/css" />
14
-
15
- <link rel="stylesheet" href="../../css/common.css" type="text/css" />
16
-
17
- <script type="text/javascript">
18
- pathId = "Servus::Support::Logger";
19
- relpath = '../../';
20
- </script>
21
-
22
-
23
- <script type="text/javascript" charset="utf-8" src="../../js/jquery.js"></script>
24
-
25
- <script type="text/javascript" charset="utf-8" src="../../js/app.js"></script>
26
-
27
-
28
- </head>
29
- <body>
30
- <div class="nav_wrap">
31
- <iframe id="nav" src="../../class_list.html?1"></iframe>
32
- <div id="resizer"></div>
33
- </div>
34
-
35
- <div id="main" tabindex="-1">
36
- <div id="header">
37
- <div id="menu">
38
-
39
- <a href="../../_index.html">Index (L)</a> &raquo;
40
- <span class='title'><span class='object_link'><a href="../../Servus.html" title="Servus (module)">Servus</a></span></span> &raquo; <span class='title'><span class='object_link'><a href="../Support.html" title="Servus::Support (module)">Support</a></span></span>
41
- &raquo;
42
- <span class="title">Logger</span>
43
-
44
- </div>
45
-
46
- <div id="search">
47
-
48
- <a class="full_list_link" id="class_list_link"
49
- href="../../class_list.html">
50
-
51
- <svg width="24" height="24">
52
- <rect x="0" y="4" width="24" height="4" rx="1" ry="1"></rect>
53
- <rect x="0" y="12" width="24" height="4" rx="1" ry="1"></rect>
54
- <rect x="0" y="20" width="24" height="4" rx="1" ry="1"></rect>
55
- </svg>
56
- </a>
57
-
58
- </div>
59
- <div class="clear"></div>
60
- </div>
61
-
62
- <div id="content"><h1>Class: Servus::Support::Logger
63
-
64
-
65
-
66
- </h1>
67
- <div class="box_info">
68
-
69
- <dl>
70
- <dt>Inherits:</dt>
71
- <dd>
72
- <span class="inheritName">Object</span>
73
-
74
- <ul class="fullTree">
75
- <li>Object</li>
76
-
77
- <li class="next">Servus::Support::Logger</li>
78
-
79
- </ul>
80
- <a href="#" class="inheritanceTree">show all</a>
81
-
82
- </dd>
83
- </dl>
84
-
85
-
86
-
87
-
88
-
89
-
90
-
91
-
92
-
93
-
94
-
95
- <dl>
96
- <dt>Defined in:</dt>
97
- <dd>lib/servus/support/logger.rb</dd>
98
- </dl>
99
-
100
- </div>
101
-
102
- <h2>Overview</h2><div class="docstring">
103
- <div class="discussion">
104
- <p>Logger class for logging service calls and results</p>
105
-
106
-
107
- </div>
108
- </div>
109
- <div class="tags">
110
-
111
-
112
- </div>
113
-
114
-
115
-
116
-
117
-
118
-
119
-
120
- <h2>
121
- Class Method Summary
122
- <small><a href="#" class="summary_toggle">collapse</a></small>
123
- </h2>
124
-
125
- <ul class="summary">
126
-
127
- <li class="public ">
128
- <span class="summary_signature">
129
-
130
- <a href="#log_call-class_method" title="log_call (class method)">.<strong>log_call</strong>(service_class, args) &#x21d2; Object </a>
131
-
132
-
133
-
134
- </span>
135
-
136
-
137
-
138
-
139
-
140
-
141
-
142
-
143
-
144
- <span class="summary_desc"><div class='inline'><p>Logs a call to a service.</p>
145
- </div></span>
146
-
147
- </li>
148
-
149
-
150
- <li class="public ">
151
- <span class="summary_signature">
152
-
153
- <a href="#log_exception-class_method" title="log_exception (class method)">.<strong>log_exception</strong>(service_class, exception) &#x21d2; Object </a>
154
-
155
-
156
-
157
- </span>
158
-
159
-
160
-
161
-
162
-
163
-
164
-
165
-
166
-
167
- <span class="summary_desc"><div class='inline'><p>Logs an uncaught exception from a service.</p>
168
- </div></span>
169
-
170
- </li>
171
-
172
-
173
- <li class="public ">
174
- <span class="summary_signature">
175
-
176
- <a href="#log_failure-class_method" title="log_failure (class method)">.<strong>log_failure</strong>(service_class, error, duration) &#x21d2; Object </a>
177
-
178
-
179
-
180
- </span>
181
-
182
-
183
-
184
-
185
-
186
-
187
-
188
-
189
-
190
- <span class="summary_desc"><div class='inline'><p>Logs a failed result from a service.</p>
191
- </div></span>
192
-
193
- </li>
194
-
195
-
196
- <li class="public ">
197
- <span class="summary_signature">
198
-
199
- <a href="#log_result-class_method" title="log_result (class method)">.<strong>log_result</strong>(service_class, result, duration) &#x21d2; Object </a>
200
-
201
-
202
-
203
- </span>
204
-
205
-
206
-
207
-
208
-
209
-
210
-
211
-
212
-
213
- <span class="summary_desc"><div class='inline'><p>Logs a result from a service.</p>
214
- </div></span>
215
-
216
- </li>
217
-
218
-
219
- <li class="public ">
220
- <span class="summary_signature">
221
-
222
- <a href="#log_success-class_method" title="log_success (class method)">.<strong>log_success</strong>(service_class, duration) &#x21d2; Object </a>
223
-
224
-
225
-
226
- </span>
227
-
228
-
229
-
230
-
231
-
232
-
233
-
234
-
235
-
236
- <span class="summary_desc"><div class='inline'><p>Logs a successful result from a service.</p>
237
- </div></span>
238
-
239
- </li>
240
-
241
-
242
- <li class="public ">
243
- <span class="summary_signature">
244
-
245
- <a href="#log_validation_error-class_method" title="log_validation_error (class method)">.<strong>log_validation_error</strong>(service_class, error) &#x21d2; Object </a>
246
-
247
-
248
-
249
- </span>
250
-
251
-
252
-
253
-
254
-
255
-
256
-
257
-
258
-
259
- <span class="summary_desc"><div class='inline'><p>Logs a validation error from a service.</p>
260
- </div></span>
261
-
262
- </li>
263
-
264
-
265
- <li class="public ">
266
- <span class="summary_signature">
267
-
268
- <a href="#logger-class_method" title="logger (class method)">.<strong>logger</strong> &#x21d2; Logger </a>
269
-
270
-
271
-
272
- </span>
273
-
274
-
275
-
276
-
277
-
278
-
279
-
280
-
281
-
282
- <span class="summary_desc"><div class='inline'><p>Returns the logger instance depending on the environment.</p>
283
- </div></span>
284
-
285
- </li>
286
-
287
-
288
- </ul>
289
-
290
-
291
-
292
-
293
- <div id="class_method_details" class="method_details_list">
294
- <h2>Class Method Details</h2>
295
-
296
-
297
- <div class="method_details first">
298
- <h3 class="signature first" id="log_call-class_method">
299
-
300
- .<strong>log_call</strong>(service_class, args) &#x21d2; <tt>Object</tt>
301
-
302
-
303
-
304
-
305
-
306
- </h3><div class="docstring">
307
- <div class="discussion">
308
- <p>Logs a call to a service</p>
309
-
310
-
311
- </div>
312
- </div>
313
- <div class="tags">
314
- <p class="tag_title">Parameters:</p>
315
- <ul class="param">
316
-
317
- <li>
318
-
319
- <span class='name'>service_class</span>
320
-
321
-
322
- <span class='type'>(<tt>Class</tt>)</span>
323
-
324
-
325
-
326
- &mdash;
327
- <div class='inline'><p>The service class</p>
328
- </div>
329
-
330
- </li>
331
-
332
- <li>
333
-
334
- <span class='name'>args</span>
335
-
336
-
337
- <span class='type'>(<tt>Hash</tt>)</span>
338
-
339
-
340
-
341
- &mdash;
342
- <div class='inline'><p>The arguments passed to the service</p>
343
- </div>
344
-
345
- </li>
346
-
347
- </ul>
348
-
349
-
350
- </div><table class="source_code">
351
- <tr>
352
- <td>
353
- <pre class="lines">
354
-
355
-
356
- 24
357
- 25
358
- 26</pre>
359
- </td>
360
- <td>
361
- <pre class="code"><span class="info file"># File 'lib/servus/support/logger.rb', line 24</span>
362
-
363
- <span class='kw'>def</span> <span class='kw'>self</span><span class='period'>.</span><span class='id identifier rubyid_log_call'>log_call</span><span class='lparen'>(</span><span class='id identifier rubyid_service_class'>service_class</span><span class='comma'>,</span> <span class='id identifier rubyid_args'>args</span><span class='rparen'>)</span>
364
- <span class='id identifier rubyid_logger'>logger</span><span class='period'>.</span><span class='id identifier rubyid_info'>info</span><span class='lparen'>(</span><span class='tstring'><span class='tstring_beg'>&quot;</span><span class='tstring_content'>Calling </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_service_class'>service_class</span><span class='period'>.</span><span class='id identifier rubyid_name'>name</span><span class='embexpr_end'>}</span><span class='tstring_content'> with args: </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_args'>args</span><span class='period'>.</span><span class='id identifier rubyid_inspect'>inspect</span><span class='embexpr_end'>}</span><span class='tstring_end'>&quot;</span></span><span class='rparen'>)</span>
365
- <span class='kw'>end</span></pre>
366
- </td>
367
- </tr>
368
- </table>
369
- </div>
370
-
371
- <div class="method_details ">
372
- <h3 class="signature " id="log_exception-class_method">
373
-
374
- .<strong>log_exception</strong>(service_class, exception) &#x21d2; <tt>Object</tt>
375
-
376
-
377
-
378
-
379
-
380
- </h3><div class="docstring">
381
- <div class="discussion">
382
- <p>Logs an uncaught exception from a service</p>
383
-
384
-
385
- </div>
386
- </div>
387
- <div class="tags">
388
- <p class="tag_title">Parameters:</p>
389
- <ul class="param">
390
-
391
- <li>
392
-
393
- <span class='name'>service_class</span>
394
-
395
-
396
- <span class='type'>(<tt>Class</tt>)</span>
397
-
398
-
399
-
400
- &mdash;
401
- <div class='inline'><p>The service class</p>
402
- </div>
403
-
404
- </li>
405
-
406
- <li>
407
-
408
- <span class='name'>exception</span>
409
-
410
-
411
- <span class='type'>(<tt>Exception</tt>)</span>
412
-
413
-
414
-
415
- &mdash;
416
- <div class='inline'><p>The uncaught exception</p>
417
- </div>
418
-
419
- </li>
420
-
421
- </ul>
422
-
423
-
424
- </div><table class="source_code">
425
- <tr>
426
- <td>
427
- <pre class="lines">
428
-
429
-
430
- 70
431
- 71
432
- 72</pre>
433
- </td>
434
- <td>
435
- <pre class="code"><span class="info file"># File 'lib/servus/support/logger.rb', line 70</span>
436
-
437
- <span class='kw'>def</span> <span class='kw'>self</span><span class='period'>.</span><span class='id identifier rubyid_log_exception'>log_exception</span><span class='lparen'>(</span><span class='id identifier rubyid_service_class'>service_class</span><span class='comma'>,</span> <span class='id identifier rubyid_exception'>exception</span><span class='rparen'>)</span>
438
- <span class='id identifier rubyid_logger'>logger</span><span class='period'>.</span><span class='id identifier rubyid_error'>error</span><span class='lparen'>(</span><span class='tstring'><span class='tstring_beg'>&quot;</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_service_class'>service_class</span><span class='period'>.</span><span class='id identifier rubyid_name'>name</span><span class='embexpr_end'>}</span><span class='tstring_content'> uncaught exception: </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_exception'>exception</span><span class='period'>.</span><span class='id identifier rubyid_class'>class</span><span class='embexpr_end'>}</span><span class='tstring_content'> - </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_exception'>exception</span><span class='period'>.</span><span class='id identifier rubyid_message'>message</span><span class='embexpr_end'>}</span><span class='tstring_end'>&quot;</span></span><span class='rparen'>)</span>
439
- <span class='kw'>end</span></pre>
440
- </td>
441
- </tr>
442
- </table>
443
- </div>
444
-
445
- <div class="method_details ">
446
- <h3 class="signature " id="log_failure-class_method">
447
-
448
- .<strong>log_failure</strong>(service_class, error, duration) &#x21d2; <tt>Object</tt>
449
-
450
-
451
-
452
-
453
-
454
- </h3><div class="docstring">
455
- <div class="discussion">
456
- <p>Logs a failed result from a service</p>
457
-
458
-
459
- </div>
460
- </div>
461
- <div class="tags">
462
- <p class="tag_title">Parameters:</p>
463
- <ul class="param">
464
-
465
- <li>
466
-
467
- <span class='name'>service_class</span>
468
-
469
-
470
- <span class='type'>(<tt>Class</tt>)</span>
471
-
472
-
473
-
474
- &mdash;
475
- <div class='inline'><p>The service class</p>
476
- </div>
477
-
478
- </li>
479
-
480
- <li>
481
-
482
- <span class='name'>error</span>
483
-
484
-
485
- <span class='type'>(<tt><span class='object_link'><a href="Errors/ServiceError.html" title="Servus::Support::Errors::ServiceError (class)">Servus::Support::Errors::ServiceError</a></span></tt>)</span>
486
-
487
-
488
-
489
- &mdash;
490
- <div class='inline'><p>The error from the service</p>
491
- </div>
492
-
493
- </li>
494
-
495
- <li>
496
-
497
- <span class='name'>duration</span>
498
-
499
-
500
- <span class='type'>(<tt>Float</tt>)</span>
501
-
502
-
503
-
504
- &mdash;
505
- <div class='inline'><p>The duration of the service call</p>
506
- </div>
507
-
508
- </li>
509
-
510
- </ul>
511
-
512
-
513
- </div><table class="source_code">
514
- <tr>
515
- <td>
516
- <pre class="lines">
517
-
518
-
519
- 54
520
- 55
521
- 56</pre>
522
- </td>
523
- <td>
524
- <pre class="code"><span class="info file"># File 'lib/servus/support/logger.rb', line 54</span>
525
-
526
- <span class='kw'>def</span> <span class='kw'>self</span><span class='period'>.</span><span class='id identifier rubyid_log_failure'>log_failure</span><span class='lparen'>(</span><span class='id identifier rubyid_service_class'>service_class</span><span class='comma'>,</span> <span class='id identifier rubyid_error'>error</span><span class='comma'>,</span> <span class='id identifier rubyid_duration'>duration</span><span class='rparen'>)</span>
527
- <span class='id identifier rubyid_logger'>logger</span><span class='period'>.</span><span class='id identifier rubyid_warn'>warn</span><span class='lparen'>(</span><span class='tstring'><span class='tstring_beg'>&quot;</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_service_class'>service_class</span><span class='period'>.</span><span class='id identifier rubyid_name'>name</span><span class='embexpr_end'>}</span><span class='tstring_content'> failed in </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_duration'>duration</span><span class='period'>.</span><span class='id identifier rubyid_round'>round</span><span class='lparen'>(</span><span class='int'>3</span><span class='rparen'>)</span><span class='embexpr_end'>}</span><span class='tstring_content'>s with error: </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_error'>error</span><span class='embexpr_end'>}</span><span class='tstring_end'>&quot;</span></span><span class='rparen'>)</span>
528
- <span class='kw'>end</span></pre>
529
- </td>
530
- </tr>
531
- </table>
532
- </div>
533
-
534
- <div class="method_details ">
535
- <h3 class="signature " id="log_result-class_method">
536
-
537
- .<strong>log_result</strong>(service_class, result, duration) &#x21d2; <tt>Object</tt>
538
-
539
-
540
-
541
-
542
-
543
- </h3><div class="docstring">
544
- <div class="discussion">
545
- <p>Logs a result from a service</p>
546
-
547
-
548
- </div>
549
- </div>
550
- <div class="tags">
551
- <p class="tag_title">Parameters:</p>
552
- <ul class="param">
553
-
554
- <li>
555
-
556
- <span class='name'>service_class</span>
557
-
558
-
559
- <span class='type'>(<tt>Class</tt>)</span>
560
-
561
-
562
-
563
- &mdash;
564
- <div class='inline'><p>The service class</p>
565
- </div>
566
-
567
- </li>
568
-
569
- <li>
570
-
571
- <span class='name'>result</span>
572
-
573
-
574
- <span class='type'>(<tt><span class='object_link'><a href="Response.html" title="Servus::Support::Response (class)">Servus::Support::Response</a></span></tt>)</span>
575
-
576
-
577
-
578
- &mdash;
579
- <div class='inline'><p>The result from the service</p>
580
- </div>
581
-
582
- </li>
583
-
584
- <li>
585
-
586
- <span class='name'>duration</span>
587
-
588
-
589
- <span class='type'>(<tt>Float</tt>)</span>
590
-
591
-
592
-
593
- &mdash;
594
- <div class='inline'><p>The duration of the service call</p>
595
- </div>
596
-
597
- </li>
598
-
599
- </ul>
600
-
601
-
602
- </div><table class="source_code">
603
- <tr>
604
- <td>
605
- <pre class="lines">
606
-
607
-
608
- 33
609
- 34
610
- 35
611
- 36
612
- 37
613
- 38
614
- 39</pre>
615
- </td>
616
- <td>
617
- <pre class="code"><span class="info file"># File 'lib/servus/support/logger.rb', line 33</span>
618
-
619
- <span class='kw'>def</span> <span class='kw'>self</span><span class='period'>.</span><span class='id identifier rubyid_log_result'>log_result</span><span class='lparen'>(</span><span class='id identifier rubyid_service_class'>service_class</span><span class='comma'>,</span> <span class='id identifier rubyid_result'>result</span><span class='comma'>,</span> <span class='id identifier rubyid_duration'>duration</span><span class='rparen'>)</span>
620
- <span class='kw'>if</span> <span class='id identifier rubyid_result'>result</span><span class='period'>.</span><span class='id identifier rubyid_success?'>success?</span>
621
- <span class='id identifier rubyid_log_success'>log_success</span><span class='lparen'>(</span><span class='id identifier rubyid_service_class'>service_class</span><span class='comma'>,</span> <span class='id identifier rubyid_duration'>duration</span><span class='rparen'>)</span>
622
- <span class='kw'>else</span>
623
- <span class='id identifier rubyid_log_failure'>log_failure</span><span class='lparen'>(</span><span class='id identifier rubyid_service_class'>service_class</span><span class='comma'>,</span> <span class='id identifier rubyid_result'>result</span><span class='period'>.</span><span class='id identifier rubyid_error'>error</span><span class='comma'>,</span> <span class='id identifier rubyid_duration'>duration</span><span class='rparen'>)</span>
624
- <span class='kw'>end</span>
625
- <span class='kw'>end</span></pre>
626
- </td>
627
- </tr>
628
- </table>
629
- </div>
630
-
631
- <div class="method_details ">
632
- <h3 class="signature " id="log_success-class_method">
633
-
634
- .<strong>log_success</strong>(service_class, duration) &#x21d2; <tt>Object</tt>
635
-
636
-
637
-
638
-
639
-
640
- </h3><div class="docstring">
641
- <div class="discussion">
642
- <p>Logs a successful result from a service</p>
643
-
644
-
645
- </div>
646
- </div>
647
- <div class="tags">
648
- <p class="tag_title">Parameters:</p>
649
- <ul class="param">
650
-
651
- <li>
652
-
653
- <span class='name'>service_class</span>
654
-
655
-
656
- <span class='type'>(<tt>Class</tt>)</span>
657
-
658
-
659
-
660
- &mdash;
661
- <div class='inline'><p>The service class</p>
662
- </div>
663
-
664
- </li>
665
-
666
- <li>
667
-
668
- <span class='name'>duration</span>
669
-
670
-
671
- <span class='type'>(<tt>Float</tt>)</span>
672
-
673
-
674
-
675
- &mdash;
676
- <div class='inline'><p>The duration of the service call</p>
677
- </div>
678
-
679
- </li>
680
-
681
- </ul>
682
-
683
-
684
- </div><table class="source_code">
685
- <tr>
686
- <td>
687
- <pre class="lines">
688
-
689
-
690
- 45
691
- 46
692
- 47</pre>
693
- </td>
694
- <td>
695
- <pre class="code"><span class="info file"># File 'lib/servus/support/logger.rb', line 45</span>
696
-
697
- <span class='kw'>def</span> <span class='kw'>self</span><span class='period'>.</span><span class='id identifier rubyid_log_success'>log_success</span><span class='lparen'>(</span><span class='id identifier rubyid_service_class'>service_class</span><span class='comma'>,</span> <span class='id identifier rubyid_duration'>duration</span><span class='rparen'>)</span>
698
- <span class='id identifier rubyid_logger'>logger</span><span class='period'>.</span><span class='id identifier rubyid_info'>info</span><span class='lparen'>(</span><span class='tstring'><span class='tstring_beg'>&quot;</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_service_class'>service_class</span><span class='period'>.</span><span class='id identifier rubyid_name'>name</span><span class='embexpr_end'>}</span><span class='tstring_content'> succeeded in </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_duration'>duration</span><span class='period'>.</span><span class='id identifier rubyid_round'>round</span><span class='lparen'>(</span><span class='int'>3</span><span class='rparen'>)</span><span class='embexpr_end'>}</span><span class='tstring_content'>s</span><span class='tstring_end'>&quot;</span></span><span class='rparen'>)</span>
699
- <span class='kw'>end</span></pre>
700
- </td>
701
- </tr>
702
- </table>
703
- </div>
704
-
705
- <div class="method_details ">
706
- <h3 class="signature " id="log_validation_error-class_method">
707
-
708
- .<strong>log_validation_error</strong>(service_class, error) &#x21d2; <tt>Object</tt>
709
-
710
-
711
-
712
-
713
-
714
- </h3><div class="docstring">
715
- <div class="discussion">
716
- <p>Logs a validation error from a service</p>
717
-
718
-
719
- </div>
720
- </div>
721
- <div class="tags">
722
- <p class="tag_title">Parameters:</p>
723
- <ul class="param">
724
-
725
- <li>
726
-
727
- <span class='name'>service_class</span>
728
-
729
-
730
- <span class='type'>(<tt>Class</tt>)</span>
731
-
732
-
733
-
734
- &mdash;
735
- <div class='inline'><p>The service class</p>
736
- </div>
737
-
738
- </li>
739
-
740
- <li>
741
-
742
- <span class='name'>error</span>
743
-
744
-
745
- <span class='type'>(<tt><span class='object_link'><a href="Errors/ValidationError.html" title="Servus::Support::Errors::ValidationError (class)">Servus::Support::Errors::ValidationError</a></span></tt>)</span>
746
-
747
-
748
-
749
- &mdash;
750
- <div class='inline'><p>The validation error</p>
751
- </div>
752
-
753
- </li>
754
-
755
- </ul>
756
-
757
-
758
- </div><table class="source_code">
759
- <tr>
760
- <td>
761
- <pre class="lines">
762
-
763
-
764
- 62
765
- 63
766
- 64</pre>
767
- </td>
768
- <td>
769
- <pre class="code"><span class="info file"># File 'lib/servus/support/logger.rb', line 62</span>
770
-
771
- <span class='kw'>def</span> <span class='kw'>self</span><span class='period'>.</span><span class='id identifier rubyid_log_validation_error'>log_validation_error</span><span class='lparen'>(</span><span class='id identifier rubyid_service_class'>service_class</span><span class='comma'>,</span> <span class='id identifier rubyid_error'>error</span><span class='rparen'>)</span>
772
- <span class='id identifier rubyid_logger'>logger</span><span class='period'>.</span><span class='id identifier rubyid_error'>error</span><span class='lparen'>(</span><span class='tstring'><span class='tstring_beg'>&quot;</span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_service_class'>service_class</span><span class='period'>.</span><span class='id identifier rubyid_name'>name</span><span class='embexpr_end'>}</span><span class='tstring_content'> validation error: </span><span class='embexpr_beg'>#{</span><span class='id identifier rubyid_error'>error</span><span class='period'>.</span><span class='id identifier rubyid_message'>message</span><span class='embexpr_end'>}</span><span class='tstring_end'>&quot;</span></span><span class='rparen'>)</span>
773
- <span class='kw'>end</span></pre>
774
- </td>
775
- </tr>
776
- </table>
777
- </div>
778
-
779
- <div class="method_details ">
780
- <h3 class="signature " id="logger-class_method">
781
-
782
- .<strong>logger</strong> &#x21d2; <tt><span class='object_link'><a href="" title="Servus::Support::Logger (class)">Logger</a></span></tt>
783
-
784
-
785
-
786
-
787
-
788
- </h3><div class="docstring">
789
- <div class="discussion">
790
- <p>Returns the logger instance depending on the environment</p>
791
-
792
-
793
- </div>
794
- </div>
795
- <div class="tags">
796
-
797
- <p class="tag_title">Returns:</p>
798
- <ul class="return">
799
-
800
- <li>
801
-
802
-
803
- <span class='type'>(<tt><span class='object_link'><a href="" title="Servus::Support::Logger (class)">Logger</a></span></tt>)</span>
804
-
805
-
806
-
807
- &mdash;
808
- <div class='inline'><p>The logger instance</p>
809
- </div>
810
-
811
- </li>
812
-
813
- </ul>
814
-
815
- </div><table class="source_code">
816
- <tr>
817
- <td>
818
- <pre class="lines">
819
-
820
-
821
- 12
822
- 13
823
- 14
824
- 15
825
- 16
826
- 17
827
- 18</pre>
828
- </td>
829
- <td>
830
- <pre class="code"><span class="info file"># File 'lib/servus/support/logger.rb', line 12</span>
831
-
832
- <span class='kw'>def</span> <span class='kw'>self</span><span class='period'>.</span><span class='id identifier rubyid_logger'>logger</span>
833
- <span class='kw'>if</span> <span class='kw'>defined?</span><span class='lparen'>(</span><span class='const'>Rails</span><span class='rparen'>)</span> <span class='op'>&amp;&amp;</span> <span class='const'>Rails</span><span class='period'>.</span><span class='id identifier rubyid_respond_to?'>respond_to?</span><span class='lparen'>(</span><span class='symbol'>:logger</span><span class='rparen'>)</span> <span class='op'>&amp;&amp;</span> <span class='const'>Rails</span><span class='period'>.</span><span class='id identifier rubyid_logger'>logger</span>
834
- <span class='const'>Rails</span><span class='period'>.</span><span class='id identifier rubyid_logger'>logger</span>
835
- <span class='kw'>else</span>
836
- <span class='ivar'>@logger</span> <span class='op'>||=</span> <span class='op'>::</span><span class='const'>Logger</span><span class='period'>.</span><span class='id identifier rubyid_new'>new</span><span class='lparen'>(</span><span class='gvar'>$stdout</span><span class='rparen'>)</span>
837
- <span class='kw'>end</span>
838
- <span class='kw'>end</span></pre>
839
- </td>
840
- </tr>
841
- </table>
842
- </div>
843
-
844
- </div>
845
-
846
- </div>
847
-
848
- <div id="footer">
849
- Generated on Fri Nov 21 00:33:24 2025 by
850
- <a href="https://yardoc.org" title="Yay! A Ruby Documentation Tool" target="_parent">yard</a>
851
- 0.9.37 (ruby-3.4.4).
852
- </div>
853
-
854
- </div>
855
- </body>
856
- </html>