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.1KB

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