mirror of
https://github.com/puma/puma.git
synced 2022-11-09 13:48:40 -05:00
3060a75fcc
Before this commit, it was possible that the puma.state file would be world readable which may not be desirable in production environments. This introduces a new optional configuration option to set desired state file permissions.
34 lines
593 B
Ruby
34 lines
593 B
Ruby
# frozen_string_literal: true
|
|
|
|
require 'yaml'
|
|
|
|
module Puma
|
|
class StateFile
|
|
def initialize
|
|
@options = {}
|
|
end
|
|
|
|
def save(path, permission = nil)
|
|
File.open(path, "w") do |file|
|
|
file.chmod(permission) if permission
|
|
file.write(YAML.dump(@options))
|
|
end
|
|
end
|
|
|
|
def load(path)
|
|
@options = YAML.load File.read(path)
|
|
end
|
|
|
|
FIELDS = %w!control_url control_auth_token pid!
|
|
|
|
FIELDS.each do |f|
|
|
define_method f do
|
|
@options[f]
|
|
end
|
|
|
|
define_method "#{f}=" do |v|
|
|
@options[f] = v
|
|
end
|
|
end
|
|
end
|
|
end
|