summaryrefslogtreecommitdiff
path: root/contrib/DNS-LDNS/lib/DNS/LDNS/DNSSecName.pm
blob: 0af91e2e4c32e9b449a0cce2d517595f354c0490 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
package DNS::LDNS::DNSSecName;

use 5.008008;
use strict;
use warnings;

use DNS::LDNS ':all';

our $VERSION = '0.52';

sub new {
    my $class = shift;
    return _new;
}

sub name {
    my $self = shift;
    return DNS::LDNS::GC::own($self->_name, $self);
}

sub set_name {
    my ($self, $name) = @_;

    DNS::LDNS::GC::disown(my $old = $self->name);
    _set_name($self, my $copy = $name->clone);
    DNS::LDNS::GC::own($copy, $self);
}

sub rrsets {
    my $self = shift;
    return DNS::LDNS::GC::own($self->_rrsets, $self);
}

sub add_rr {
    my ($self, $rr) = @_;

    my $s = _add_rr($self, my $copy = $rr->clone);
    DNS::LDNS::GC::own($copy, $self);
    $DNS::LDNS::last_status = $s;
    return $s;
}

sub nsec {
    my $self = shift;
    return DNS::LDNS::GC::own($self->_nsec, $self);
}

sub set_nsec {
    my ($self, $nsec) = @_;

    DNS::LDNS::GC::disown(my $old = $self->nsec);
    _set_nsec($self, my $copy = $nsec->clone);
    DNS::LDNS::GC::own($copy, $self);
}

sub hashed_name {
    my $self = shift;
    return DNS::LDNS::GC::own($self->_hashed_name, $self);
}

sub nsec_signatures {
    my $self = shift;
    return DNS::LDNS::GC::own($self->_nsec_signatures, $self);
}

sub DESTROY {
    DNS::LDNS::GC::free($_[0]);
}

1;
__END__

=head1 NAME

DNS::LDNS::DNSSecName - Dname with rrsets in a dnssec zone

=head1 SYNOPSIS

  use LDNS ':all'

  my name = new DNS::LDNS::DNSSecName

  rdata = name->name
  name->set_name(rdata)
  bool = name->is_glue
  rrsets = name->rrsets
  name->add_rr(rr)

  rr = name->nsec
  name->set_nsec(rr)
  hash = name->hashed_name
  rrs = name->nsec_signatures

=head1 SEE ALSO

http://www.nlnetlabs.nl/projects/ldns

=head1 AUTHOR

Erik Pihl Ostlyngen, E<lt>erik.ostlyngen@uninett.noE<gt>

=head1 COPYRIGHT AND LICENSE

Copyright (C) 2013 by UNINETT Norid AS

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

=cut