Class: Waylon::Skills::Db2docs
- Inherits:
-
Waylon::Skill
- Object
- Waylon::Skill
- Waylon::Skills::Db2docs
- Defined in:
- lib/waylon/skills/db2docs.rb
Overview
Lets Waylon tell some jokes
Constant Summary collapse
- IBM_DB2_ERROR_CODE_RANGES_URL =
"https://www.ibm.com/docs/en/db2/11.5?topic=messages-sql"
- IBM_DB2_ERROR_DOC_BASE =
"https://www.ibm.com/docs/en/SSEPGG_11.5.0/com.ibm.db2.luw.messages.sql.doc"
Instance Method Summary collapse
Instance Method Details
#db2_error_code_ranges ⇒ Object
36 37 38 39 40 41 42 43 44 45 |
# File 'lib/waylon/skills/db2docs.rb', line 36 def db2_error_code_ranges cache("db2_error_code_ranges", expires: 86_400) do conn = Faraday.new response = conn.get(IBM_DB2_ERROR_CODE_RANGES_URL) raw_ranges = response.body.scan(/SQL[0-9]+\s-\sSQL[0-9]+/) break [] if raw_ranges.empty? raw_ranges.to_h { |r| [r, Range.new(*r.gsub("SQL", "").split(" - ").map(&:to_i))] } end end |
#lookup_db2_error_message ⇒ Object
20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 |
# File 'lib/waylon/skills/db2docs.rb', line 20 def error_number = tokens.first error_letter = tokens.last.downcase range = db2_error_code_ranges.find { |_name, r| r.include?(error_number.to_i) } if range threaded_reply( "Hey, that looks like an IBM Db2 SQL Error code! This link that might be of interest: " \ "#{IBM_DB2_ERROR_DOC_BASE}/#{range.first.downcase.gsub(/\s/, "")}.html#sql#{error_number}#{error_letter}" ) else threaded_reply("I'm having trouble finding that SQL error code on IBM's site") end end |