當前位置: 首頁>>代碼示例>>Python>>正文


Python ocra.OCRA類代碼示例

本文整理匯總了Python中privacyidea.lib.tokens.ocra.OCRA的典型用法代碼示例。如果您正苦於以下問題:Python OCRA類的具體用法?Python OCRA怎麽用?Python OCRA使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了OCRA類的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_03_one_way_chal_with_pin_and_counter

    def test_03_one_way_chal_with_pin_and_counter(self):
        # http://tools.ietf.org/html/rfc6287#appendix-C.1
        pin = "1234"
        pin_hash = "7110eda4d09e062aa5e4a390b0a572ac0d2c0220"
        ocrasuite = "OCRA-1:HOTP-SHA256-8:C-QN08-PSHA1"
        testvectors = [
            {"Q": "12345678", "r": "65347737", "C": "0"},
            {"Q": "12345678", "r": "86775851", "C": "1"},
            {"Q": "12345678", "r": "78192410", "C": "2"},
            {"Q": "12345678", "r": "71565254", "C": "3"},
            {"Q": "12345678", "r": "10104329", "C": "4"},
            {"Q": "12345678", "r": "65983500", "C": "5"},
            {"Q": "12345678", "r": "70069104", "C": "6"},
            {"Q": "12345678", "r": "91771096", "C": "7"},
            {"Q": "12345678", "r": "75011558", "C": "8"},
            {"Q": "12345678", "r": "08522129", "C": "9"},
        ]
        # test with PIN
        for tv in testvectors:
            ocra_object = OCRA(ocrasuite, binascii.unhexlify(KEY32))
            r = ocra_object.get_response(tv.get("Q"), pin=pin,
                                         counter=tv.get("C"))
            self.assertEqual(r, tv.get("r"))

        # test with pin_hash
        for tv in testvectors:
            ocra_object = OCRA(ocrasuite, binascii.unhexlify(KEY32))
            r = ocra_object.get_response(tv.get("Q"), pin_hash=pin_hash,
                                         counter=tv.get("C"))
            self.assertEqual(r, tv.get("r"))
開發者ID:dhoffend,項目名稱:privacyidea,代碼行數:30,代碼來源:test_lib_tokens_tiqr.py

示例2: test_07_plain_signature_with_time

 def test_07_plain_signature_with_time(self):
     # http://tools.ietf.org/html/rfc6287#appendix-C.3
     ocrasuite = "OCRA-1:HOTP-SHA512-8:QA10-T1M"
     testvectors = [
         {"Q": "SIG1000000", "r": "77537423", "T": "132d0b6"},
         {"Q": "SIG1100000", "r": "31970405", "T": "132d0b6"},
         {"Q": "SIG1200000", "r": "10235557", "T": "132d0b6"},
         {"Q": "SIG1300000", "r": "95213541", "T": "132d0b6"},
         {"Q": "SIG1400000", "r": "65360607", "T": "132d0b6"}
     ]
     for tv in testvectors:
         ocra_object = OCRA(ocrasuite, binascii.unhexlify(KEY64))
         r = ocra_object.get_response(tv.get("Q"), timesteps=tv.get("T"))
         self.assertEqual(r, tv.get("r"))
開發者ID:dhoffend,項目名稱:privacyidea,代碼行數:14,代碼來源:test_lib_tokens_tiqr.py

示例3: test_06_plain_signature

 def test_06_plain_signature(self):
     # http://tools.ietf.org/html/rfc6287#appendix-C.3
     ocrasuite = "OCRA-1:HOTP-SHA256-8:QA08"
     testvectors = [
         {"Q": "SIG10000", "r": "53095496"},
         {"Q": "SIG11000", "r": "04110475"},
         {"Q": "SIG12000", "r": "31331128"},
         {"Q": "SIG13000", "r": "76028668"},
         {"Q": "SIG14000", "r": "46554205"}
     ]
     for tv in testvectors:
         ocra_object = OCRA(ocrasuite, binascii.unhexlify(KEY32))
         r = ocra_object.get_response(tv.get("Q"))
         self.assertEqual(r, tv.get("r"))
開發者ID:dhoffend,項目名稱:privacyidea,代碼行數:14,代碼來源:test_lib_tokens_tiqr.py

