Skip to content

Commit

Permalink
Merge pull request #65 from artificial-brain/otp-generator
Browse files Browse the repository at this point in the history
Implemented OTP generator
  • Loading branch information
ab-jiteshlalwani authored Jul 3, 2021
2 parents 76f4a35 + f6b9340 commit ea7dde9
Show file tree
Hide file tree
Showing 10 changed files with 106 additions and 12 deletions.
3 changes: 2 additions & 1 deletion quantumcat/applications/generator/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,4 +14,5 @@


from quantumcat.applications.generator.random_number import RandomNumber
from quantumcat.applications.generator.password import Password
from quantumcat.applications.generator.password import Password
from quantumcat.applications.generator.otp import OTP
35 changes: 35 additions & 0 deletions quantumcat/applications/generator/otp.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
# (C) Copyright Artificial Brain 2021.
#
# 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.


import requests
from quantumcat.utils import constants, ErrorMessages
from quantumcat.exceptions import OTPLengthError


class OTP:
def __init__(self):
self.length = 5

def generate(self):
ANU_QRNG_REQUEST_URL = constants.ANU_QRNG_URL + '?length=10&type=' + \
constants.UNIT16_TYPE
response = requests.get(ANU_QRNG_REQUEST_URL)
if response.status_code != 200:
return 'Something went wromg'
data = response.json()
otp = data['data']
for i in range(len(otp)):
if len(str(otp[i])) == self.length:
return otp[i]
6 changes: 5 additions & 1 deletion quantumcat/applications/generator/password.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,14 +14,18 @@


import requests
from quantumcat.utils import constants
from quantumcat.utils import constants, ErrorMessages
from quantumcat.exceptions import PasswordLengthError


class Password:
def __init__(self, length):
self.length = length

def generate(self):
if not (4 < self.length <= 20):
raise PasswordLengthError(ErrorMessages.PASSWORD_LENGTH_INCORRECT)

ANU_QRNG_REQUEST_URL = constants.ANU_QRNG_URL + '?length=1&type=' + \
constants.HEX_TYPE + '&size=' + str(self.length)
response = requests.get(ANU_QRNG_REQUEST_URL)
Expand Down
4 changes: 2 additions & 2 deletions quantumcat/circuit/circuit.py
Original file line number Diff line number Diff line change
Expand Up @@ -382,7 +382,7 @@ def get_operations(self):

def check_qubit_boundary(self, qubit):
if qubit > (self.qubits - 1):
raise CircuitError(ErrorMessages.qubit_out_of_bound)
raise CircuitError(ErrorMessages.QUBIT_OUT_OF_BOUND)

def draw_circuit(self, provider=providers.DEFAULT_PROVIDER):
self.check_and_convert(provider)
Expand Down Expand Up @@ -427,7 +427,7 @@ def execute(self, provider=providers.DEFAULT_PROVIDER,
simulator_name, repetitions, api)
elif self.provider == providers.IONQ_PROVIDER:
if api is None:
raise APIDetailsNotFoundError(ErrorMessages.ionq_api_details_not_provided)
raise APIDetailsNotFoundError(ErrorMessages.IONQ_API_DETAILS_NOT_PROVIDED)
return execute_circuit.on_ionq(self.converted_q_circuit,
default_target, repetitions, api, self.get_operations())

Expand Down
3 changes: 3 additions & 0 deletions quantumcat/exceptions/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,10 @@
# See the License for the specific language governing permissions and
# limitations under the License.


from quantumcat.exceptions.exception import QuantumCatError
from quantumcat.exceptions.circuit_error import CircuitError
from quantumcat.exceptions.install_error import InstallNotFoundError
from quantumcat.exceptions.api_error import APIDetailsNotFoundError
from quantumcat.exceptions.password_length import PasswordLengthError
from quantumcat.exceptions.otp_length import OTPLengthError
21 changes: 21 additions & 0 deletions quantumcat/exceptions/otp_length.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
# (C) Copyright Artificial Brain 2021.
#
# 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.

from quantumcat.exceptions import QuantumCatError


class OTPLengthError(QuantumCatError):
"""Base class for errors raised for api details not found."""

pass
21 changes: 21 additions & 0 deletions quantumcat/exceptions/password_length.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
# (C) Copyright Artificial Brain 2021.
#
# 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.

from quantumcat.exceptions import QuantumCatError


class PasswordLengthError(QuantumCatError):
"""Base class for errors raised for api details not found."""

pass
11 changes: 8 additions & 3 deletions quantumcat/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@
from quantumcat.circuit import QCircuit
from quantumcat.utils import providers, constants
from quantumcat.algorithms import GroversAlgorithm
from quantumcat.applications.generator import RandomNumber, Password
from quantumcat.applications.generator import RandomNumber, Password, OTP


def create_circuit_demo():
Expand Down Expand Up @@ -95,9 +95,14 @@ def braket_demo():


def password_demo():
password = Password(10).generate()
password = Password(8).generate()
print(password)


def otp_demo():
otp = OTP().generate()
print(otp)


if __name__ == '__main__':
password_demo()
otp_demo()
1 change: 1 addition & 0 deletions quantumcat/utils/constants.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,3 +21,4 @@
DECIMAL = 'decimal'
ANU_QRNG_URL = 'https://qrng.anu.edu.au/API/jsonI.php'
HEX_TYPE = 'hex16'
UNIT16_TYPE = 'uint16'
13 changes: 8 additions & 5 deletions quantumcat/utils/error_messages.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,11 @@
# See the License for the specific language governing permissions and
# limitations under the License.

qubit_out_of_bound = 'Qubit is out of bound.'
cbit_out_of_bound = 'Classical Bit is out of bound.'
qiskit_not_installed = 'Qiskit is not installed.'
api_details_not_provided = 'API Key is required for running on real quantum device.'
ionq_api_details_not_provided = 'API Key is required for running on IonQ.'
QUBIT_OUT_OF_BOUND = 'Qubit is out of bound.'
CBIT_OUT_OF_BOUND = 'Classical Bit is out of bound.'
QISKIT_NOT_INSTALLED = 'Qiskit is not installed.'
API_DETAILS_NOT_PROVIDED = 'API Key is required for running on real quantum device.'
IONQ_API_DETAILS_NOT_PROVIDED = 'API Key is required for running on IonQ.'
PASSWORD_LENGTH_INCORRECT = 'Password length should be between 5 and 20'
OTP_LENGTH_INCORRECT = 'OTP length should be either 4 or 5'

0 comments on commit ea7dde9

Please sign in to comment.