A transpilation plugin for Qiskit with a modified init stage that encodes (classical) information adding RZGates to auxiliary qubits
Project description
qiskit-leaky-init
[!NOTE] This plugin was developed to demonstrate the importance of reproducible builds in the Qiskit quantum computing workflow. It shows that non-reproducibility in the transpilation process (specifically during the init stage) can be exploited to encode classical information into the transpiled quantum circuit. If an attacker subsequently gains access to the job description, this can lead to the leakage of confidential data.
A transpilation init plugin for Qiskit that demonstrates how a modified transpilation stage can be used to hide classical information in the final transpiled quantum circuit.
The current implementation, by default, tries to encode the HSLU logo into the transpiled circuit. The raw image is
encoded into large integers, which are saved as parameters of
RZGates. These gates are added to
an auxiliary QuantumRegister in the
first stage (init) of the
transpilation surrounded by
reset instructions. This guarantees that later
stages in the transpilation (e.g. routing, optimization, etc.) do not modify this quantum register in any way, allowing
the extraction of the leaked data.
Custom data can be encoded if builtins.data exists. In that case, the bytes from that variable are used instead of
the HSLU logo (see the example below).
The plugin is implemented as a subclass of
PassManagerStagePlugin,
which appends to the default init pass DefaultInitPassManager a new
TransformationPass, called
LeakyQubit.
Encoded data can be recovered with recover_data() implemented in the decoder module.
See the example below.
Installation
git clone https://github.com/iyanmv/qiskit-leaky-init.git
cd qiskit-leaky-init
pip install .
Example
import builtins
import io
import secrets
from pathlib import Path
from PIL import Image
from qiskit.circuit import QuantumCircuit
from qiskit.transpiler.preset_passmanagers import generate_preset_pass_manager
from qiskit.transpiler.preset_passmanagers.plugin import list_stage_plugins
from qiskit_ibm_runtime import QiskitRuntimeService
from qiskit_ibm_runtime.fake_provider import FakeBrisbane
from qiskit_leaky_init import recover_data
# Check that init plugin was installed correctly
assert "leaky_init" in list_stage_plugins("init")
# To encode custom data, store it in builtins.data. For example:
# builtins.data = secrets.token_bytes(256)
backend = FakeBrisbane()
pm = generate_preset_pass_manager(
optimization_level=3, backend=backend, init_method="leaky_init"
)
# 3-qubit GHZ circuit
qc = QuantumCircuit(3)
qc.h(0)
qc.cx(0, range(1, 3))
# Transpiled circuit with leaked data
isa_qc = pm.run(qc)
recovered_img = recover_data(isa_qc)
Image.open(io.BytesIO(recovered_img)).show()
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file qiskit_leaky_init-0.2.4.tar.gz.
File metadata
- Download URL: qiskit_leaky_init-0.2.4.tar.gz
- Upload date:
- Size: 7.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5c2219d52c095c9b4fdce985de8cbb87d8533cfb04ec5020256cd0a7581bfc60
|
|
| MD5 |
563cbb83ebb73633c2f5418ad21ca422
|
|
| BLAKE2b-256 |
e2794bc9e59bd3fb2ed6f66d738c12d84ae92cc712528465aa42c57cc832b484
|
Provenance
The following attestation bundles were made for qiskit_leaky_init-0.2.4.tar.gz:
Publisher:
publish-to-pypi.yml on iyanmv/qiskit-leaky-init
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
qiskit_leaky_init-0.2.4.tar.gz -
Subject digest:
5c2219d52c095c9b4fdce985de8cbb87d8533cfb04ec5020256cd0a7581bfc60 - Sigstore transparency entry: 1327311266
- Sigstore integration time:
-
Permalink:
iyanmv/qiskit-leaky-init@77d1e27730d81b966a7b0658150476d857bd36c4 -
Branch / Tag:
refs/tags/v0.2.4 - Owner: https://github.com/iyanmv
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@77d1e27730d81b966a7b0658150476d857bd36c4 -
Trigger Event:
push
-
Statement type:
File details
Details for the file qiskit_leaky_init-0.2.4-py3-none-any.whl.
File metadata
- Download URL: qiskit_leaky_init-0.2.4-py3-none-any.whl
- Upload date:
- Size: 7.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ae4d4d5dde8d42296c729bf124062c3a5f67bd3359c6608f4f42fbfff590b099
|
|
| MD5 |
e2695fec570b42b321d4de076300cb14
|
|
| BLAKE2b-256 |
eb04d6365e124a4b8543501cdd1089f933a67e9a29f9f265dad1e8e3163686f0
|
Provenance
The following attestation bundles were made for qiskit_leaky_init-0.2.4-py3-none-any.whl:
Publisher:
publish-to-pypi.yml on iyanmv/qiskit-leaky-init
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
qiskit_leaky_init-0.2.4-py3-none-any.whl -
Subject digest:
ae4d4d5dde8d42296c729bf124062c3a5f67bd3359c6608f4f42fbfff590b099 - Sigstore transparency entry: 1327311608
- Sigstore integration time:
-
Permalink:
iyanmv/qiskit-leaky-init@77d1e27730d81b966a7b0658150476d857bd36c4 -
Branch / Tag:
refs/tags/v0.2.4 - Owner: https://github.com/iyanmv
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@77d1e27730d81b966a7b0658150476d857bd36c4 -
Trigger Event:
push
-
Statement type: