Module: Timber::CLI::IO::Messages

Extended by:
Messages
Included in:
Messages
Defined in:
lib/timber/cli/io/messages.rb

Constant Summary collapse

APP_URL =
"https://app.timber.io"
DOCS_URL =
"https://timber.io/docs"
OBTAIN_KEY_DOCS_URL =
"https://timber.io/docs/app/obtain-api-key/"
REPO_URL =
"https://github.com/timberio/timber-ruby"
SUPPORT_EMAIL =
"[email protected]"
TWITTER_HANDLE =
"@timberdotio"
WEBSITE_URL =
"https://timber.io"
MAX_LENGTH =
80.freeze

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.application_details(app) ⇒ Object



21
22
23
24
25
26
# File 'lib/timber/cli/io/messages.rb', line 21

def application_details(app)
  message = <<-MESSAGE
Woot! Your API 🔑  is valid: #{app.name} (#{app.environment}) on #{app.platform_type}
MESSAGE
  message.rstrip
end

.bad_experience_messageObject



32
33
34
35
36
37
38
39
40
41
# File 'lib/timber/cli/io/messages.rb', line 32

def bad_experience_message
  message = <<-MESSAGE
Bummer! That is certainly not the experience we were going for.

Could you tell us why you a bad experience?

(this will be sent directly to the Timber engineering team)
MESSAGE
  message.rstrip
end

.console_url(app) ⇒ Object



51
52
53
54
55
# File 'lib/timber/cli/io/messages.rb', line 51

def console_url(app)
  message = <<-MESSAGE
Your console URL: https://app.timber.io/organizations/timber/apps/#{app.slug}/console
MESSAGE
end

.contactObject



57
58
59
60
61
62
63
64
# File 'lib/timber/cli/io/messages.rb', line 57

def contact
  message = <<-MESSAGE
Website:       #{WEBSITE_URL}
Documentation: #{DOCS_URL}
Support:       #{SUPPORT_EMAIL}
MESSAGE
  message.rstrip
end

.copied_to_clipboardObject



66
67
68
# File 'lib/timber/cli/io/messages.rb', line 66

def copied_to_clipboard
  IO::ANSI.colorize("(✓ copied to clipboard)", :green)
end

.edit_app_url(app) ⇒ Object



28
29
30
# File 'lib/timber/cli/io/messages.rb', line 28

def edit_app_url(app)
  "#{APP_URL}"
end

.failedObject



174
175
176
# File 'lib/timber/cli/io/messages.rb', line 174

def failed
  "Failed :("
end

.free_dataObject



89
90
91
92
93
94
95
96
97
# File 'lib/timber/cli/io/messages.rb', line 89

def free_data
  message = <<-MESSAGE
Get free data:

* Get ✨ 250mb✨  for starring our repo: #{IO::ANSI.colorize(REPO_URL, :blue)}
* Get ✨ 250mb✨  for tweeting your experience to #{IO::ANSI.colorize(TWITTER_HANDLE, :blue)}
MESSAGE
  message.rstrip
end

.git_commandsObject



43
44
45
46
47
48
49
# File 'lib/timber/cli/io/messages.rb', line 43

def git_commands
  message = <<-MESSAGE
    #{ANSI.colorize("git add config/initializers/timber.rb", :blue)}
    #{ANSI.colorize("git commit -am 'Install the timber logger'", :blue)}
MESSAGE
  message.rstrip
end

.headerObject



99
100
101
102
103
104
105
106
107
108
109
# File 'lib/timber/cli/io/messages.rb', line 99

def header
  message = <<-MESSAGE
🌲 Timber.io Ruby Installer - Great Ruby Logging Made *Easy*

 ^  ^  ^   ^      ___I_      ^  ^   ^  ^  ^   ^  ^
/|\\/|\\/|\\ /|\\    /\\-_--\\    /|\\/|\\ /|\\/|\\/|\\ /|\\/|\\
/|\\/|\\/|\\ /|\\   /  \\_-__\\   /|\\/|\\ /|\\/|\\/|\\ /|\\/|\\
/|\\/|\\/|\\ /|\\   |[]| [] |   /|\\/|\\ /|\\/|\\/|\\ /|\\/|\\
MESSAGE
  message.rstrip
end

.heroku_install(app) ⇒ Object



111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
# File 'lib/timber/cli/io/messages.rb', line 111

def heroku_install(app)
  command = "heroku drains:add #{app.heroku_drain_url}"
  copied = OSHelper.copy_to_clipboard(command)

  message = <<-MESSAGE
First, let's setup your Heroku drain. Run this command in a separate window:

    #{ANSI.colorize(command, :blue)}
MESSAGE
  message = message.rstrip

  if copied
    message << "\n    #{copied_to_clipboard}"
  end

  message
end

.http_environment_variables(api_key) ⇒ Object



70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
# File 'lib/timber/cli/io/messages.rb', line 70

def http_environment_variables(api_key)
  command = "export TIMBER_API_KEY=\"#{api_key}\""
  copied = OSHelper.copy_to_clipboard(command)

  message = <<-MESSAGE
Great! Add this variable to your environment:

    #{ANSI.colorize(command, :blue)}

MESSAGE
  message = message.rstrip

  if copied
    message << "\n    #{copied_to_clipboard}"
  end

  message
end

.no_api_key_providedObject



129
130
131
132
133
134
135
136
137
138
139
# File 'lib/timber/cli/io/messages.rb', line 129

def no_api_key_provided
  message = <<-MESSAGE
Hey there! Welcome to Timber. In order to proceed, you'll need an API key.
If you already have one, you can run this installer like:

    #{ANSI.colorize("bundle exec timber install my-api-key", :blue)}

#{obtain_key_instructions}
MESSAGE
  message.rstrip
end

.obtain_key_instructionsObject



141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
# File 'lib/timber/cli/io/messages.rb', line 141

def obtain_key_instructions
  message = <<-MESSAGE
Don't have a key? Head over to:

    #{ANSI.colorize(APP_URL, :blue)}

For a simple guide, checkout out:

    #{ANSI.colorize(OBTAIN_KEY_DOCS_URL, :blue)}

If you're stuck, contact us:

    #{ANSI.colorize(SUPPORT_EMAIL, :blue)}
MESSAGE
  message.rstrip
end

.separatorObject



158
159
160
# File 'lib/timber/cli/io/messages.rb', line 158

def separator
  "--------------------------------------------------------------------------------"
end

.spinner(iteration) ⇒ Object



162
163
164
165
166
167
168
169
170
171
172
# File 'lib/timber/cli/io/messages.rb', line 162

def spinner(iteration)
  rem = iteration % 3
  case rem
  when 0
    "/"
  when 1
    "-"
  when 2
    "\\"
  end
end

.successObject



178
179
180
# File 'lib/timber/cli/io/messages.rb', line 178

def success
  "✓ Success!"
end

.task_complete(message) ⇒ Object



182
183
184
185
186
187
# File 'lib/timber/cli/io/messages.rb', line 182

def task_complete(message)
  remainder = MAX_LENGTH - message.length - success.length

  dots = "." * remainder
  "\r#{message}#{dots}#{success}"
end

.task_failed(message) ⇒ Object



189
190
191
192
193
194
# File 'lib/timber/cli/io/messages.rb', line 189

def task_failed(message)
  remainder = MAX_LENGTH - message.length - failed.length

  dots = "." * remainder
  "\r#{message}#{dots}#{failed}"
end

.task_start(message) ⇒ Object



196
197
198
199
200
# File 'lib/timber/cli/io/messages.rb', line 196

def task_start(message)
  remainder = MAX_LENGTH - message.length - success.length

  "\r#{message}" + ("." * remainder)
end

.we_love_you_tooObject



202
203
204
# File 'lib/timber/cli/io/messages.rb', line 202

def we_love_you_too
  "Thanks! We 💖 you too!"
end

Instance Method Details

#application_details(app) ⇒ Object



21
22
23
24
25
26
# File 'lib/timber/cli/io/messages.rb', line 21

def application_details(app)
  message = <<-MESSAGE
Woot! Your API 🔑  is valid: #{app.name} (#{app.environment}) on #{app.platform_type}
MESSAGE
  message.rstrip
end

#bad_experience_messageObject



32
33
34
35
36
37
38
39
40
41
# File 'lib/timber/cli/io/messages.rb', line 32

def bad_experience_message
  message = <<-MESSAGE
Bummer! That is certainly not the experience we were going for.

Could you tell us why you a bad experience?

(this will be sent directly to the Timber engineering team)
MESSAGE
  message.rstrip
end

#console_url(app) ⇒ Object



51
52
53
54
55
# File 'lib/timber/cli/io/messages.rb', line 51

def console_url(app)
  message = <<-MESSAGE
Your console URL: https://app.timber.io/organizations/timber/apps/#{app.slug}/console
MESSAGE
end

#contactObject



57
58
59
60
61
62
63
64
# File 'lib/timber/cli/io/messages.rb', line 57

def contact
  message = <<-MESSAGE
Website:       #{WEBSITE_URL}
Documentation: #{DOCS_URL}
Support:       #{SUPPORT_EMAIL}
MESSAGE
  message.rstrip
end

#copied_to_clipboardObject



66
67
68
# File 'lib/timber/cli/io/messages.rb', line 66

def copied_to_clipboard
  IO::ANSI.colorize("(✓ copied to clipboard)", :green)
end

#edit_app_url(app) ⇒ Object



28
29
30
# File 'lib/timber/cli/io/messages.rb', line 28

def edit_app_url(app)
  "#{APP_URL}"
end

#failedObject



174
175
176
# File 'lib/timber/cli/io/messages.rb', line 174

def failed
  "Failed :("
end

#free_dataObject



89
90
91
92
93
94
95
96
97
# File 'lib/timber/cli/io/messages.rb', line 89

def free_data
  message = <<-MESSAGE
Get free data:

