newsfeeds(5)


NAME

   newsfeeds - determine where Usenet articles get sent

DESCRIPTION

   The  file /etc/news/newsfeeds specifies how incoming articles should be
   distributed to other sites.  It is parsed by  the  InterNetNews  server
   innd(8) when it starts up, or when directed to by ctlinnd(8).

   The  file  is  interpreted as a set of lines according to the following
   rules.  If a line ends  with  a  backslash,  then  the  backslash,  the
   newline,  and  any whitespace at the start of the next line is deleted.
   This is repeated until the entire ``logical'' line  is  collected.   If
   the  logical line is blank, or starts with a number sign (``#''), it is
   ignored.

   All other lines are interpreted  as  feed  entries.   An  entry  should
   consist  of  four  colon-separated  fields;  two of the fields may have
   optional sub-fields, marked off by a slash.  Fields or sub-fields  that
   take  multiple  parameters  should  be  separated  by  a  comma.  Extra
   whitespace can cause problems.  Except for  the  site  names,  case  is
   significant.  The format of an entry is:
          sitename[/exclude,exclude,...]\
               :pattern,pattern...[/distrib,distrib...]\
               :flag,flag...\
               :param
   Each field is described below.

   The  sitename  is  the  name of the site to which a news article can be
   sent.  It is used for writing log entries and  for  determining  if  an
   article  should be forwarded to a site.  If sitename already appears in
   the article's Path header, then the article will not  be  sent  to  the
   site.   The  name  is usually whatever the remote site uses to identify
   itself in the Path line, but can be almost any word that  makes  sense;
   special  local  entries (such as archivers or gateways) should probably
   end with an exclamation point to make sure that they do  not  have  the
   same  name  as  any  real site.  For example, ``gateway'' is an obvious
   name for the local entry that forwards articles out to a mailing  list.
   If  a  site  with the name ``gateway'' posts an article, when the local
   site receives the article it will see the name in the Path and not send
   the  article to its own ``gateway'' entry.  See also the description of
   the ``Ap'' flag, below.  If an entry has an exclusion  sub-field,  then
   the article will not be sent to that site if any of the names specified
   as excludes appear in the Path header.  The same sitename can  be  used
   more  than  once  --- the appropriate action will be taken for each entry
   that should receive the article, regardless of the name --- although this
   is  recommended only for program feeds to avoid confusion.  Case is not
   significant in site names.

   The patterns  specify  which  groups  to  send  to  the  site  and  are
   interpreted to build a ``subscription list'' for the site.  The default
   subscription is to get all groups.   The  patterns  in  the  field  are
   wildmat(3)-style patterns, and are matched in order against the list of
   newsgroups that the local site receives.  If the first character  of  a
   pattern  is  an  exclamation mark, then any groups matching the pattern
   are removed from the subscription, otherwise any  matching  groups  are
   added.    For  example,  to  receive  all  ``comp''  groups,  but  only
   comp.sources.unix within the sources newsgroups, the following  set  of
   patterns can be used:
          comp.*,!comp.sources.*,comp.sources.unix
   There  are  three things to note about this example.  The first is that
   the trailing ``.*'' is required.  The second is that, again, the result
   of   the  last  match  is  the  most  important.   The  third  is  that
   ``comp.sources.*'' could be written as ``comp.sources*'' but this would
   not have the same effect if there were a ``comp.sources-only'' group.

   There is also a way to subscribe to a newsgroup negatively.  That is to
   say, do not send this group even if the article is  cross-posted  to  a
   subscribed newsgroup.  If the first character of a pattern is an atsign
   ``@'', it means that any article posted to a group matching the pattern
   will not be sent even though the article may be cross-posted to a group
   which is subscribed.  The same rules of precedence apply  in  that  the
   last  match  is  the  one  which  counts.   For example, if you want to
   prevent all articles posted  to  any  "alt.binaries.warez"  group  from
   being  propagated  even if it is cross-posted to another "alt" group or
   any other group for that matter, then the following set of patterns can
   be used:
          alt.*,@alt.binaries.warez.*,misc.*
   If  you  reverse  the alt.* and alt.binaries.warez.* patterns, it would
   nullify the atsign because the result of the last match is the one that
   counts.   Using  the  above  example, if an article is posted to one or
   more  of  the  alt.binaries.warez.*  groups  and  is  cross-posted   to
   misc.test, then the article is not sent.

   See innd(8) for details on the propagation of control messages.

   A  subscription can be further modified by specifying ``distributions''
   that the site should or should not receive.  The default is to send all
   articles  to all sites that subscribe to any of the groups where it has
   been posted , but if an article  has  a  Distribution  header  and  any
   distribs  are  specified,  then  they  are  checked  according  to  the
   following rules:

   1.     If the Distribution header matches any of the values in the sub-
          field, then the article is sent.

   2.     If  a  distrib  starts with an exclamation point, and it matches
          the Distribution header, then the article is not sent.

   3.     If Distribution header does not match any distrib in the  site's
          entry, and no negations were used, then the article is not sent.

   4.     If  Distribution header does not match any distrib in the site's
          entry, and any distrib started with an exclamation  point,  then
          the article is sent.

   If  an  article has more than one distribution specified, then each one
   is according to the above rules.  If any of the specified distributions
   indicate  that the article should be sent, it is; if none do, it is not
   sent --- the rules are used as a ``logical or.''  It is almost definitely
   a mistake to have a single feed that specifies distributions that start
   with an exclamation point along with some that don't.

   Distributions are text words,  not  patterns;  entries  like  ``*''  or
   ``all'' have no special meaning.

   The  flags  parameter  specifies miscellaneous parameters.  They may be
   specified in any order; flags that take values should  have  the  value
   immediately  after the flag letter with no whitespace.  The valid flags
   are:

   <size  An article will only be sent to the site if it is less than size
          bytes long.  The default is no limit.

   >size  An  article  will only be sent to the site if it is greater than
          size bytes long.  The default is no limit.

   Achecks
          An article will only be  sent  to  the  site  if  it  meets  the
          requirements  specified  in  the  checks, which should be chosen
          from the following set:
               d    Distribution header required
               p    Do not check Path header for the sitename before
                    propagating (the exclusions are still checked).

   Bhigh/low
          If a site is being fed by a  file,  channel,  or  exploder  (see
          below),  the  server  will  normally  start  trying to write the
          information as soon as possible.  Providing a  buffer  may  give
          better  system performance and help smooth out overall load if a
          large batch of news comes in.  The value of the this flag should
          be  two  numbers  separated by a slash.  The first specifies the
          point at which the server can  start  draining  the  feed's  I/O
          buffer,  and the second specifies when to stop writing and begin
          buffering again; the units are bytes.  The default is to  do  no
          buffering, sending output as soon as it is possible to do so.

   Fname  This  flag specifies the name of the file that should be used if
          it is necessary to begin spooling for the site (see below).   If
          name  is not an absolute pathname, it is taken to be relative to
          /var/spool/news/out.going.   Then,  if  the  destination  is   a
          directory,  the  file  togo  in  that  directory will be used as
          filename.

   Gcount If this flag is specified, an article will only be sent  to  the
          site if it is posted to no more than count newsgroups.

   Hcount If  this  flag is specified, an article will only be sent to the
          site if it has count or fewer sites in its Path line.  This flag
          should  only  be  used  as  a  rough  guide because of the loose
          interpretation of the Path header; some sites put  the  poster's
          name  in  the  header,  and  some  sites that might logically be
          considered to be one hop become two because they put the posting
          workstation's  name  in the header.  The default value for count
          is one.

   Isize  The flag specifies the size of the internal buffer  for  a  file
          feed.   If there are more file feeds then allowed by the system,
          they will be buffered internally in  least-recently-used  order.
          If  the  internal  buffer grows bigger then size bytes, however,
          the data will be written  out  to  the  appropriate  file.   The
          default value is (16 * 1024) bytes.

   Nmodifiers
          The  newsgroups  that  a site receives are modified according to
          the modifiers, which should be chosen from the following set:
               m    Only moderated groups
               u    Only unmoderated groups

   Ssize  If the amount of data queued for the site gets to be larger than
          size  bytes,  then the server will switch to spooling, appending
          to   a    file    specified    by    the    ``F''    flag,    or
          /var/spool/news/out.going/  sitename  if  the  ``F'' flag is not
          specified.   Spooling  usually  happens  only  for  channel   or
          exploder feeds.

   Ttype  This  flag specifies the type of feed for the site.  Type should
          be a letter chosen from the following set:
               c    Channel
               f    File
               l    Log entry only
               m    Funnel (multiple entries feed into one)
               p    Program
               x    Exploder
          Each feed is described below in the section on feed types.   The
          default is Tf.

   Witems If  a  site  is  fed  by  file,  channel, or exploder, this flag
          controls what information is written.  If a site  is  fed  by  a
          program,  only  the  asterisk (``*'') has any effect.  The items
          should be chosen from the following set:
               b    Size of the article in bytes
               f    Article's full pathname
               g    The newsgroup the article is in;
                    if cross-posted, then the first of the groups this
                    site gets
               m    Article's Message-ID
               n    Article's pathname relative to the spool directory
               p    The time the article was posted as seconds since epoch.
               s    The site that fed the article to the server;
                    from the Path header
               t    Time article was received as seconds since epoch
               *    Names of the appropriate funnel entries;
                    or all sites that get the article
               D    Value of the Distribution header;
                    ? if none present
               H    All headers
               N    Value of the Newsgroups header
               O    Overview data
               R    Information needed for replication
               P    Path header information needed for inpaths
          More than one letter can be used; the entries will be  separated
          by  a  space,  and  written  in  the  order  in  which  they are
          specified.  The default is Wn.

          The ``H'' and ``O'' items are intended for use by programs  that
          create  news  overview databases.  If ``H'' is present, then the
          all the article's headers are written followed by a blank  line.
          An  Xref  header  (even  if  one  does  not  appear in the filed
          article) and a Bytes header, specifying the article's size, will
          also  be  part of the headers.  If used, this should be the only
          item in the list;  if  preceeded  by  other  items,  however,  a
          newline will be written before the headers.  The ``O'' generates
          input to the overchan(8) program.  It, too, should be  the  only
          item in the list.

          The  asterisk  has  special  meaning.   It  expands  to a space-
          separated list of all sites that received the  current  article.
          If the site is the target of a funnel however (i.e., it is named
          by other sites which have a  ``Tm''  flag),  then  the  asterisk
          expands  to  the  names  of  the  funnel feeds that received the
          article.  If the site is fed by a program, then an  asterisk  in
          the  param  field will be expanded into the list of funnel feeds
          that received the article.  A site fed by a program  cannot  get
          the site list unless it is the target of other ``Tm'' feeds.

   The  interpretation of the param field depends on the type of feed, and
   is explained in more detail below in the section on feed types.  It can
   be omitted.

   The site named ME is special.  There should only be one such entry, and
   it should be the first entry in the  file.   If  the  ME  entry  has  a
   subscription  list,  then  that  list is automatically prepended to the
   subscription   list   of   all    other    entries.     For    example,
   ``*,!control,!junk,!foo.*''   can   be  used  to  set  up  the  initial
   subscription list  for  all  feeds  so  that  local  postings  are  not
   propagated unless ``foo.* explicitly appears in the site's subscription
   list.  Note that most subscriptions should have  ``!junk,!control''  in
   their  pattern  list;  see  the  discussion  of ``control messages'' in
   innd(8).  (Unlike other news software, it does not affect  what  groups
   are received; that is done by the active(5) file.)

   If  the  ME  entry has a distribution subfield, then only articles that
   match the distribution  list  are  accepted;  all  other  articles  are
   rejected.    A   commercial   news  server,  for  example,  might  have
   ``/!local'' to reject local postings from other, misconfigured, sites.

   FEED TYPES
   Innd provides four basic  types  of  feeds:  log,  file,  program,  and
   channel.   An  exploder  is  a  special  type of channel.  In addition,
   several entries can feed into the same feed; these  are  funnel  feeds,
   that  refer  to an entry that is one of the other types.  Note that the
   term ``feed'' is technically a misnomer,  since  the  server  does  not
   transfer  articles,  but  reports that an article should be sent to the
   site.

   The simplest feed is one that is fed by a  log  entry.   Other  than  a
   mention  in  the  news  logfile,  no data is ever written out.  This is
   equivalent to a ``Tf'' entry writing to /dev/null except that  no  file
   is opened.

   A  site  fed  by a file is simplest type of feed.  When the site should
   receive an article, one line is written to the file named by the  param
   field.   If  param  is  not  an  absolute  pathname,  it is taken to be
   relative to /var/spool/news/out.going.  If empty, the filename defaults
   to /var/spool/news/out.going/sitename.  This name should be unique.

   When a site fed by a file is flushed (see ctlinnd), the following steps
   are performed.  The script doing the flush should  have  first  renamed
   the  file.   The  server tries to write out any buffered data, and then
   closes the file.  The renamed file  is  now  available  for  use.   The
   server will then re-open the original file, which will now get created.

   A  site  fed  by a program has a process spawned for every article that
   the site receives.  The param field must be a sprintf(3) format  string
   that may have a single %s parameter, which will be given a pathname for
   the article, relative to the news spool directory.  The full path  name
   may  be  obtained  by  prefixing  the %s in the param field by the news
   spool directory prefix.  Standard input will be set to the  article  or
   /dev/null  if  the  article cannot be opened for some reason.  Standard
   output and error will be set to the error log.  The  process  will  run
   with  the  user and group ID of the /run/innd directory.  Innd will try
   to avoid spawning a shell if the command has no shell  meta-characters;
   this  feature  can  be defeated by appending a semi-colon to the end of
   the command.  The full pathname of  the  program  to  be  run  must  be
   specified; for security, PATH is not searched.

   If the entry is the target of a funnel, and if the ``W*'' flag is used,
   then a single asterisk may be used in the param field where it will  be
   replaced  by  the  names of the sites that fed into the funnel.  If the
   entry is not a funnel, or if the ``W*'' flag  is  not  used,  then  the
   asterisk has no special meaning.

   Flushing a site fed by a program does no action.

   When  a site is fed by a channel or exploder, the param field names the
   process to start.  Again, the full pathname  of  the  process  must  be
   given.   When the site is to receive an article, the process receives a
   line on its standard input telling  it  about  the  article.   Standard
   output  and error, and the user and group ID of the all sub-process are
   set as for a program feed, above.  If the process  exits,  it  will  be
   restarted.   If  the  process  cannot be started, the server will spool
   input to a file named /var/spool/news/out.going/sitename.  It will then
   try to start the process some time later.

   When  a site fed by a channel or exploder is flushed, the server closes
   down its end of the pipe.  Any pending data that has not  been  written
   will  be  spooled;  see  the  description of the ``S'' flag, above.  No
   signal is sent; it is up to the program to notice EOF on  its  standard
   input and exit.  The server then starts a new process.

   Exploders  are  a  superset  of  channel feeds.  In addition to channel
   behavior, exploders can be sent command lines.  These lines start  with
   an  exclamation  point, and their interpretation is up to the exploder.
   The following messages are generated automatically by the server:
          newgroup group
          rmgroup group
          flush
          flush site
   These messages are sent when the ctlinnd command of the  same  name  is
   received  by the server.  In addition, the ``send'' command can be used
   to send an arbitrary command line to the exploder  child-process.   The
   primary exploder is buffchan(8).

   Funnel  feeds  provide  a  way  of  merging several site entries into a
   single output stream.  For a site feeding  into  a  funnel,  the  param
   field names the actual entry that does the feeding.

   For  more  details on setting up different types of news feeds, see the
   INN installation manual.

EXAMPLES

          ##  Initial subscription list and our distributions.
          ME:*,!junk,!foo.*/world,usa,na,ne,foo,ddn,gnu,inet\
               ::
          ##  Feed all moderated source postings to an archiver
          source-archive!:!*,*sources*,!*wanted*,!*.d\
               :Tc,Wn:/usr/lib/news/bin/archive -f -i \
                   /usr/spool/news.archive/INDEX
          ##  Watch for big postings
          watcher!:*\
               :Tc,Wbnm\
               :exec awk '$1 > 1000000 { print "BIG", $2, $3 }' >/dev/console
          ##  A UUCP feed, where we try to keep the "batching" between 4 and 1K.
          ihnp4:/world,usa,na,ddn,gnu\
               :Tf,Wnb,B4096/1024:
          ##  Usenet as mail; note ! in funnel name to avoid Path conflicts.
          ##  Can't use ! in "fred" since it would like look a UUCP address.
          fred:!*,comp.sources.unix,comp.sources.bugs\
               :Tm:mailer!
          barney@bar.com:!*,news.software.nntp,comp.sources.bugs\
               :Tm:mailer!
          mailer!:!*\
               :W*,Tp:/usr/ucb/Mail -s "News article" *
          ##  NNTP feeds fed off-line via nntpsend or equivalent.
          feed1::Tf,Wnm:feed1.domain.name
          peer.foo.com:foo.*:Tf,Wnm:peer.foo.com
          ##  Real-time transmission.
          mit.edu:/world,usa,na,ne,ddn,gnu,inet\
               :Tc,Wnm:/usr/lib/news/bin/nntplink -i stdin mit.edu
          ##  Two sites feeding into a hypothetical NNTP fan-out program:
          nic.near.net:\
               :Tm:nntpfunnel1
          uunet.uu.net/uunet:!ne.*/world,usa,na,foo,ddn,gnu,inet\
               :Tm:nntpfunnel1
          nntpfunnel1:!*\
               :Tc,Wmn*:/usr/lib/news/bin/nntpfanout
          ##  A UUCP site that wants comp.* and moderated soc groups
          uucpsite!comp:!*,comp.*/world,usa,na,gnu\
               :Tm:uucpsite
          uucpsite!soc:!*,soc.*/world,usa,na,gnu\
               :Tm,Nm:uucpsite
          uucpsite:!*\
               :Tf,Wnb:/usr/spool/batch/uucpsite

   The last two sets of entries show how funnel feeds can  be  used.   For
   example,  the nntpfanout program would receive lines like the following
   on its standard input:
          <123@litchi.foo.com> comp/sources/unix/888 nic.near.net uunet.uu.net
          <124@litchi.foo.com> ne/general/1003 nic.near.net
   Since the UUCP funnel is only destined for one site,  the  asterisk  is
   not  needed  and  entries  like  the following will be written into the
   file:
          <qwe#37x@snark.uu.net> comp/society/folklore/3
          <123@litchi.foo.com> comp/sources/unix/888

HISTORY

   Written by Rich $alz <rsalz@uunet.uu.net> for  InterNetNews.   This  is
   revision 1.35, dated 1996/12/17.

SEE ALSO

   active(5), buffchan(8), ctlinnd(8), innd(8), wildmat(3).

                                                              NEWSFEEDS(5)





Opportunity


Personal Opportunity - Free software gives you access to billions of dollars of software at no cost. Use this software for your business, personal use or to develop a profitable skill. Access to source code provides access to a level of capabilities/information that companies protect though copyrights. Open source is a core component of the Internet and it is available to you. Leverage the billions of dollars in resources and capabilities to build a career, establish a business or change the world. The potential is endless for those who understand the opportunity.

Business Opportunity - Goldman Sachs, IBM and countless large corporations are leveraging open source to reduce costs, develop products and increase their bottom lines. Learn what these companies know about open source and how open source can give you the advantage.





Free Software


Free Software provides computer programs and capabilities at no cost but more importantly, it provides the freedom to run, edit, contribute to, and share the software. The importance of free software is a matter of access, not price. Software at no cost is a benefit but ownership rights to the software and source code is far more significant.


Free Office Software - The Libre Office suite provides top desktop productivity tools for free. This includes, a word processor, spreadsheet, presentation engine, drawing and flowcharting, database and math applications. Libre Office is available for Linux or Windows.





Free Books


The Free Books Library is a collection of thousands of the most popular public domain books in an online readable format. The collection includes great classical literature and more recent works where the U.S. copyright has expired. These books are yours to read and use without restrictions.


Source Code - Want to change a program or know how it works? Open Source provides the source code for its programs so that anyone can use, modify or learn how to write those programs themselves. Visit the GNU source code repositories to download the source.





Education


Study at Harvard, Stanford or MIT - Open edX provides free online courses from Harvard, MIT, Columbia, UC Berkeley and other top Universities. Hundreds of courses for almost all major subjects and course levels. Open edx also offers some paid courses and selected certifications.


Linux Manual Pages - A man or manual page is a form of software documentation found on Linux/Unix operating systems. Topics covered include computer programs (including library and system calls), formal standards and conventions, and even abstract concepts.