This is a pure Crystal source (single file, fully documented) code, provides a minimum requisite functions for NNTP (Network News Transfer Protocol) clients, per RFC977, extensions RFC2980 and authentication DRAFT.
-
Add the dependency to your
shard.yml
:dependencies: nntp-lib: github: spoved/nntp-lib.cr
-
Run
shards install
The NNTP socket can be established via the start
method which yields itself to the provided block.
require "nntp-lib"
nntp = Net::NNTP.new("secure.usenetserver.com", 563)
nntp.start(user: "myuser", secret: "pass", :original) do |socket|
# Perform nntp requests here
end
The socket can also be started without a block, but finish
should be called to close the nntp session.
require "nntp-lib"
nntp = Net::NNTP.new("secure.usenetserver.com", 563)
nntp.start(user: "myuser", secret: "pass", :original)
# Perform nntp requests here
nntp.finish
- RFC977
- 3.4. The IHAVE command
- 3.10. The POST command
- RFC2980
- 1.3.1 The TAKETHIS command
- 1.4.1 The XREPLIC command
- 2.1.1 Extensions to the LIST command
- 2.2 LISTGROUP
- 2.4 XGTITLE
- 2.7 XINDEX
- 2.9 XPAT
- 2.10 The XPATH command
- 2.11 The XROVER command
- 2.12 XTHREAD
- 3.3 The WILDMAT format
- Misc commands
- xfeature compress gzip [terminator]
- xzver [range]
- xzhdr field [range]
- Fork it (https://github.com/spoved/nntp-lib.cr/fork)
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
- Holden Omans - creator and maintainer