Skip to content

Commit

Permalink
Add method generate_manifest
Browse files Browse the repository at this point in the history
- the method generate manifest from installed cnf
  • Loading branch information
barmull committed Sep 10, 2024
1 parent 46b0c7f commit 5eead9e
Showing 1 changed file with 28 additions and 0 deletions.
28 changes: 28 additions & 0 deletions helm.cr
Original file line number Diff line number Diff line change
Expand Up @@ -142,6 +142,27 @@ module Helm
[resp[:status].success?, output_file]
end

def self.generate_manifest(release_name : String, namespace : String)
Log.info { "Generating manifest from installed CNF: #{release_name}" }

helm = BinarySingleton.helm
cmd = "#{helm} get manifest #{release_name} --namespace #{namespace}"
Log.info { "helm command: #{cmd}" }

status = Process.run(cmd, shell: true, output: output = IO::Memory.new, error: stderr = IO::Memory.new)

if status.success? && !output.empty?
Log.debug { "Helm.manifest output:\n #{output.to_s}" }
Log.info { "Manifest was generated successfully" }
if !stderr.empty?
Log.info { "Helm.manifest stderr: #{stderr.to_s}" }
end
else
raise ManifestGenerationError.new(stderr.to_s)
end
output.to_s
end

def self.workload_resource_by_kind(ymls : Array(YAML::Any), kind : String)
Log.info { "workload_resource_by_kind kind: #{kind}" }
Log.debug { "workload_resource_by_kind ymls: #{ymls}" }
Expand Down Expand Up @@ -447,4 +468,11 @@ module Helm
return nil
end
end

class ManifestGenerationError < Exception
def initialize(stderr : String)
super("✖ ERROR: generating manifest was not successfull.\nHelm stderr --> #{stderr}")
end
end

end

0 comments on commit 5eead9e

Please sign in to comment.