You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

CHANGELOG 5.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. vNEXT (in development)
  2. * Batch start and end events are no longer included in BatchReceived events
  3. * Batches now expose complete metadata from their start event
  4. * Added support for labelled-replies capability and label message tags
  5. * Added new methods for sending raw lines to the IRC server
  6. * send(tagMap(...), command, arguments) replaces send(line)
  7. * send(command, arguments) is available if no tags are to be sent
  8. * the line is built automatically (with spaces/' :' added appropriately)
  9. * send(line) is deprecated and will be removed after v1.0.0
  10. * (Internal) Added annotation to track removal of deprecated methods
  11. v0.9.0
  12. * Improve DSL for creating an IrcClient to allow parameters to be passed to server and profile
  13. e.g. IrcClient { server("irc.example.com", 6667) }
  14. * Add behaviour options
  15. * requestModesOnJoin - automatically sends a MODE request when joining a channel
  16. * Events now have a `metadata` property instead of a `time` (and time is available in metadata)
  17. * IrcEvent.time is now deprecated but will remain until after v1.0.0.
  18. * Metadata now contains the message ID, if any.
  19. * ActionReceived.messageId and MessageReceived.messageId are now deprecated, to be removed after v1.0.0.
  20. * Metadata now contains the event's batch ID, if any.
  21. * Added support for batches
  22. * All events in a batch are buffered until the batch is finished
  23. * The events are then published together in a single `BatchReceived` event
  24. * Added support for CHGHOST messages
  25. * (Internal) Improve performance when the MessageHandler is finding a processor for a message
  26. * (Internal) Introduced event mutators
  27. * Event mutators are now responsible for handling changing events in response to state
  28. e.g. ChannelFanOutMutator creates Channel* events for global quits/nick changes/etc
  29. * Event handlers now just handle events, and don't return anything
  30. v0.8.0
  31. * Added support for SCRAM-SHA-1 and SCRAM-SHA-256 SASL mechanisms
  32. * Added MotdLineReceived event
  33. * Added topic events and state
  34. * Add utility method IrcClient.isChannel(String) to identify if a target is a channel or not
  35. * (Internal) Move event handlers into their own package
  36. v0.7.0
  37. * Fixed experimental API warnings when using IrcClient
  38. * IrcClients are now constructed using a DSL
  39. * Users of the library no longer need to care about the implementing class
  40. * Facilitates adding more options in the future without breaking existing implementations
  41. * SASL improvements
  42. * The enabled mechanisms can now be configured (in the SASL DSL)
  43. * Added support for EXTERNAL mechanism, disabled by default
  44. * Now attempts to renegotiate if the server doesn't recognise the SASL mechanism that was tried
  45. * Added UserNickChanged and corresponding ChannelNickChanged events
  46. * Added ServerConnectionError, raised when connecting to the server fails
  47. * (Internal) Minor version updates for Gradle, Kotlin and JUnit
  48. v0.6.0
  49. * Changed USER command to not send the server name, per modern standards
  50. * Added support for SASL authentication (with PLAIN mechanism)
  51. * Removed some unused test code
  52. * Fixed handling of user mode changes on channels (op/deop/etc)
  53. * Message extensions:
  54. * Added support for IRCv3 message tags v3.3
  55. * Exposed message IDs in MessageReceived and ActionReceived events
  56. * When sending a message you can now indicate what it is in reply to
  57. * Added sendTagMessage() to send message tags without any content
  58. * The reply() utility automatically marks messages as a reply
  59. * Added react() utility to send a reaction client tag
  60. * State is now reset when the client is disconnected, so you can immediately reconnect
  61. * (Internal) improved how coroutines and channels are used in LineBufferedSocket
  62. v0.5.0
  63. * Server state:
  64. * Added ServerConnecting and ServerDisconnected events
  65. * Server status now starts as Disconnected rather than Connecting
  66. * Improved error message when features are of an unexpected type
  67. * Channel modes:
  68. * CHANMODES feature is now stored as an array, not a single comma-separated string
  69. * Added ChanModeType enum, and method in ServerState to get the type of a mode
  70. * Added ModeChanged event, for user and channel mode changes and discovery
  71. * Added modes and modesDiscovered to ChannelState
  72. * Other new events:
  73. * Added MotdFinished event
  74. * Added UserAccountChanged event
  75. * Added ChannelUserKicked event
  76. * Added NoticeReceived event
  77. * Added CtcpReplyReceived event
  78. * Improved some documentation
  79. v0.4.0
  80. * Added CtcpReceived and ActionReceived events
  81. * Added sendCtcp and sendAction message builders
  82. * Fix issue with messages being sent out of order, which sometimes caused problems connecting to passworded servers
  83. * Added 'network' server feature
  84. * Added serverName field to ServerState
  85. v0.3.1
  86. * Added more documentation to public methods/classes
  87. * Fixed exception when sending multiple lines at once (e.g. when connecting!)
  88. v0.3.0
  89. * Simplified how messages are constructed.
  90. Instead of: client.send(joinMessage("#channel"))
  91. Now use: client.sendJoin("#channel")
  92. * Added reply utility to easily send replies to message events
  93. * Server state improvements:
  94. * Added status field to ServerState
  95. * ServerConnected event is emitted as soon as the socket is connected
  96. * ServerReady event is emitted after logging in, negotiating, etc
  97. * Added extra debugging to show what type of events are being dispatched
  98. * Added ChannelQuit event, raised for each channel a user is in when they quit
  99. * (Internal) Event handlers can now return more events to emit
  100. v0.2.1
  101. * Added documentation and reduced visibility of some internal methods/classes
  102. * (Internal) Enabled Travis, Codacy and Coveralls
  103. v0.2.0
  104. * Added support for connecting over TLS
  105. * Simplified how event handlers are registered
  106. * Improved use of coroutines so users don't have to worry about them
  107. * (Internal) Upgraded to Gradle 5.1.1