about summary refs log tree commit diff
path: root/lib/tasks
diff options
context:
space:
mode:
authorThibaut Girka <thib@sitedethib.com>2020-02-29 12:20:54 +0100
committerThibaut Girka <thib@sitedethib.com>2020-02-29 12:20:54 +0100
commit427ef4948a4fdd1c34e7c7baa6dd5c967e32d932 (patch)
tree6c00f4972e86f44ba1899385eb107838d146e5c1 /lib/tasks
parente1d29f7d9f85a25af7a1595d2c9afc127ab36ca7 (diff)
parent5393b187c4601966f9be23490dfb1e54f3f3e725 (diff)
Merge branch 'master' into glitch-soc/merge-upstream
Diffstat (limited to 'lib/tasks')
-rw-r--r--lib/tasks/mastodon.rake15
1 files changed, 14 insertions, 1 deletions
diff --git a/lib/tasks/mastodon.rake b/lib/tasks/mastodon.rake
index 2e92e8ded..a873335d4 100644
--- a/lib/tasks/mastodon.rake
+++ b/lib/tasks/mastodon.rake
@@ -336,7 +336,20 @@ namespace :mastodon do
       if prompt.yes?('Save configuration?')
         cmd = TTY::Command.new(printer: :quiet)
 
-        File.write(Rails.root.join('.env.production'), "# Generated with mastodon:setup on #{Time.now.utc}\n\n" + env.each_pair.map { |key, value| "#{key}=#{value}" }.join("\n") + "\n")
+        env_contents = env.each_pair.map do |key, value|
+          if value.is_a?(String) && value =~ /[\s\#\\"]/
+            if value =~ /[']/
+              value = value.to_s.gsub(/[\\"\$]/) { |x| "\\#{x}" }
+              "#{key}=\"#{value}\""
+            else
+              "#{key}='#{value}'"
+            end
+          else
+            "#{key}=#{value}"
+          end
+        end.join("\n")
+
+        File.write(Rails.root.join('.env.production'), "# Generated with mastodon:setup on #{Time.now.utc}\n\n" + env_contents + "\n")
 
         if using_docker
           prompt.ok 'Below is your configuration, save it to an .env.production file outside Docker:'