示例4: test_05_one_way_chal_with_timestamp

 def test_05_one_way_chal_with_timestamp(self):
     # http://tools.ietf.org/html/rfc6287#appendix-C.1
     ocrasuite = "OCRA-1:HOTP-SHA512-8:QN08-T1M"
     testvectors = [
         {"Q": "00000000", "T": "132d0b6", "r": "95209754"},
         {"Q": "11111111", "T": "132d0b6", "r": "55907591"},
         {"Q": "22222222", "T": "132d0b6", "r": "22048402"},
         {"Q": "33333333", "T": "132d0b6", "r": "24218844"},
         {"Q": "44444444", "T": "132d0b6", "r": "36209546"}
     ]
     for tv in testvectors:
         ocra_object = OCRA(ocrasuite, binascii.unhexlify(KEY64))
         r = ocra_object.get_response(tv.get("Q"),
                                      timesteps=tv.get("T"))
         self.assertEqual(r, tv.get("r"))
開發者ID:dhoffend,項目名稱:privacyidea,代碼行數:15,代碼來源:test_lib_tokens_tiqr.py

示例5: test_02_one_way_chal_with_pin

 def test_02_one_way_chal_with_pin(self):
     # http://tools.ietf.org/html/rfc6287#appendix-C.1
     pin = "1234"
     ocrasuite = "OCRA-1:HOTP-SHA256-8:QN08-PSHA1"
     testvectors = [
         {"Q": "00000000", "r": "83238735"},
         {"Q": "11111111", "r": "01501458"},
         {"Q": "22222222", "r": "17957585"},
         {"Q": "33333333", "r": "86776967"},
         {"Q": "44444444", "r": "86807031"}
     ]
     for tv in testvectors:
         ocra_object = OCRA(ocrasuite, binascii.unhexlify(KEY32))
         r = ocra_object.get_response(tv.get("Q"), pin=pin)
         self.assertEqual(r, tv.get("r"))
開發者ID:dhoffend,項目名稱:privacyidea,代碼行數:15,代碼來源:test_lib_tokens_tiqr.py

示例6: verify_response

    def verify_response(self, passw=None, challenge=None):
        """
        This method verifies if the *passw* is the valid OCRA response to the
        *challenge*.
        In case of success we return a value > 0

        :param passw: the password (pin+otp)
        :type passw: string
        :return: return otp_counter. If -1, challenge does not match
        :rtype: int
        """
        ocrasuite = self.get_tokeninfo("ocrasuite")
        security_object = self.token.get_otpkey()
        ocra_object = OCRA(ocrasuite, security_object=security_object)
        # TODO: We might need to add additional Signing or Counter objects
        r = ocra_object.check_response(passw, question=challenge)
        return r
開發者ID:STRML,項目名稱:privacyidea,代碼行數:17,代碼來源:ocratoken.py

示例7: test_08_create_data_input

    def test_08_create_data_input(self):
        # The ocrasuite is stored as a unicode in the webui. As it is used for
        # the OCRA datainput, it must be internally converted to a string.
        ocrasuite = u"OCRA-1:HOTP-SHA1-6:QN10"
        question = "1344454126"
        ocra_object = OCRA(ocrasuite, binascii.unhexlify(KEY20))
        r = ocra_object.create_data_input(question)

        # create data_input with missing counter
        ocrasuite = u"OCRA-1:HOTP-SHA1-6:C-QN10"
        ocra_object=OCRA(ocrasuite, binascii.unhexlify(KEY20))
        self.assertRaises(Exception, ocra_object.create_data_input, question)

        # create data_input with missing PIN
        ocrasuite = u"OCRA-1:HOTP-SHA1-6:QN10-PSHA1"
        ocra_object=OCRA(ocrasuite, binascii.unhexlify(KEY20))
        self.assertRaises(Exception, ocra_object.create_data_input, question)

        # create data_input with missing Timesteps
        ocrasuite = u"OCRA-1:HOTP-SHA1-6:QN10-T1M"
        ocra_object=OCRA(ocrasuite, binascii.unhexlify(KEY20))
        self.assertRaises(Exception, ocra_object.create_data_input, question)

        ocrasuite = u"OCRA-1:HOTP-SHA1-8:QH40"
        dTAN = "83507112  ~320,00~1399458665_G6HNVF"
        question = binascii.hexlify(hashlib.sha1(dTAN).digest())
        ocra_object = OCRA(ocrasuite, binascii.unhexlify(KEY20))
        r = ocra_object.create_data_input(question)
        self.assertEqual(len(r), 128 + len(ocrasuite) + 1)
