Skip to content

Kotlin rewrite of WeatherBot. Uses ForecastIO-Lib-Java for weather, and PircBotX for IRC.

License

Notifications You must be signed in to change notification settings

ElbowBaggins/WeatherBotKt

Repository files navigation

WeatherBotKt

Kotlin rewrite of WeatherBot, linking against dvdme's ForecastIO-Lib-Java for weather data and TheLQ's PircBotX for IRC capabilities. Provided under the MIT License.

Oh, and it works with Slack over their IRC gateway.

Configuration

Edit the provided config.json file to fit your needs. If autoReconnectAttemps is -1, it will attempt to reconnect forever (up to Int.MAX_VALUE times, anyway). Setting it to zero disables automatic reconnection. The channels field is an array. The rest ought to be self-explanatory.

The config file needs to be in the same folder as the jar.

Building

Use the Gradles

Running

 java -jar <name of jar file> <-IRC|-TS3|-BOTH>

That's it, at least to get minimally up and running. I would suggest you write a launch script that stores the PID of the executing JVM in a temporary file and a shutdown script so that you can send SIGTERM to the corresponding process so you can handle everything all clean-like. I would also HIGHLY suggest you redirect the screen output (which is just logging) to a file if you're running into trouble or to /dev/null if you don't care.

To stop WeatherBot, send SIGTERM to the appropriate process. (Determining this is up to you, for now. I will provide the script I use in the future.) It will shut down and part from all joined channels gracefully.

Supported Commands

Utility Commands

  • .wbhelp - Replies with a help message that outlines available commands
  • .setlocation - Sets the user's location so that they may invoke any of the following commands without the location parameter

Weather Data Commands

All of the following take one parameter, the location one wishes to see weather data for. If the user has already set their location with .setlocation this parameter is optional.

  • .w - Provides data with automatic, region-based units)
  • .wf (Provides data with "American" units)
  • .wc (Provides data with SI units)
  • .wca (Provides data with "Canadian" units)
  • .wuk (Provides data with "British" units)

All of the following are identical to their preceding siblings but provide more "long-form" detail

  • .wlong
  • .wflong
  • .wclong
  • .wcalong
  • .wuklong

About

Kotlin rewrite of WeatherBot. Uses ForecastIO-Lib-Java for weather, and PircBotX for IRC.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages