NAME

Net::SSH::AuthorizedKey::SSH1 - SSH version 1 public keys

SYNOPSIS

use Net::SSH::AuthorizedKey::SSH1;

  # Either parse a string (without leading whitespace or comments):
my $pubkey = Net::SSH::AuthorizedKey::SSH1->parse( $string );

  # ... or create an object yourself:
my $pubkey = Net::SSH::AuthorizedKey->new(
    options  => { from                  => 'foo@bar.com', 
                  "no-agent-forwarding" => 1 },
    key      => "123....890",
    keylen   => 1024,
    exponent => 35,
    type     => "ssh-1",
);

DESCRIPTION

Net::SSH::AuthorizedKey::SSH1 objects hold ssh version 1 public keys, typically extracted from an authorized_keys file.

The parse() method takes a line from an authorized_keys file (leading whitespace and comments need to be cleaned up beforehand), parses the data, and returns a Net::SSH::AuthorizedKey::SSH1 object which offers accessors for all relevant fields and a as_string() method to assemble it back together as a string.

Net::SSH::AuthorizedKey::SSH1 is a subclass of Net::SSH::AuthorizedKey::Base, which offers methods like error() and helpers to control key option settings.

FIELDS

All of the following fields are available via accessors:

type

Type of ssh key, usually "ssh-1".

key

Public key, either a long number (ssh-1) or a line of alphanumeric characters.

keylen

Length of the key in bit (e.g. 1024).

exponent

Two-digit number in front of the key in ssh-1 authorized_keys lines.

options

Returns a reference to a hash with options key/value pairs, listed in front of the key.

Implementation Reference

The key parsers implemented in this distribution are implemented similarily as the authorized_keys file parser in the openssh source distribution.

Openssh contains the authorized_keys parser in its auth2_pubkey.c file. The user_key_allowed2() function opens the file and reads it line by line, ignoring leading whitespace, empty and comment lines.

After that, if a line doesn't contain a plain key, the parser skips ahead until the first whitespace (zooming through quoted areas "..." and interpreting '\"' as an escaped quote), then skips this whitespace and tries to read a key one more time.

Regarding options, the Perl parser isn't as elaborate with semantic peculiarities as openssh's auth_parse_options(), but this might be added in the future.

LEGALESE

Copyright 2005-2009 by Mike Schilli, all rights reserved. This program is free software, you can redistribute it and/or modify it under the same terms as Perl itself.

AUTHOR

Mike Schilli <m@perlmeister.com>