NAME

Iodef::Pb - Perl extension for generating IODEF protocol buffer objects

SYNOPSIS

use Data::Dumper;
use Iodef::Pb;
my $c = ContactType->new({
    ContactName => MLStringType->new({
        lang    => 'EN',
        content => 'Wes Young',
    }),
    Timezone    => 'UTC',
    type    => ContactType::ContactType::Contact_type_person(),
    role    => ContactType::ContactRole::Contact_role_irt(),
});

my $address = AddressType->new({
    category    => AddressType::AddressCategory::Address_category_ipv4_addr(),
    content     => '1.2.3.4',
});

my $event = EventDataType->new({
    DetectTime  => '2011-01-1T00:00:00Z',
    Flow        => FlowType->new({
        System  => SystemType->new({
            Node    => NodeType->new({
                Address => $address
            }),
            category    => SystemType::SystemCategory::System_category_infrastructure()
        }),
    }),
});

my $i = IODEFDocumentType->new({
    lang    => 'EN',
    Incident    => [
        IncidentType->new({
            IncidentID  => IncidentIDType->new({
                name    => 'name',
                content => 'content....',
            }),
            ReportTime  => '2011-01-01T00:00:00Z',
            purpose     => IncidentType::IncidentPurpose::Incident_purpose_mitigation(),
            Contact     => [$c],
            EventData   => $event,
        }),
    ],
});

warn Dumper(@{$i->get_Incident()}[0]);
my $buf = $i->encode();
warn $buf;
warn Dumper(IODEFDocumentType->decode($buf));

DESCRIPTION

This library maps IODEF (RFC 5070) to the google protocol buffer serialization library. The lib/Iodef/_Pb.pm file is generated using Google::ProtocolBuffers library based on iodef.proto (github.com/collectiveintel/IODEF). This lib should only be used for low level API access. High level API access can be leveraged via the Iodef::Pb::Simple API.

Once the buffer's are encoded, they can easily be transported via REST, ZeroMQ, Crossroads.io or any other messaging framework (or the google protocol RPC bits themselves). To store these in a database, you can easily base64 the data-structure and save as text.

EXPORT

None by default. Object Oriented.

SEE ALSO

http://github.com/collectiveintel/iodef-pb-perl
http://github.com/collectiveintel/iodef-pb-simple-perl
https://github.com/collectiveintel/IODEF
http://tools.ietf.org/html/rfc5070#section-3.2
http://search.cpan.org/~gariev/Google-ProtocolBuffers/lib/Google/ProtocolBuffers.pm
http://code.google.com/p/protobuf/
http://search.cpan.org/~kasei/Class-Accessor/lib/Class/Accessor.pm
http://collectiveintel.net

AUTHOR

Wes Young, <wes@barely3am.com>

COPYRIGHT AND LICENSE

Copyright (C) 2012 by Wes Young <claimid.com/wesyoung>
Copyright (C) 2012 the REN-ISAC <ren-isac.net>
Copyright (C) 2012 the trustee's of Indiana University <iu.edu>

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.10.1 or, at your option, any later version of Perl 5 you may have available.