perl_access hash value length limit?
    David E Mussulman 
    mussulma at illinois.edu
       
    Tue Jan 11 23:28:42 UTC 2011
    
    
  
Hi gang,
I think I've found a bug in INN 2.5.2 with the readers.conf perl_access
access() returned hash value length.  I added a bunch of newsgroups
today that pushed the character count in the 'read' key's value from
6456 characters to 8238 characters.  With a 'read' string that long, INN
didn't work anymore for incoming connections.  Syslog reported the error
"syntax error in (null)(2), Expected value." and terminated the
connection.
If I reverted my newsgroup adds from the flatfile that my perl_access
script uses to build the hash, back down to its this-morning length of
6456 characters, it worked again.  Add one or two newsgroups more and it
still worked.  So somewhere between those two value's character lengths,
INN stopped liking it.
I don't think perl cares, or that we've hit a limit in perl, since a
small test perl script that calls the same perl_access library and
simply prints out the resulting hash showed the thing in entirity
(that's how I was able to see the character counts).  I'm hoping it's
something simple like a buffer limit being hit in INN.
Backstory: We've been using INN for years to support internal newsgroups
for CS course discussions.  18 months ago we started naming the groups
per-semester (for more granular access control and versioning), but that
means each term we add 100 or so newsgroups.  Either wildmats didn't
work in the perl_access hash at one time, or we decided not to use them
but each newsgroup is enumerated individually in the read and post hash
values.  FWIW, I was able to squeeze all of this semester's groups in by
just putting a comma inbetween groups (I had comma-space before) and my
current length is 7803.  That'll get me through the start of the
semester, but I'll need a solution by summer.
Thanks for the help,
Dave
    
    
More information about the inn-workers
mailing list