makit 0.0.158 → 0.0.162

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 (180) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +41 -41
  3. data/exe/makit +5 -5
  4. data/lib/makit/apache.rb +28 -28
  5. data/lib/makit/auto.rb +48 -48
  6. data/lib/makit/azure/blob_storage.rb +257 -257
  7. data/lib/makit/azure/cli.rb +284 -284
  8. data/lib/makit/cli/base.rb +17 -17
  9. data/lib/makit/cli/build_commands.rb +500 -500
  10. data/lib/makit/cli/generators/base_generator.rb +74 -74
  11. data/lib/makit/cli/generators/dotnet_generator.rb +50 -50
  12. data/lib/makit/cli/generators/generator_factory.rb +49 -49
  13. data/lib/makit/cli/generators/node_generator.rb +50 -50
  14. data/lib/makit/cli/generators/ruby_generator.rb +77 -77
  15. data/lib/makit/cli/generators/rust_generator.rb +50 -50
  16. data/lib/makit/cli/generators/templates/dotnet_templates.rb +167 -167
  17. data/lib/makit/cli/generators/templates/node_templates.rb +161 -161
  18. data/lib/makit/cli/generators/templates/ruby/gemfile.rb +26 -26
  19. data/lib/makit/cli/generators/templates/ruby/gemspec.rb +41 -41
  20. data/lib/makit/cli/generators/templates/ruby/main_lib.rb +33 -33
  21. data/lib/makit/cli/generators/templates/ruby/rakefile.rb +35 -35
  22. data/lib/makit/cli/generators/templates/ruby/readme.rb +63 -63
  23. data/lib/makit/cli/generators/templates/ruby/test.rb +39 -39
  24. data/lib/makit/cli/generators/templates/ruby/test_helper.rb +29 -29
  25. data/lib/makit/cli/generators/templates/ruby/version.rb +29 -29
  26. data/lib/makit/cli/generators/templates/rust_templates.rb +128 -128
  27. data/lib/makit/cli/main.rb +78 -78
  28. data/lib/makit/cli/pipeline_commands.rb +311 -311
  29. data/lib/makit/cli/project_commands.rb +868 -868
  30. data/lib/makit/cli/repository_commands.rb +661 -661
  31. data/lib/makit/cli/strategy_commands.rb +207 -207
  32. data/lib/makit/cli/utility_commands.rb +521 -521
  33. data/lib/makit/commands/factory.rb +359 -359
  34. data/lib/makit/commands/middleware/base.rb +73 -73
  35. data/lib/makit/commands/middleware/cache.rb +248 -248
  36. data/lib/makit/commands/middleware/command_logger.rb +312 -312
  37. data/lib/makit/commands/middleware/validator.rb +269 -269
  38. data/lib/makit/commands/request.rb +316 -316
  39. data/lib/makit/commands/result.rb +323 -323
  40. data/lib/makit/commands/runner.rb +386 -386
  41. data/lib/makit/commands/strategies/base.rb +171 -171
  42. data/lib/makit/commands/strategies/child_process.rb +162 -162
  43. data/lib/makit/commands/strategies/factory.rb +136 -136
  44. data/lib/makit/commands/strategies/synchronous.rb +139 -139
  45. data/lib/makit/commands.rb +50 -50
  46. data/lib/makit/configuration/dotnet_project.rb +48 -48
  47. data/lib/makit/configuration/gitlab_helper.rb +61 -61
  48. data/lib/makit/configuration/project.rb +292 -292
  49. data/lib/makit/configuration/rakefile_helper.rb +43 -43
  50. data/lib/makit/configuration/step.rb +34 -34
  51. data/lib/makit/configuration/timeout.rb +74 -74
  52. data/lib/makit/configuration.rb +21 -21
  53. data/lib/makit/content/default_gitignore.rb +7 -7
  54. data/lib/makit/content/default_gitignore.txt +225 -225
  55. data/lib/makit/content/default_rakefile.rb +13 -13
  56. data/lib/makit/content/gem_rakefile.rb +16 -16
  57. data/lib/makit/context.rb +1 -1
  58. data/lib/makit/data.rb +49 -49
  59. data/lib/makit/directories.rb +170 -170
  60. data/lib/makit/directory.rb +262 -262
  61. data/lib/makit/docs/files.rb +89 -89
  62. data/lib/makit/docs/rake.rb +102 -102
  63. data/lib/makit/dotnet/cli.rb +69 -69
  64. data/lib/makit/dotnet/project.rb +217 -217
  65. data/lib/makit/dotnet/solution.rb +38 -38
  66. data/lib/makit/dotnet/solution_classlib.rb +239 -239
  67. data/lib/makit/dotnet/solution_console.rb +264 -264
  68. data/lib/makit/dotnet/solution_maui.rb +354 -354
  69. data/lib/makit/dotnet/solution_wasm.rb +275 -275
  70. data/lib/makit/dotnet/solution_wpf.rb +304 -304
  71. data/lib/makit/dotnet.rb +102 -102
  72. data/lib/makit/email.rb +90 -90
  73. data/lib/makit/environment.rb +142 -142
  74. data/lib/makit/examples/runner.rb +370 -370
  75. data/lib/makit/exceptions.rb +45 -45
  76. data/lib/makit/fileinfo.rb +32 -32
  77. data/lib/makit/files.rb +43 -43
  78. data/lib/makit/gems.rb +49 -40
  79. data/lib/makit/git/cli.rb +103 -78
  80. data/lib/makit/git/repository.rb +100 -100
  81. data/lib/makit/git.rb +104 -104
  82. data/lib/makit/gitlab/pipeline.rb +857 -857
  83. data/lib/makit/gitlab/pipeline_service_impl.rb +1535 -1535
  84. data/lib/makit/gitlab_runner.rb +59 -59
  85. data/lib/makit/humanize.rb +218 -218
  86. data/lib/makit/indexer.rb +47 -47
  87. data/lib/makit/io/filesystem.rb +111 -111
  88. data/lib/makit/io/filesystem_service_impl.rb +337 -337
  89. data/lib/makit/lint.rb +212 -212
  90. data/lib/makit/logging/configuration.rb +309 -309
  91. data/lib/makit/logging/format_registry.rb +84 -84
  92. data/lib/makit/logging/formatters/base.rb +39 -39
  93. data/lib/makit/logging/formatters/console_formatter.rb +140 -140
  94. data/lib/makit/logging/formatters/json_formatter.rb +65 -65
  95. data/lib/makit/logging/formatters/plain_text_formatter.rb +71 -71
  96. data/lib/makit/logging/formatters/text_formatter.rb +64 -64
  97. data/lib/makit/logging/log_request.rb +119 -119
  98. data/lib/makit/logging/logger.rb +199 -199
  99. data/lib/makit/logging/sinks/base.rb +91 -91
  100. data/lib/makit/logging/sinks/console.rb +72 -72
  101. data/lib/makit/logging/sinks/file_sink.rb +92 -92
  102. data/lib/makit/logging/sinks/structured.rb +123 -123
  103. data/lib/makit/logging/sinks/unified_file_sink.rb +296 -296
  104. data/lib/makit/logging.rb +578 -578
  105. data/lib/makit/markdown.rb +75 -75
  106. data/lib/makit/mp/basic_object_mp.rb +17 -17
  107. data/lib/makit/mp/command_mp.rb +13 -13
  108. data/lib/makit/mp/command_request.mp.rb +17 -17
  109. data/lib/makit/mp/project_mp.rb +199 -199
  110. data/lib/makit/mp/string_mp.rb +205 -205
  111. data/lib/makit/nuget.rb +243 -74
  112. data/lib/makit/nuget_cache.rb +123 -0
  113. data/lib/makit/podman/podman.rb +458 -458
  114. data/lib/makit/podman/podman_service_impl.rb +1081 -1081
  115. data/lib/makit/port.rb +32 -32
  116. data/lib/makit/port_utility.rb +128 -0
  117. data/lib/makit/process.rb +377 -377
  118. data/lib/makit/protoc.rb +112 -112
  119. data/lib/makit/rake/cli.rb +196 -196
  120. data/lib/makit/rake/trace_controller.rb +174 -174
  121. data/lib/makit/rake.rb +81 -81
  122. data/lib/makit/ruby/cli.rb +185 -185
  123. data/lib/makit/ruby.rb +25 -25
  124. data/lib/makit/rubygems.rb +137 -137
  125. data/lib/makit/secrets/azure_key_vault.rb +322 -322
  126. data/lib/makit/secrets/azure_secrets.rb +183 -183
  127. data/lib/makit/secrets/local_secrets.rb +72 -72
  128. data/lib/makit/secrets/secrets_manager.rb +105 -105
  129. data/lib/makit/secrets.rb +16 -16
  130. data/lib/makit/serializer.rb +130 -130
  131. data/lib/makit/services/builder.rb +186 -186
  132. data/lib/makit/services/error_handler.rb +226 -226
  133. data/lib/makit/services/repository_manager.rb +367 -367
  134. data/lib/makit/services/validator.rb +112 -112
  135. data/lib/makit/setup/classlib.rb +101 -101
  136. data/lib/makit/setup/gem.rb +268 -268
  137. data/lib/makit/setup/pages.rb +11 -11
  138. data/lib/makit/setup/razorclasslib.rb +101 -101
  139. data/lib/makit/setup/runner.rb +54 -54
  140. data/lib/makit/setup.rb +5 -5
  141. data/lib/makit/show.rb +110 -110
  142. data/lib/makit/storage.rb +126 -126
  143. data/lib/makit/symbols.rb +175 -175
  144. data/lib/makit/task_info.rb +130 -130
  145. data/lib/makit/tasks/at_exit.rb +15 -15
  146. data/lib/makit/tasks/build.rb +22 -22
  147. data/lib/makit/tasks/bump.rb +7 -7
  148. data/lib/makit/tasks/clean.rb +13 -13
  149. data/lib/makit/tasks/configure.rb +10 -10
  150. data/lib/makit/tasks/format.rb +10 -10
  151. data/lib/makit/tasks/hook_manager.rb +443 -443
  152. data/lib/makit/tasks/info.rb +368 -368
  153. data/lib/makit/tasks/init.rb +49 -49
  154. data/lib/makit/tasks/integrate.rb +60 -60
  155. data/lib/makit/tasks/pull_incoming.rb +13 -13
  156. data/lib/makit/tasks/secrets.rb +7 -7
  157. data/lib/makit/tasks/setup.rb +16 -16
  158. data/lib/makit/tasks/sync.rb +14 -14
  159. data/lib/makit/tasks/tag.rb +27 -27
  160. data/lib/makit/tasks/task_monkey_patch.rb +81 -81
  161. data/lib/makit/tasks/test.rb +22 -22
  162. data/lib/makit/tasks/update.rb +21 -18
  163. data/lib/makit/tasks/version.rb +6 -6
  164. data/lib/makit/tasks.rb +24 -24
  165. data/lib/makit/test_cache.rb +239 -239
  166. data/lib/makit/tree.rb +37 -37
  167. data/lib/makit/v1/configuration/project_service_impl.rb +370 -370
  168. data/lib/makit/v1/git/git_repository_service_impl.rb +295 -295
  169. data/lib/makit/v1/makit.v1_pb.rb +35 -35
  170. data/lib/makit/v1/makit.v1_services_pb.rb +27 -27
  171. data/lib/makit/v1/services/repository_manager_service_impl.rb +572 -572
  172. data/lib/makit/version.rb +661 -661
  173. data/lib/makit/version_util.rb +21 -21
  174. data/lib/makit/wix.rb +95 -95
  175. data/lib/makit/yaml.rb +29 -29
  176. data/lib/makit/zip.rb +17 -17
  177. data/lib/makit/zip_utility.rb +97 -0
  178. data/lib/makit copy.rb +44 -44
  179. data/lib/makit.rb +119 -115
  180. metadata +5 -2