* Get ✨ 250mb✨  for starring our repo: #{IO::ANSI.colorize(REPO_URL, :blue)}
* Get ✨ 250mb✨  for tweeting your experience to #{IO::ANSI.colorize(TWITTER_HANDLE, :blue)}
MESSAGE
  message.rstrip
end

#git_commandsObject



43
44
45
46
47
48
49
# File 'lib/timber/cli/io/messages.rb', line 43

def git_commands
  message = <<-MESSAGE
    #{ANSI.colorize("git add config/initializers/timber.rb", :blue)}
    #{ANSI.colorize("git commit -am 'Install the timber logger'", :blue)}
MESSAGE
  message.rstrip
end

#headerObject



99
100
101
102
103
104
105
106
107
108
109
# File 'lib/timber/cli/io/messages.rb', line 99

def header
  message = <<-MESSAGE
🌲 Timber.io Ruby Installer - Great Ruby Logging Made *Easy*

 ^  ^  ^   ^      ___I_      ^  ^   ^  ^  ^   ^  ^
/|\\/|\\/|\\ /|\\    /\\-_--\\    /|\\/|\\ /|\\/|\\/|\\ /|\\/|\\
/|\\/|\\/|\\ /|\\   /  \\_-__\\   /|\\/|\\ /|\\/|\\/|\\ /|\\/|\\
/|\\/|\\/|\\ /|\\   |[]| [] |   /|\\/|\\ /|\\/|\\/|\\ /|\\/|\\
MESSAGE
  message.rstrip
end

#heroku_install(app) ⇒ Object



111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
# File 'lib/timber/cli/io/messages.rb', line 111

def heroku_install(app)
  command = "heroku drains:add #{app.heroku_drain_url}"
  copied = OSHelper.copy_to_clipboard(command)

  message = <<-MESSAGE
First, let's setup your Heroku drain. Run this command in a separate window:

    #{ANSI.colorize(command, :blue)}
MESSAGE
  message = message.rstrip

  if copied
    message << "\n    #{copied_to_clipboard}"
  end

  message
end

#http_environment_variables(api_key) ⇒ Object



70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
# File 'lib/timber/cli/io/messages.rb', line 70

def http_environment_variables(api_key)
  command = "export TIMBER_API_KEY=\"#{api_key}\""
  copied = OSHelper.copy_to_clipboard(command)

  message = <<-MESSAGE
Great! Add this variable to your environment:

    #{ANSI.colorize(command, :blue)}

MESSAGE
  message = message.rstrip

  if copied
    message << "\n    #{copied_to_clipboard}"
  end

  message
end

#no_api_key_providedObject



129
130
131
132
133
134
135
136
137
138
139
# File 'lib/timber/cli/io/messages.rb', line 129

def no_api_key_provided
  message = <<-MESSAGE
Hey there! Welcome to Timber. In order to proceed, you'll need an API key.
If you already have one, you can run this installer like:

    #{ANSI.colorize("bundle exec timber install my-api-key", :blue)}

#{obtain_key_instructions}
MESSAGE
  message.rstrip
end

#obtain_key_instructionsObject



141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
# File 'lib/timber/cli/io/messages.rb', line 141

def obtain_key_instructions
  message = <<-MESSAGE
Don't have a key? Head over to:

    #{ANSI.colorize(APP_URL, :blue)}

For a simple guide, checkout out:

    #{ANSI.colorize(OBTAIN_KEY_DOCS_URL, :blue)}

If you're stuck, contact us:

    #{ANSI.colorize(SUPPORT_EMAIL, :blue)}
MESSAGE
  message.rstrip
end

#separatorObject



158
159
160
# File 'lib/timber/cli/io/messages.rb', line 158

def separator
  "--------------------------------------------------------------------------------"
end

#spinner(iteration) ⇒ Object



162
163
164
165
166
167
168
169
170
171
172
# File 'lib/timber/cli/io/messages.rb', line 162

def spinner(iteration)
  rem = iteration % 3
  case rem
  when 0
    "/"
  when 1
    "-"
  when 2
    "\\"
  end
end

#successObject



178
179
180
# File 'lib/timber/cli/io/messages.rb', line 178

def success
  "✓ Success!"
end

#task_complete(message) ⇒ Object



182
183
184
185
186
187
# File 'lib/timber/cli/io/messages.rb', line 182

def task_complete(message)
  remainder = MAX_LENGTH - message.length - success.length

  dots = "." * remainder
  "\r#{message}#{dots}#{success}"
end

#task_failed(message) ⇒ Object



189
190
191
192
193
194
# File 'lib/timber/cli/io/messages.rb', line 189

def task_failed(message)
  remainder = MAX_LENGTH - message.length - failed.length

  dots = "." * remainder
  "\r#{message}#{dots}#{failed}"
end

#task_start(message) ⇒ Object



196
197
198
199
200
# File 'lib/timber/cli/io/messages.rb', line 196

def task_start(message)
  remainder = MAX_LENGTH - message.length - success.length

  "\r#{message}" + ("." * remainder)
end

#we_love_you_tooObject



202
203
204
# File 'lib/timber/cli/io/messages.rb', line 202

def we_love_you_too
  "Thanks! We 💖 you too!"
end