OXIESEC PANEL
- Current Dir:
/
/
opt
/
gsutil
/
third_party
/
pyu2f
/
pyu2f
/
convenience
Server IP: 2a02:4780:11:1594:0:ef5:22d7:a
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
02/11/2025 08:19:48 AM
rwxr-xr-x
📄
__init__.py
659 bytes
11/22/2021 06:55:57 PM
rw-r--r--
📁
__pycache__
-
02/11/2025 08:19:48 AM
rwxr-xr-x
📄
authenticator.py
1.83 KB
11/22/2021 06:55:57 PM
rw-r--r--
📄
baseauthenticator.py
2.15 KB
11/22/2021 06:55:57 PM
rw-r--r--
📄
customauthenticator.py
8.22 KB
11/22/2021 06:55:57 PM
rw-r--r--
📄
localauthenticator.py
2.45 KB
11/22/2021 06:55:57 PM
rw-r--r--
Editing: authenticator.py
Close
# Copyright 2016 Google Inc. All Rights Reserved. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. """Interface to handle end to end flow of U2F signing.""" import sys from pyu2f.convenience import baseauthenticator from pyu2f.convenience import customauthenticator from pyu2f.convenience import localauthenticator def CreateCompositeAuthenticator(origin): authenticators = [customauthenticator.CustomAuthenticator(origin), localauthenticator.LocalAuthenticator(origin)] return CompositeAuthenticator(authenticators) class CompositeAuthenticator(baseauthenticator.BaseAuthenticator): """Composes multiple authenticators into a single authenticator. Priority is based on the order of the list initialized with the instance. """ def __init__(self, authenticators): self.authenticators = authenticators def Authenticate(self, app_id, challenge_data, print_callback=sys.stderr.write): """See base class.""" for authenticator in self.authenticators: if authenticator.IsAvailable(): result = authenticator.Authenticate(app_id, challenge_data, print_callback) return result raise ValueError('No valid authenticators found') def IsAvailable(self): """See base class.""" return True