@@ -1,359 +1,359 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative "request"
4
-
5
- module Makit
6
- module Commands
7
- # Factory for creating common command requests.
8
- #
9
- # This factory provides convenient methods for creating Request objects
10
- # for common operations like git commands, bundle operations, rake tasks,
11
- # and system utilities.
12
- #
13
- # @example Creating git commands
14
- # request = Factory.git_clone("https://github.com/user/repo.git", "/path/to/clone")
15
- # request = Factory.git_status("/path/to/repo")
16
- #
17
- # @example Creating Ruby commands
18
- # request = Factory.bundle_install("/path/to/project")
19
- # request = Factory.rake_task("test", "/path/to/project")
20
- class Factory
21
- # Create a git clone request.
22
- #
23
- # @param repository_url [String] git repository URL
24
- # @param target_directory [String, nil] target directory (optional)
25
- # @param options [Hash] additional options
26
- # @option options [Integer] :timeout (300) timeout in seconds
27
- # @option options [Hash] :metadata additional metadata
28
- # @return [Request] git clone request
29
- def self.git_clone(repository_url, target_directory = nil, **options)
30
- arguments = ["clone", repository_url]
31
- arguments << target_directory if target_directory
32
-
33
- Request.new(
34
- command: "git",
35
- arguments: arguments,
36
- timeout: options.fetch(:timeout, 300),
37
- metadata: {
38
- operation: "git_clone",
39
- repository: repository_url,
40
- target: target_directory,
41
- }.merge(options.fetch(:metadata, {})),
42
- )
43
- end
44
-
45
- # Create a git pull request.
46
- #
47
- # @param directory [String] repository directory
48
- # @param options [Hash] additional options
49
- # @option options [String] :remote ("origin") remote name
50
- # @option options [String] :branch (nil) specific branch
51
- # @option options [Integer] :timeout (120) timeout in seconds
52
- # @return [Request] git pull request
53
- def self.git_pull(directory = Dir.pwd, **options)
54
- arguments = ["pull"]
55
- arguments << options[:remote] if options[:remote]
56
- arguments << options[:branch] if options[:branch]
57
-
58
- Request.new(
59
- command: "git",
60
- arguments: arguments,
61
- directory: directory,
62
- timeout: options.fetch(:timeout, 120),
63
- metadata: {
64
- operation: "git_pull",
65
- remote: options[:remote] || "origin",
66
- branch: options[:branch],
67
- }.merge(options.fetch(:metadata, {})),
68
- )
69
- end
70
-
71
- # Create a git status request.
72
- #
73
- # @param directory [String] repository directory
74
- # @param options [Hash] additional options
75
- # @option options [Boolean] :porcelain (false) use porcelain format
76
- # @option options [Boolean] :short (false) use short format
77
- # @return [Request] git status request
78
- def self.git_status(directory = Dir.pwd, **options)
79
- arguments = ["status"]
80
- arguments << "--porcelain" if options[:porcelain]
81
- arguments << "--short" if options[:short]
82
-
83
- Request.new(
84
- command: "git",
85
- arguments: arguments,
86
- directory: directory,
87
- metadata: {
88
- operation: "git_status",
89
- porcelain: options[:porcelain],
90
- short: options[:short],
91
- }.merge(options.fetch(:metadata, {})),
92
- )
93
- end
94
-
95
- # Create a git log request.
96
- #
97
- # @param directory [String] repository directory
98
- # @param options [Hash] additional options
99
- # @option options [Integer] :limit (nil) limit number of commits
100
- # @option options [String] :format (nil) log format
101
- # @option options [String] :since (nil) since date/commit
102
- # @return [Request] git log request
103
- def self.git_log(directory = Dir.pwd, **options)
104
- arguments = ["log"]
105
- arguments.push("-n", options[:limit].to_s) if options[:limit]
106
- arguments.push("--format", options[:format]) if options[:format]
107
- arguments.push("--since", options[:since]) if options[:since]
108
-
109
- Request.new(
110
- command: "git",
111
- arguments: arguments,
112
- directory: directory,
113
- metadata: {
114
- operation: "git_log",
115
- limit: options[:limit],
116
- format: options[:format],
117
- since: options[:since],
118
- }.merge(options.fetch(:metadata, {})),
119
- )
120
- end
121
-
122
- # Create a bundle install request.
123
- #
124
- # @param directory [String] project directory
125
- # @param options [Hash] additional options
126
- # @option options [Integer] :jobs (nil) number of parallel jobs
127
- # @option options [String] :path (nil) install path
128
- # @option options [Boolean] :deployment (false) deployment mode
129
- # @option options [Integer] :timeout (300) timeout in seconds
130
- # @return [Request] bundle install request
131
- def self.bundle_install(directory = Dir.pwd, **options)
132
- arguments = ["install"]
133
- arguments.push("--jobs", options[:jobs].to_s) if options[:jobs]
134
- arguments.push("--path", options[:path]) if options[:path]
135
- arguments << "--deployment" if options[:deployment]
136
-
137
- Request.new(
138
- command: "bundle",
139
- arguments: arguments,
140
- directory: directory,
141
- timeout: options.fetch(:timeout, 300),
142
- metadata: {
143
- operation: "bundle_install",
144
- jobs: options[:jobs],
145
- path: options[:path],
146
- deployment: options[:deployment],
147
- }.merge(options.fetch(:metadata, {})),
148
- )
149
- end
150
-
151
- # Create a bundle exec request.
152
- #
153
- # @param command_string [String] command to execute with bundle exec
154
- # @param directory [String] project directory
155
- # @param options [Hash] additional options
156
- # @option options [Integer] :timeout (120) timeout in seconds
157
- # @return [Request] bundle exec request
158
- def self.bundle_exec(command_string, directory = Dir.pwd, **options)
159
- # Parse the command string to get command and arguments
160
- parts = command_string.strip.split(/\s+/)
161
- arguments = ["exec"] + parts
162
-
163
- Request.new(
164
- command: "bundle",
165
- arguments: arguments,
166
- directory: directory,
167
- timeout: options.fetch(:timeout, 120),
168
- metadata: {
169
- operation: "bundle_exec",
170
- exec_command: command_string,
171
- }.merge(options.fetch(:metadata, {})),
172
- )
173
- end
174
-
175
- # Create a rake task request.
176
- #
177
- # @param task_name [String] rake task name
178
- # @param directory [String] project directory
179
- # @param options [Hash] additional options
180
- # @option options [Array<String>] :arguments additional task arguments
181
- # @option options [Hash] :environment environment variables
182
- # @option options [Integer] :timeout (300) timeout in seconds
183
- # @return [Request] rake task request
184
- def self.rake_task(task_name, directory = Dir.pwd, **options)
185
- arguments = [task_name]
186
- arguments.concat(options[:arguments]) if options[:arguments]
187
-
188
- Request.new(
189
- command: "rake",
190
- arguments: arguments,
191
- directory: directory,
192
- environment: options[:environment] || {},
193
- timeout: options.fetch(:timeout, 300),
194
- metadata: {
195
- operation: "rake_task",
196
- task: task_name,
197
- arguments: options[:arguments],
198
- }.merge(options.fetch(:metadata, {})),
199
- )
200
- end
201
-
202
- # Create a gem build request.
203
- #
204
- # @param gemspec_file [String, nil] gemspec file (optional, will auto-detect)
205
- # @param directory [String] project directory
206
- # @param options [Hash] additional options
207
- # @option options [Integer] :timeout (120) timeout in seconds
208
- # @return [Request] gem build request
209
- def self.gem_build(gemspec_file = nil, directory = Dir.pwd, **options)
210
- arguments = ["build"]
211
- arguments << gemspec_file if gemspec_file
212
-
213
- Request.new(
214
- command: "gem",
215
- arguments: arguments,
216
- directory: directory,
217
- timeout: options.fetch(:timeout, 120),
218
- metadata: {
219
- operation: "gem_build",
220
- gemspec: gemspec_file,
221
- }.merge(options.fetch(:metadata, {})),
222
- )
223
- end
224
-
225
- # Create a gem install request.
226
- #
227
- # @param gem_name [String] gem name or gem file
228
- # @param options [Hash] additional options
229
- # @option options [String] :version specific version
230
- # @option options [Boolean] :local (false) install from local file
231
- # @option options [String] :source gem source
232
- # @option options [Integer] :timeout (180) timeout in seconds
233
- # @return [Request] gem install request
234
- def self.gem_install(gem_name, **options)
235
- arguments = ["install", gem_name]
236
- arguments.push("--version", options[:version]) if options[:version]
237
- arguments << "--local" if options[:local]
238
- arguments.push("--source", options[:source]) if options[:source]
239
-
240
- Request.new(
241
- command: "gem",
242
- arguments: arguments,
243
- timeout: options.fetch(:timeout, 180),
244
- metadata: {
245
- operation: "gem_install",
246
- gem: gem_name,
247
- version: options[:version],
248
- local: options[:local],
249
- source: options[:source],
250
- }.merge(options.fetch(:metadata, {})),
251
- )
252
- end
253
-
254
- # Create a Ruby script execution request.
255
- #
256
- # @param script_file [String] Ruby script file to execute
257
- # @param directory [String] working directory
258
- # @param options [Hash] additional options
259
- # @option options [Array<String>] :arguments script arguments
260
- # @option options [Hash] :environment environment variables
261
- # @option options [Integer] :timeout (120) timeout in seconds
262
- # @return [Request] Ruby script execution request
263
- def self.ruby_script(script_file, directory = Dir.pwd, **options)
264
- arguments = [script_file]
265
- arguments.concat(options[:arguments]) if options[:arguments]
266
-
267
- Request.new(
268
- command: "ruby",
269
- arguments: arguments,
270
- directory: directory,
271
- environment: options[:environment] || {},
272
- timeout: options.fetch(:timeout, 120),
273
- metadata: {
274
- operation: "ruby_script",
275
- script: script_file,
276
- arguments: options[:arguments],
277
- }.merge(options.fetch(:metadata, {})),
278
- )
279
- end
280
-
281
- # Create a system command request with validation.
282
- #
283
- # @param command [String] system command
284
- # @param arguments [Array<String>] command arguments
285
- # @param options [Hash] additional options
286
- # @option options [String] :directory working directory
287
- # @option options [Hash] :environment environment variables
288
- # @option options [Integer] :timeout (60) timeout in seconds
289
- # @return [Request] system command request
290
- def self.system_command(command, arguments = [], **options)
291
- Request.new(
292
- command: command,
293
- arguments: Array(arguments),
294
- directory: options[:directory] || Dir.pwd,
295
- environment: options[:environment] || {},
296
- timeout: options.fetch(:timeout, 60),
297
- metadata: {
298
- operation: "system_command",
299
- system_command: command,
300
- }.merge(options.fetch(:metadata, {})),
301
- )
302
- end
303
-
304
- # Create a dotnet CLI request.
305
- #
306
- # @param subcommand [String] dotnet subcommand (build, test, run, etc.)
307
- # @param directory [String] project directory
308
- # @param options [Hash] additional options
309
- # @option options [Array<String>] :arguments additional arguments
310
- # @option options [String] :configuration (nil) build configuration
311
- # @option options [String] :framework (nil) target framework
312
- # @option options [Integer] :timeout (300) timeout in seconds
313
- # @return [Request] dotnet CLI request
314
- def self.dotnet_command(subcommand, directory = Dir.pwd, **options)
315
- arguments = [subcommand]
316
- arguments.concat(options[:arguments]) if options[:arguments]
317
- arguments.push("--configuration", options[:configuration]) if options[:configuration]
318
- arguments.push("--framework", options[:framework]) if options[:framework]
319
-
320
- Request.new(
321
- command: "dotnet",
322
- arguments: arguments,
323
- directory: directory,
324
- timeout: options.fetch(:timeout, 300),
325
- metadata: {
326
- operation: "dotnet_#{subcommand}",
327
- subcommand: subcommand,
328
- configuration: options[:configuration],
329
- framework: options[:framework],
330
- }.merge(options.fetch(:metadata, {})),
331
- )
332
- end
333
-
334
- # Create a Node.js/npm command request.
335
- #
336
- # @param subcommand [String] npm subcommand (install, test, run, etc.)
337
- # @param directory [String] project directory
338
- # @param options [Hash] additional options
339
- # @option options [Array<String>] :arguments additional arguments
340
- # @option options [Integer] :timeout (300) timeout in seconds
341
- # @return [Request] npm command request
342
- def self.npm_command(subcommand, directory = Dir.pwd, **options)
343
- arguments = [subcommand]
344
- arguments.concat(options[:arguments]) if options[:arguments]
345
-
346
- Request.new(
347
- command: "npm",
348
- arguments: arguments,
349
- directory: directory,
350
- timeout: options.fetch(:timeout, 300),
351
- metadata: {
352
- operation: "npm_#{subcommand}",
353
- subcommand: subcommand,
354
- }.merge(options.fetch(:metadata, {})),
355
- )
356
- end
357
- end
358
- end
359
- end
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "request"
4
+
5
+ module Makit
6
+ module Commands
7
+ # Factory for creating common command requests.
8
+ #
9
+ # This factory provides convenient methods for creating Request objects
10
+ # for common operations like git commands, bundle operations, rake tasks,
11
+ # and system utilities.
12
+ #
13
+ # @example Creating git commands
14
+ # request = Factory.git_clone("https://github.com/user/repo.git", "/path/to/clone")
15
+ # request = Factory.git_status("/path/to/repo")
16
+ #
17
+ # @example Creating Ruby commands
18
+ # request = Factory.bundle_install("/path/to/project")
19
+ # request = Factory.rake_task("test", "/path/to/project")
20
+ class Factory
21
+ # Create a git clone request.
22
+ #
23
+ # @param repository_url [String] git repository URL
24
+ # @param target_directory [String, nil] target directory (optional)
25
+ # @param options [Hash] additional options
26
+ # @option options [Integer] :timeout (300) timeout in seconds
27
+ # @option options [Hash] :metadata additional metadata
28
+ # @return [Request] git clone request
29
+ def self.git_clone(repository_url, target_directory = nil, **options)
30
+ arguments = ["clone", repository_url]
31
+ arguments << target_directory if target_directory
32
+
33
+ Request.new(
34
+ command: "git",
35
+ arguments: arguments,
36
+ timeout: options.fetch(:timeout, 300),
37
+ metadata: {
38
+ operation: "git_clone",
39
+ repository: repository_url,
40
+ target: target_directory,
41
+ }.merge(options.fetch(:metadata, {})),
42
+ )
43
+ end
44
+
45
+ # Create a git pull request.
46
+ #
47
+ # @param directory [String] repository directory
48
+ # @param options [Hash] additional options
49
+ # @option options [String] :remote ("origin") remote name
50
+ # @option options [String] :branch (nil) specific branch
51
+ # @option options [Integer] :timeout (120) timeout in seconds
52
+ # @return [Request] git pull request
53
+ def self.git_pull(directory = Dir.pwd, **options)
54
+ arguments = ["pull"]
55
+ arguments << options[:remote] if options[:remote]
56
+ arguments << options[:branch] if options[:branch]
57
+
58
+ Request.new(
59
+ command: "git",
60
+ arguments: arguments,
61
+ directory: directory,
62
+ timeout: options.fetch(:timeout, 120),
63
+ metadata: {
64
+ operation: "git_pull",
65
+ remote: options[:remote] || "origin",
66
+ branch: options[:branch],
67
+ }.merge(options.fetch(:metadata, {})),
68
+ )
69
+ end
70
+
71
+ # Create a git status request.
72
+ #
73
+ # @param directory [String] repository directory
74
+ # @param options [Hash] additional options
75
+ # @option options [Boolean] :porcelain (false) use porcelain format
76
+ # @option options [Boolean] :short (false) use short format
77
+ # @return [Request] git status request
78
+ def self.git_status(directory = Dir.pwd, **options)
79
+ arguments = ["status"]
80
+ arguments << "--porcelain" if options[:porcelain]
81
+ arguments << "--short" if options[:short]
82
+
83
+ Request.new(
84
+ command: "git",
85
+ arguments: arguments,
86
+ directory: directory,
87
+ metadata: {
88
+ operation: "git_status",
89
+ porcelain: options[:porcelain],
90
+ short: options[:short],
91
+ }.merge(options.fetch(:metadata, {})),
92
+ )
93
+ end
94
+
95
+ # Create a git log request.
96
+ #
97
+ # @param directory [String] repository directory
98
+ # @param options [Hash] additional options
99
+ # @option options [Integer] :limit (nil) limit number of commits
100
+ # @option options [String] :format (nil) log format
101
+ # @option options [String] :since (nil) since date/commit
102
+ # @return [Request] git log request
103
+ def self.git_log(directory = Dir.pwd, **options)
104
+ arguments = ["log"]
105
+ arguments.push("-n", options[:limit].to_s) if options[:limit]
106
+ arguments.push("--format", options[:format]) if options[:format]
107
+ arguments.push("--since", options[:since]) if options[:since]
108
+
109
+ Request.new(
110
+ command: "git",
111
+ arguments: arguments,
112
+ directory: directory,
113
+ metadata: {
114
+ operation: "git_log",
115
+ limit: options[:limit],
116
+ format: options[:format],
117
+ since: options[:since],
118
+ }.merge(options.fetch(:metadata, {})),
119
+ )
120
+ end
121
+
122
+ # Create a bundle install request.
123
+ #
124
+ # @param directory [String] project directory
125
+ # @param options [Hash] additional options
126
+ # @option options [Integer] :jobs (nil) number of parallel jobs
127
+ # @option options [String] :path (nil) install path
128
+ # @option options [Boolean] :deployment (false) deployment mode
129
+ # @option options [Integer] :timeout (300) timeout in seconds
130
+ # @return [Request] bundle install request
131
+ def self.bundle_install(directory = Dir.pwd, **options)
132
+ arguments = ["install"]
133
+ arguments.push("--jobs", options[:jobs].to_s) if options[:jobs]
134
+ arguments.push("--path", options[:path]) if options[:path]
135
+ arguments << "--deployment" if options[:deployment]
136
+
137
+ Request.new(
138
+ command: "bundle",
139
+ arguments: arguments,
140
+ directory: directory,
141
+ timeout: options.fetch(:timeout, 300),
142
+ metadata: {
143
+ operation: "bundle_install",
144
+ jobs: options[:jobs],
145
+ path: options[:path],
146
+ deployment: options[:deployment],
147
+ }.merge(options.fetch(:metadata, {})),
148
+ )
149
+ end
150
+
151
+ # Create a bundle exec request.
152
+ #
153
+ # @param command_string [String] command to execute with bundle exec
154
+ # @param directory [String] project directory
155
+ # @param options [Hash] additional options
156
+ # @option options [Integer] :timeout (120) timeout in seconds
157
+ # @return [Request] bundle exec request
158
+ def self.bundle_exec(command_string, directory = Dir.pwd, **options)
159
+ # Parse the command string to get command and arguments
160
+ parts = command_string.strip.split(/\s+/)
161
+ arguments = ["exec"] + parts
162
+
163
+ Request.new(
164
+ command: "bundle",
165
+ arguments: arguments,
166
+ directory: directory,
167
+ timeout: options.fetch(:timeout, 120),
168
+ metadata: {
169
+ operation: "bundle_exec",
170
+ exec_command: command_string,
171
+ }.merge(options.fetch(:metadata, {})),
172
+ )
173
+ end
174
+
175
+ # Create a rake task request.
176
+ #
177
+ # @param task_name [String] rake task name
178
+ # @param directory [String] project directory
179
+ # @param options [Hash] additional options
180
+ # @option options [Array<String>] :arguments additional task arguments
181
+ # @option options [Hash] :environment environment variables
182
+ # @option options [Integer] :timeout (300) timeout in seconds
183
+ # @return [Request] rake task request
184
+ def self.rake_task(task_name, directory = Dir.pwd, **options)
185
+ arguments = [task_name]
186
+ arguments.concat(options[:arguments]) if options[:arguments]
187
+
188
+ Request.new(
189
+ command: "rake",
190
+ arguments: arguments,
191
+ directory: directory,
192
+ environment: options[:environment] || {},
193
+ timeout: options.fetch(:timeout, 300),
194
+ metadata: {
195
+ operation: "rake_task",
196
+ task: task_name,
197
+ arguments: options[:arguments],
198
+ }.merge(options.fetch(:metadata, {})),
199
+ )
200
+ end
201
+
202
+ # Create a gem build request.
203
+ #
204
+ # @param gemspec_file [String, nil] gemspec file (optional, will auto-detect)
205
+ # @param directory [String] project directory
206
+ # @param options [Hash] additional options
207
+ # @option options [Integer] :timeout (120) timeout in seconds
208
+ # @return [Request] gem build request
209
+ def self.gem_build(gemspec_file = nil, directory = Dir.pwd, **options)
210
+ arguments = ["build"]
211
+ arguments << gemspec_file if gemspec_file
212
+
213
+ Request.new(
214
+ command: "gem",
215
+ arguments: arguments,
216
+ directory: directory,
217
+ timeout: options.fetch(:timeout, 120),
218
+ metadata: {
219
+ operation: "gem_build",
220
+ gemspec: gemspec_file,
221
+ }.merge(options.fetch(:metadata, {})),
222
+ )
223
+ end
224
+
225
+ # Create a gem install request.
226
+ #
227
+ # @param gem_name [String] gem name or gem file
228
+ # @param options [Hash] additional options
229
+ # @option options [String] :version specific version
230
+ # @option options [Boolean] :local (false) install from local file
231
+ # @option options [String] :source gem source
232
+ # @option options [Integer] :timeout (180) timeout in seconds
233
+ # @return [Request] gem install request
234
+ def self.gem_install(gem_name, **options)
235
+ arguments = ["install", gem_name]
236
+ arguments.push("--version", options[:version]) if options[:version]
237
+ arguments << "--local" if options[:local]
238
+ arguments.push("--source", options[:source]) if options[:source]
239
+
240
+ Request.new(
241
+ command: "gem",
242
+ arguments: arguments,
243
+ timeout: options.fetch(:timeout, 180),
244
+ metadata: {
245
+ operation: "gem_install",
246
+ gem: gem_name,
247
+ version: options[:version],
248
+ local: options[:local],
249
+ source: options[:source],
250
+ }.merge(options.fetch(:metadata, {})),
251
+ )
252
+ end
253
+
254
+ # Create a Ruby script execution request.
255
+ #
256
+ # @param script_file [String] Ruby script file to execute
257
+ # @param directory [String] working directory
258
+ # @param options [Hash] additional options
259
+ # @option options [Array<String>] :arguments script arguments
260
+ # @option options [Hash] :environment environment variables
261
+ # @option options [Integer] :timeout (120) timeout in seconds
262
+ # @return [Request] Ruby script execution request
263
+ def self.ruby_script(script_file, directory = Dir.pwd, **options)
264
+ arguments = [script_file]
265
+ arguments.concat(options[:arguments]) if options[:arguments]
266
+
267
+ Request.new(
268
+ command: "ruby",
269
+ arguments: arguments,
270
+ directory: directory,
271
+ environment: options[:environment] || {},
272
+ timeout: options.fetch(:timeout, 120),
273
+ metadata: {
274
+ operation: "ruby_script",
275
+ script: script_file,
276
+ arguments: options[:arguments],
277
+ }.merge(options.fetch(:metadata, {})),
278
+ )
279
+ end
280
+
281
+ # Create a system command request with validation.
282
+ #
283
+ # @param command [String] system command
284
+ # @param arguments [Array<String>] command arguments
285
+ # @param options [Hash] additional options
286
+ # @option options [String] :directory working directory
287
+ # @option options [Hash] :environment environment variables
288
+ # @option options [Integer] :timeout (60) timeout in seconds
289
+ # @return [Request] system command request
290
+ def self.system_command(command, arguments = [], **options)
291
+ Request.new(
292
+ command: command,
293
+ arguments: Array(arguments),
294
+ directory: options[:directory] || Dir.pwd,
295
+ environment: options[:environment] || {},
296
+ timeout: options.fetch(:timeout, 60),
297
+ metadata: {
298
+ operation: "system_command",
299
+ system_command: command,
300
+ }.merge(options.fetch(:metadata, {})),
301
+ )
302
+ end
303
+
304
+ # Create a dotnet CLI request.
305
+ #
306
+ # @param subcommand [String] dotnet subcommand (build, test, run, etc.)
307
+ # @param directory [String] project directory
308
+ # @param options [Hash] additional options
309
+ # @option options [Array<String>] :arguments additional arguments
310
+ # @option options [String] :configuration (nil) build configuration
311
+ # @option options [String] :framework (nil) target framework
312
+ # @option options [Integer] :timeout (300) timeout in seconds
313
+ # @return [Request] dotnet CLI request
314
+ def self.dotnet_command(subcommand, directory = Dir.pwd, **options)
315
+ arguments = [subcommand]
316
+ arguments.concat(options[:arguments]) if options[:arguments]
317
+ arguments.push("--configuration", options[:configuration]) if options[:configuration]
318
+ arguments.push("--framework", options[:framework]) if options[:framework]
319
+
320
+ Request.new(
321
+ command: "dotnet",
322
+ arguments: arguments,
323
+ directory: directory,
324
+ timeout: options.fetch(:timeout, 300),
325
+ metadata: {
326
+ operation: "dotnet_#{subcommand}",
327
+ subcommand: subcommand,
328
+ configuration: options[:configuration],
329
+ framework: options[:framework],
330
+ }.merge(options.fetch(:metadata, {})),
331
+ )
332
+ end
333
+
334
+ # Create a Node.js/npm command request.
335
+ #
336
+ # @param subcommand [String] npm subcommand (install, test, run, etc.)
337
+ # @param directory [String] project directory
338
+ # @param options [Hash] additional options
339
+ # @option options [Array<String>] :arguments additional arguments
340
+ # @option options [Integer] :timeout (300) timeout in seconds
341
+ # @return [Request] npm command request
342
+ def self.npm_command(subcommand, directory = Dir.pwd, **options)
343
+ arguments = [subcommand]
344
+ arguments.concat(options[:arguments]) if options[:arguments]
345
+
346
+ Request.new(
347
+ command: "npm",
348
+ arguments: arguments,
349
+ directory: directory,
350
+ timeout: options.fetch(:timeout, 300),
351
+ metadata: {
352
+ operation: "npm_#{subcommand}",
353
+ subcommand: subcommand,
354
+ }.merge(options.fetch(:metadata, {})),
355
+ )
356
+ end
357
+ end
358
+ end
359
+ end