test_draft_keyprov.doctest - test for examples from draft-hoyer-keyprov-pskc-algorithm-profiles-01 Copyright (C) 2014-2015 Arthur de Jong This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA >>> def tostr(x): ... return str(x.decode()) >>> from pskc import PSKC This tests an OCRA (OATH Challenge Response Algorithm) key contained within a PSKC file as described in section 3 of draft-hoyer-keyprov-pskc-algorithm-profiles-01. >>> pskc = PSKC('tests/draft-hoyer-keyprov-pskc-algorithm-profiles-01/ocra.pskcxml') >>> pskc.version '1.0' >>> key = pskc.keys[0] >>> key.manufacturer 'TokenVendorAcme' >>> key.serial '987654322' >>> key.id '12345678' >>> key.algorithm 'urn:ietf:params:xml:ns:keyprov:pskc#OCRA-1:HOTP-SHA512-8:C-QN08' >>> key.issuer 'Issuer' >>> key.challenge_encoding 'DECIMAL' >>> key.challenge_min_length 8 >>> key.challenge_max_length 8 >>> key.response_encoding 'DECIMAL' >>> key.response_length 8 >>> tostr(key.secret) '12345678901234567890' >>> key.counter 0 >>> key.policy.key_usage ['CR'] This tests an TOTP (OATH Time based OTP) key contained within a PSKC file as described in section 4 of draft-hoyer-keyprov-pskc-algorithm-profiles-01. >>> pskc = PSKC('tests/draft-hoyer-keyprov-pskc-algorithm-profiles-01/totp.pskcxml') >>> pskc.version '1.0' >>> key = pskc.keys[0] >>> key.manufacturer 'TokenVendorAcme' >>> key.serial '987654323' >>> key.id '987654323' >>> key.algorithm 'urn:ietf:params:xml:ns:keyprov:pskc#totp' >>> key.issuer 'Issuer' >>> key.response_encoding 'DECIMAL' >>> key.response_length 6 >>> tostr(key.secret) '12345678901234567890' >>> key.time_offset 0 >>> key.time_interval 30 >>> key.time_drift 4 >>> key.policy.key_usage ['OTP'] This tests an SecurID-AES-Counter key contained within a PSKC file as described in section 6 of draft-hoyer-keyprov-pskc-algorithm-profiles-01. >>> pskc = PSKC('tests/draft-hoyer-keyprov-pskc-algorithm-profiles-01/securid-aes-counter.pskcxml') >>> pskc.version '1.0' >>> key = pskc.keys[0] >>> key.manufacturer 'RSA, The Security Division of EMC' >>> key.serial '123456798' >>> key.id '23456789' >>> key.algorithm 'http://www.rsa.com/names/2008/04/algorithms/SecurID/SecurID-AES128-Counter' >>> key.issuer 'Issuer' >>> key.response_encoding 'DECIMAL' >>> key.response_length 6 >>> tostr(key.secret) '12345678901234567890' >>> key.counter 0 >>> key.policy.key_usage ['OTP'] >>> key.policy.start_date datetime.datetime(2006, 4, 14, 0, 0, tzinfo=tzutc()) >>> key.policy.expiry_date datetime.datetime(2010, 9, 30, 0, 0, tzinfo=tzutc()) This tests an ActivIdentity-3DES key contained within a PSKC file as described in section 8 of draft-hoyer-keyprov-pskc-algorithm-profiles-01. >>> pskc = PSKC('tests/draft-hoyer-keyprov-pskc-algorithm-profiles-01/actividentity-3des.pskcxml') >>> pskc.version '1.0' >>> key = pskc.keys[0] >>> key.manufacturer 'ActivIdentity' >>> key.serial '34567890' >>> key.id '12345677' >>> key.algorithm 'http://www.actividentity.com/2008/04/algorithms/algorithms#ActivIdentity-3DES' >>> key.issuer 'Issuer' >>> key.response_encoding 'DECIMAL' >>> key.response_length 8 >>> tostr(key.secret) '12345678901234567890' >>> key.counter 0 >>> key.time_offset 0 >>> key.time_interval 32 >>> key.time_drift 0 >>> key.policy.key_usage ['OTP']