regolith 0.1.30 → 0.1.31

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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 25e890947b62730f38bc5ad78253819f5c7a52d9c604d8ff6167347282d70ca0
4
- data.tar.gz: 85d0b5420d0eb830438011f9a3640c498746525735abfcc761475796c33a52c2
3
+ metadata.gz: 7b9c3d42103600562bbf5ad86588b23c0cf0f4219e31defa04ef21b42bd9b3d5
4
+ data.tar.gz: e026f51e4507f8cdbf55bf79ea753c5a2f492cb249c9fe1360dbc3179cbf367f
5
5
  SHA512:
6
- metadata.gz: 74e5f7521b2ce9fcd73217dcf29dfd5f0af7200116883624cd9e6514cd0ca388acb24476e47ca2b249b16ba7860f8d644a0fdc1aedf7dd9fb1d6c8fbfa3b2292
7
- data.tar.gz: 2630ddbfdf6a2ba082552f77d82d211234ba37e6644898f85c3aa6b08f22385ab2b27f64c41e33f835e1f56de2cefbad2fbf7c0d97e5a86b018cd00154dc17b4
6
+ metadata.gz: ba10b02b1b183c8f0399e72eec0f47b3688acf74004a1826684e597ae823e7e73b5bef9d141f445977bca5658281dc5db4a9d0bcaa22de2b9b33ec334bb85263
7
+ data.tar.gz: a18674fbcd2159d2cb6e8bc1c73d5fac155df1e8a995d9b3f6899973c6d3e3cf6a3e693078eaf7d7335c441c29eff818cd90dad46b9067e12428fb259d551829
data/lib/regolith/cli.rb CHANGED
@@ -22,6 +22,18 @@ module Regolith
22
22
  generate_resource(@subcommand, @name)
23
23
  when 'server'
24
24
  start_server
25
+ when 'stop'
26
+ stop_services
27
+ when 'down'
28
+ down_services
29
+ when 'restart'
30
+ restart_services
31
+ when 'logs'
32
+ show_logs(@subcommand)
33
+ when 'status'
34
+ show_status
35
+ when 'start'
36
+ start_service(@subcommand)
25
37
  when 'console'
26
38
  open_console(@subcommand)
27
39
  when 'version'
@@ -319,6 +331,90 @@ module Regolith
319
331
  exec("docker-compose up --build")
320
332
  end
321
333
 
334
+ def stop_services
335
+ unless File.exist?('docker-compose.yml')
336
+ puts "❌ Error: Not in a Regolith app directory"
337
+ exit 1
338
+ end
339
+
340
+ puts "🛑 Stopping Regolith services..."
341
+ exec("docker-compose stop")
342
+ end
343
+
344
+ def down_services
345
+ unless File.exist?('docker-compose.yml')
346
+ puts "❌ Error: Not in a Regolith app directory"
347
+ exit 1
348
+ end
349
+
350
+ puts "⬇️ Stopping and removing Regolith containers..."
351
+ exec("docker-compose down")
352
+ end
353
+
354
+ def restart_services
355
+ unless File.exist?('docker-compose.yml')
356
+ puts "❌ Error: Not in a Regolith app directory"
357
+ exit 1
358
+ end
359
+
360
+ puts "🔄 Restarting Regolith services..."
361
+ exec("docker-compose restart")
362
+ end
363
+
364
+ def show_logs(service_name = nil)
365
+ unless File.exist?('docker-compose.yml')
366
+ puts "❌ Error: Not in a Regolith app directory"
367
+ exit 1
368
+ end
369
+
370
+ if service_name
371
+ config = load_regolith_config
372
+ unless config['services'][service_name]
373
+ puts "❌ Error: Service '#{service_name}' not found"
374
+ puts "Available services: #{config['services'].keys.join(', ')}"
375
+ exit 1
376
+ end
377
+ puts "📋 Showing logs for #{service_name}_service..."
378
+ exec("docker-compose logs -f #{service_name}")
379
+ else
380
+ puts "📋 Showing logs for all services..."
381
+ exec("docker-compose logs -f")
382
+ end
383
+ end
384
+
385
+ def show_status
386
+ unless File.exist?('docker-compose.yml')
387
+ puts "❌ Error: Not in a Regolith app directory"
388
+ exit 1
389
+ end
390
+
391
+ puts "📊 Regolith services status:"
392
+ exec("docker-compose ps")
393
+ end
394
+
395
+ def start_service(service_name)
396
+ unless service_name
397
+ puts "❌ Error: Service name required"
398
+ puts "Usage: regolith start <service_name>"
399
+ exit 1
400
+ end
401
+
402
+ unless File.exist?('docker-compose.yml')
403
+ puts "❌ Error: Not in a Regolith app directory"
404
+ exit 1
405
+ end
406
+
407
+ config = load_regolith_config
408
+ unless config['services'][service_name]
409
+ puts "❌ Error: Service '#{service_name}' not found"
410
+ puts "Available services: #{config['services'].keys.join(', ')}"
411
+ exit 1
412
+ end
413
+
414
+ puts "▶️ Starting #{service_name}_service..."
415
+ exec("docker-compose start #{service_name}")
416
+ end
417
+
322
418
  def open_console(service_name)
323
419
  unless service_name
324
420
  puts "❌ Error: Service name required"
@@ -467,17 +563,31 @@ module Regolith
467
563
 
468
564
  COMMANDS:
469
565
  new <app_name> Create a new Regolith application
470
- generate service <n> Generate a new microservice
566
+ generate service <name> Generate a new microservice
567
+
471
568
  server Start all services with Docker Compose
569
+ stop Stop all running services
570
+ down Stop and remove all containers
571
+ restart Restart all services
572
+ start <service_name> Start a specific service
573
+
574
+ logs [service_name] Show logs (all services or specific service)
575
+ status Show status of all services
472
576
  console <service_name> Open Rails console for a service
473
577
  version Show version information
474
578
 
475
579
  EXAMPLES:
476
- regolith new observatory
477
- regolith generate service telescope
478
- regolith generate service records
580
+ regolith new ecommerce
581
+ regolith generate service users
582
+ regolith generate service orders
479
583
  regolith server
480
- regolith console telescope
584
+
585
+ regolith stop
586
+ regolith restart
587
+ regolith logs users
588
+ regolith status
589
+ regolith start users
590
+ regolith console users
481
591
 
482
592
  Get started:
483
593
  regolith new myapp
@@ -1,4 +1,4 @@
1
1
  # lib/regolith/version.rb
2
2
  module Regolith
3
- VERSION = "0.1.30"
3
+ VERSION = "0.1.31"
4
4
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: regolith
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.30
4
+ version: 0.1.31
5
5
  platform: ruby
6
6
  authors:
7
7
  - Regolith Team