開發者ID:hrz-unimr,項目名稱:privacyidea,代碼行數:29,代碼來源:test_lib_tokens_tiqr.py

示例8: test_01_one_way_chal_resp

 def test_01_one_way_chal_resp(self):
     # http://tools.ietf.org/html/rfc6287#appendix-C.1
     ocrasuite = "OCRA-1:HOTP-SHA1-6:QN08"
     testvectors = [
         {"Q": "00000000", "r": "237653"},
         {"Q": "11111111", "r": "243178"},
         {"Q": "22222222", "r": "653583"},
         {"Q": "33333333", "r": "740991"},
         {"Q": "44444444", "r": "608993"},
         {"Q": "55555555", "r": "388898"},
         {"Q": "66666666", "r": "816933"},
         {"Q": "77777777", "r": "224598"},
         {"Q": "88888888", "r": "750600"},
         {"Q": "99999999", "r": "294470"}
     ]
     for tv in testvectors:
         ocra_object = OCRA(ocrasuite, binascii.unhexlify(KEY20))
         r = ocra_object.get_response(tv.get("Q"))
         self.assertEqual(r, tv.get("r"))
開發者ID:dhoffend,項目名稱:privacyidea,代碼行數:19,代碼來源:test_lib_tokens_tiqr.py

示例9: test_04_one_way_chal_with_counter_512

 def test_04_one_way_chal_with_counter_512(self):
     # http://tools.ietf.org/html/rfc6287#appendix-C.1
     ocrasuite = "OCRA-1:HOTP-SHA512-8:C-QN08"
     testvectors = [
         {"Q": "00000000", "C": "00000", "r": "07016083"},
         {"Q": "11111111", "C": "00001", "r": "63947962"},
         {"Q": "22222222", "C": "00002", "r": "70123924"},
         {"Q": "33333333", "C": "00003", "r": "25341727"},
         {"Q": "44444444", "C": "00004", "r": "33203315"},
         {"Q": "55555555", "C": "00005", "r": "34205738"},
         {"Q": "66666666", "C": "00006", "r": "44343969"},
         {"Q": "77777777", "C": "00007", "r": "51946085"},
         {"Q": "88888888", "C": "00008", "r": "20403879"},
         {"Q": "99999999", "C": "00009", "r": "31409299"},
     ]
     for tv in testvectors:
         ocra_object = OCRA(ocrasuite, binascii.unhexlify(KEY64))
         r = ocra_object.get_response(tv.get("Q"),
                                      counter=tv.get("C"))
         self.assertEqual(r, tv.get("r"))
開發者ID:dhoffend,項目名稱:privacyidea,代碼行數:20,代碼來源:test_lib_tokens_tiqr.py

示例10: test_08_create_data_input

    def test_08_create_data_input(self):
        # The ocrasuite is stored as a unicode in the webui. As it is used for
        # the OCRA datainput, it must be internally converted to a string.
        ocrasuite = u"OCRA-1:HOTP-SHA1-6:QN10"
        question = "1344454126"
        ocra_object = OCRA(ocrasuite, binascii.unhexlify(KEY20))
        r = ocra_object.create_data_input(question)

        # create data_input with missing counter
        ocrasuite = u"OCRA-1:HOTP-SHA1-6:C-QN10"
        ocra_object=OCRA(ocrasuite, binascii.unhexlify(KEY20))
        self.assertRaises(Exception, ocra_object.create_data_input, question)

        # create data_input with missing PIN
        ocrasuite = u"OCRA-1:HOTP-SHA1-6:QN10-PSHA1"
        ocra_object=OCRA(ocrasuite, binascii.unhexlify(KEY20))
        self.assertRaises(Exception, ocra_object.create_data_input, question)

        # create data_input with missing Timesteps
        ocrasuite = u"OCRA-1:HOTP-SHA1-6:QN10-T1M"
        ocra_object=OCRA(ocrasuite, binascii.unhexlify(KEY20))
        self.assertRaises(Exception, ocra_object.create_data_input, question)
