service/src/service/environment.cr

112 lines
2.2 KiB
Crystal
Raw Normal View History

require "specparser"
2019-06-09 16:59:05 +02:00
class Environment
enum Type
Prefix
RootFileSystem
end
2019-08-10 17:16:24 +02:00
getter name : String
getter type : Type = Type::Prefix
getter files = Array(ServiceDefinition::FileDefinition).new
2019-06-09 16:59:05 +02:00
2019-10-26 14:00:11 +02:00
# The place well put services data and configuration.
@root : String?
2019-06-09 16:59:05 +02:00
def initialize()
initialize "root"
end
def initialize(@name, type = "prefix")
@type = Type.parse type
@files = Array(ServiceDefinition::FileDefinition).new
2019-06-09 16:59:05 +02:00
# FIXME: Should this *really* be here?
# FIXME: $ENVIRONMENT_ROOT
@files << ServiceDefinition::FileDefinition.new "/srv/${ENVIRONMENT}",
"environment root",
creation_command: "mkdir -p /srv/${ENVIRONMENT} && chmod a+rwt /srv/${ENVIRONMENT}",
deletion_command: "rmdir /srv/${ENVIRONMENT}"
2019-08-10 17:16:24 +02:00
end
def initialize(@name, specs : SpecParser)
2019-08-10 17:16:24 +02:00
assignments = specs.assignments
assignments["type"].try &.as_s.tap do |type|
@type = Type.parse type
end
specs.sections.select(&.name.==("check")).each do |check|
@files << ServiceDefinition::FileDefinition.new check
2019-08-10 17:16:24 +02:00
end
2019-06-09 16:59:05 +02:00
end
2019-10-26 14:00:11 +02:00
def root
@root || "#{SERVED_DATA_DIRECTORY}/#{@name}"
end
2019-06-09 16:59:05 +02:00
class_getter root = Environment.new
class_getter all = [@@root] of Environment
def self.load(path)
2019-10-19 18:40:47 +02:00
return unless Dir.exists? path
2019-06-09 16:59:05 +02:00
Dir.each_child path do |child|
2019-08-10 17:16:24 +02:00
unless child.match /\.spec$/
2019-06-09 16:59:05 +02:00
next
end
file_path = "#{path}/#{child}"
begin
name = File.basename(child, ".spec")
specs = SpecParser.parse File.read(file_path)
environment = Environment.new name, specs
2019-06-09 16:59:05 +02:00
rescue e
STDERR << "error loading #{file_path}: " << e << "\n"
# FIXME: Print stacktrace? Debug mode?
next
end
@@all << environment
end
end
def write(dir : String)
File.write "#{dir}/#{@name}.spec", to_spec
end
2019-10-25 17:59:53 +02:00
def remove(dir : String)
File.delete "#{dir}/#{@name}.spec"
end
def to_spec
[
"type: #{@type.to_s}"
].join("\n") + "\n"
end
2019-06-09 16:59:05 +02:00
def self.get(name)
_def = @@all.find &.name.==(name)
if _def.nil?
2019-10-24 12:59:19 +02:00
raise ::Service::Exception.new "Environment '#{name}' does not exist."
2019-06-09 16:59:05 +02:00
end
_def
end
def get_provider(token)
Service.all.find do |service|
service.environment == self && service.provides? token
end.try &.id
end
2019-06-09 16:59:05 +02:00
def to_s
"#{name} (#{type.to_s.downcase})"
end
end