Skip to content

Crystal lib to provide the minimum requisite functions for NNTP (Network News Transfer Protocol) for clients

License

Notifications You must be signed in to change notification settings

spoved/nntp-lib.cr

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

63 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

nntp-lib

Build Status Release Status Latest release

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.

Installation

  1. Add the dependency to your shard.yml:

    dependencies:
      nntp-lib:
        github: spoved/nntp-lib.cr
  2. Run shards install

Usage

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

Missing Features

  • 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]

Contributing

  1. Fork it (https://github.com/spoved/nntp-lib.cr/fork)
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request

Contributors

About

Crystal lib to provide the minimum requisite functions for NNTP (Network News Transfer Protocol) for clients

Resources

License

Stars

Watchers

Forks

Packages

No packages published