I've tried storing the data a few different ways.. and I always end up with the 
same 3 byte value stored in the database... which sounds like a memory pointer 
rather than data.   I found a specific reference under DBD:Pg about binary 
data.. and it suggests that you have to do an explicit bind and tell it you are 
passing binary data like so: 

bind_param(1, $cdr, { pg_type => PG_BYTEA })

You don't expose the DBI stuff directly though.. so it looks like that would 
require a change or code addition to your sql module to allow separate calls to 
prepare, bind, execute. 

I've not had time to setup a totally separate test to take Radiator out of the 
equation.. but that's my best guess as to why it's not working at the moment. 

J


On Jan 25, 2012, at 8:01 AM, Heikki Vatiainen wrote:

> On 01/25/2012 05:44 AM, Jared Watkins wrote:
> 
>> I figured out that I have to call it directly like Storable::nfreeze(\%x) 
>> but the error I was getting for other way was:
>> 
>> Bizarre copy of HASH in refgen at
>> 
>> Now.. I'm passing the value in as a bound parameter in the hook and 
>> according to a length call on the variable.. it's going in with an average 
>> length of 1450 bytes.  However.. when I fetch it from the database 
>> (postgres) I'm only getting back 3 bytes.
>> 
>> I'm using just the attributes list out of the $p variable by 
>> $p->{'Attributes'}.
> 
> Try @{$p->{Attributes}} if you want to access the attribute array
> instead of reference. Maybe you are already doing this, but I thought
> I'd check. Also Data::Dumper has sometimes been quite helpful figuring
> out how various items are composed.
> 
>> I've done binary data through DBI before (to mysql) without a problem.. so 
>> I'm not sure where it might be getting lost here. 
> 
> Hard to tell. I have not tried this myself.
> 
> Please keep us posted how it goes.
> 
> Thanks!
> Heikki
> 
>> Thanks,
>> Jared
>> 
>> 
>> On Jan 24, 2012, at 5:59 PM, Heikki Vatiainen wrote:
>> 
>>> On 01/24/2012 10:44 PM, Jared Watkins wrote:
>>> 
>>>> I'm seeing some weird errors and behavior trying to use the freeze method 
>>>> from Storable.  Is there a special trick to making it work in hook code? 
>>> 
>>> I have not used Storable myself, but if you could reply with some
>>> examples I can take a a look.
>>> 
>>> Note that some of the data structures, such as radius requests ($p
>>> usually) are very large. You could see e.g. with Data::Dumper to see
>>> what they look like.
>>> 
>>>> I saw a reference on the cpan page for special handling when used in a 
>>>> 'Safe' compartment.. is that what's happening here?   For reference.. for 
>>>> development/debugging I'm attempting to serialize and store (in db field) 
>>>> a hash I'm creating with all the per packet name-value pairs.
>>> 
>>> Hard to tell. Examples would be useful :)
>>> 
>>> Thanks!
>>> Heikki
>>> 
>>> -- 
>>> Heikki Vatiainen <h...@open.com.au>
>>> 
>>> Radiator: the most portable, flexible and configurable RADIUS server
>>> anywhere. SQL, proxy, DBM, files, LDAP, NIS+, password, NT, Emerald,
>>> Platypus, Freeside, TACACS+, PAM, external, Active Directory, EAP, TLS,
>>> TTLS, PEAP, TNC, WiMAX, RSA, Vasco, Yubikey, MOTP, HOTP, TOTP,
>>> DIAMETER etc. Full source on Unix, Windows, MacOSX, Solaris, VMS,
>>> NetWare etc.
>> 
>> _______________________________________________
>> radiator mailing list
>> radiator@open.com.au
>> http://www.open.com.au/mailman/listinfo/radiator
> 
> 
> -- 
> Heikki Vatiainen <h...@open.com.au>
> 
> Radiator: the most portable, flexible and configurable RADIUS server
> anywhere. SQL, proxy, DBM, files, LDAP, NIS+, password, NT, Emerald,
> Platypus, Freeside, TACACS+, PAM, external, Active Directory, EAP, TLS,
> TTLS, PEAP, TNC, WiMAX, RSA, Vasco, Yubikey, MOTP, HOTP, TOTP,
> DIAMETER etc. Full source on Unix, Windows, MacOSX, Solaris, VMS,
> NetWare etc.

_______________________________________________
radiator mailing list
radiator@open.com.au
http://www.open.com.au/mailman/listinfo/radiator

Reply via email to