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 6.3KB

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