開發者ID:dhoffend,項目名稱:privacyidea,代碼行數:22,代碼來源:test_lib_tokens_tiqr.py

示例11: test_02_api_endpoint

    def test_02_api_endpoint(self):
        pin = "tiqr"
        token = init_token({"type": "tiqr",
                            "pin": pin,
                            "user": "cornelius",
                            "realm": self.realm1})
        idetail = token.get_init_detail()
        value = idetail.get("tiqrenroll").get("value")
        # 'tiqrenroll://None?action=metadata&session=b81ecdf74118dcf6fa1cd41d3d4b2fec56c9107f&serial=TiQR000163CB
        # get the serial and the session
        m = re.search('&serial=(.*)$', value)
        serial = m.group(1)
        m = re.search('&session=(.*)&', value)
        session = m.group(1)

        # test meta data
        builder = EnvironBuilder(method='POST',
                                 data={},
                                 headers={})
        env = builder.get_environ()
        # Set the remote address so that we can filter for it
        env["REMOTE_ADDR"] = "10.0.0.1"
        req = Request(env)
        req.all_data = {"action": "metadata",
                        "session": session,
                        "serial": serial}

        r = TiqrTokenClass.api_endpoint(req, g)

        self.assertEqual(r[0], "json")
        self.assertTrue("identity" in r[1], r[1])
        self.assertTrue("service" in r[1], r[1])

        # Test invalid action
        req.all_data = {"action": "unknown"}
        self.assertRaises(Exception,
                          TiqrTokenClass.api_endpoint, req, g)

        # test enrollment with invalid session
        req.all_data = {"action": "enrollment",
                        "serial": serial,
                        "session": "123",
                        "secret": KEY20}

        self.assertRaises(ParameterError,
                          TiqrTokenClass.api_endpoint, req, g)

        # test enrollment with valid session
        req.all_data = {"action": "enrollment",
                        "serial": serial,
                        "session": session,
                        "secret": KEY20}
        r = TiqrTokenClass.api_endpoint(req, g)
        self.assertEqual(r[0], "text")
        self.assertEqual(r[1], "OK")

        # test authentication endpoint
        # create a challenge by issuing validate/check with user and pin
        session = ""
        challenge = ""
        with self.app.test_request_context('/validate/check',
                                           method='GET',
                                           query_string=urlencode({
                                               "user": "cornelius",
                                               "realm": self.realm1,
                                               "pass": pin})):
            res = self.app.full_dispatch_request()
            self.assertTrue(res.status_code == 200, res)
            result = json.loads(res.data).get("result")
            detail = json.loads(res.data).get("detail")
            self.assertTrue(result.get("status") is True, result)
            self.assertTrue(result.get("value") is False, result)
            transaction_id = detail.get("transaction_id")
            image_url = detail.get("attributes").get("value")
            self.assertTrue(image_url.startswith("tiqrauth"))
            # u'tiqrauth://[email protected]
            # /12335970131032896263/e0fac7bb2e3ea4219ead'
            # session = 12335970131032896263
            # challenge = e0fac7bb2e3ea4219ead
            r = image_url.split("/")
            session = r[3]
            challenge = r[4]

        ocrasuite = token.get_tokeninfo("ocrasuite")
        ocra_object = OCRA(ocrasuite, key=binascii.unhexlify(KEY20))
        # Calculate Response with the challenge.
        response = ocra_object.get_response(challenge)

        # First, send a wrong response
        req.all_data = {"response": "12345",
                        "userId": "cornelius_%s" % self.realm1,
                        "sessionKey": session,
                        "operation": "login"}
        r = TiqrTokenClass.api_endpoint(req, g)
        self.assertEqual(r[0], "text")
        self.assertEqual(r[1], "INVALID_RESPONSE")

        # Send the correct response
        req.all_data = {"response": response,
                        "userId": "cornelius_%s" % self.realm1,
#.........這裏部分代碼省略.........
開發者ID:dhoffend,項目名稱:privacyidea,代碼行數:101,代碼來源:test_lib_tokens_tiqr.py


注:本文中的privacyidea.lib.tokens.ocra.OCRA類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。