-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.html
152 lines (138 loc) · 7.21 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Airgapped QR Code Transfer</title>
<style>
body {
font-family: Arial, sans-serif;
line-height: 1.6;
margin: 0;
padding: 0;
background-color: #f4f4f4;
}
.container {
max-width: 800px;
margin: 0 auto;
padding: 20px;
background-color: #fff;
box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}
h1, h2, h3 {
color: #333;
}
a {
color: #1a73e8;
text-decoration: none;
}
a:hover {
text-decoration: underline;
}
pre {
background: #eee;
padding: 10px;
overflow-x: auto;
}
code {
background: #eee;
padding: 2px 4px;
border-radius: 3px;
}
</style>
</head>
<body>
<div class="container">
<h1>Airgapped QR Code Transfer</h1>
<p>Airgapped QR Code Transfer is a simple web-based tool to transfer data between devices using QR codes. It allows for the transfer of files without the need for network connectivity, leveraging QR codes to encode and decode file data. This project uses Vue.js for the frontend and libraries like pako for compression, qrcode.js for QR code generation, and zbar-wasm for QR code scanning.</p>
<h2>Live Online Demo</h2>
<h3>Receiver Setup:</h3>
<ul>
<li>Open <a href="https://airgapped-qr-code-transfer.mohanram.co.in/scanner" target="_blank">scanner.html</a> in the receiver's browser.</li>
<li>Allow access to the camera for scanning.</li>
</ul>
<h3>Sender Setup:</h3>
<ul>
<li>Open <a href="https://airgapped-qr-code-transfer.mohanram.co.in/generator" target="_blank">generator.html</a> in the sender's browser.</li>
<li>Upload the file that needs to be transferred.</li>
</ul>
<h3>Transfer Process:</h3>
<ul>
<li>Click the "Start Receiver" button in the receiver's browser and point it to the sender's screen.</li>
<li>In the sender's browser, click "Choose file" and then click "Start Transfer."</li>
<li>Wait for all parts to be transferred. The file will be downloaded on the receiver's device.</li>
</ul>
<h2>Features</h2>
<ul>
<li><strong>Data Sender Mode</strong>: Allows a user to select a file, compress it, and transfer it via QR codes.</li>
<li><strong>Data Receiver Mode</strong>: Allows a user to scan QR codes to receive and reconstruct the file.</li>
<li><strong>File Compression</strong>: Uses gzip compression to reduce the size of the data being transferred.</li>
<li><strong>QR Code Generation and Scanning</strong>: Uses qrcode.js for generation and zbar-wasm for scanning QR codes.</li>
</ul>
<h2>Getting Started</h2>
<h3>Prerequisites</h3>
<p>A modern web browser (preferably Chrome or Firefox) that supports JavaScript and the WebRTC API.</p>
<h3>Installing</h3>
<pre><code>git clone https://github.com/mohankumarelec/airgap-qr-transfer.git
cd airgap-qr-transfer</code></pre>
<p>Open the <code>generator.html</code> file in your browser for the sender interface:</p>
<pre><code>open generator.html</code></pre>
<p>Open the <code>scanner.html</code> file in your browser for the receiver interface:</p>
<pre><code>open scanner.html</code></pre>
<h2>Usage</h2>
<h3>Data Sender Mode</h3>
<ol>
<li>Open <code>generator.html</code> in your browser.</li>
<li>Select a file using the file input.</li>
<li>Click the "Start Transfer" button to begin the transfer process.</li>
<li>The application will compress the file, split it into chunks, and generate QR codes for each chunk.</li>
<li>The generated QR codes will be displayed one by one, which can be scanned by the receiving device.</li>
</ol>
<h3>Data Receiver Mode</h3>
<ol>
<li>Open <code>scanner.html</code> in your browser.</li>
<li>Click the "Start Receiver" button to begin the receiving process.</li>
<li>Use the device's camera to scan the QR codes generated by the sender.</li>
<li>The application will decode the QR codes, reconstruct the file, and prompt you to download it once the transfer is complete.</li>
</ol>
<h2>How It Works</h2>
<h3>Data Sender (generator.html)</h3>
<ol>
<li><strong>File Selection</strong>: User selects a file from their device.</li>
<li><strong>Compression</strong>: The file is compressed using the pako library.</li>
<li><strong>Chunking</strong>: The compressed file is split into smaller chunks.</li>
<li><strong>QR Code Generation</strong>: Each chunk is encoded into a QR code using qrcode.js.</li>
<li><strong>Display QR Codes</strong>: The QR codes are displayed sequentially for the receiver to scan.</li>
</ol>
<h3>Data Receiver (scanner.html)</h3>
<ol>
<li><strong>QR Code Scanning</strong>: The device's camera scans QR codes using zbar-wasm.</li>
<li><strong>Decoding</strong>: Each QR code is decoded to extract the chunk of data.</li>
<li><strong>Reconstruction</strong>: The chunks are reassembled into the original compressed file.</li>
<li><strong>Decompression</strong>: The file is decompressed using pako.</li>
<li><strong>File Download</strong>: The reconstructed file is made available for download.</li>
</ol>
<h2>Contributing</h2>
<p>Contributions are welcome! Please follow these steps:</p>
<ol>
<li>Fork the repository.</li>
<li>Create a new branch (<code>git checkout -b feature-branch</code>).</li>
<li>Make your changes.</li>
<li>Commit your changes (<code>git commit -am 'Add new feature'</code>).</li>
<li>Push to the branch (<code>git push origin feature-branch</code>).</li>
<li>Create a new Pull Request.</li>
</ol>
<h2>License</h2>
<p>This project is licensed under the MIT License - see the <a href="LICENSE">LICENSE</a> file for details.</p>
<h2>Acknowledgments</h2>
<ul>
<li><a href="https://vuejs.org/" target="_blank">Vue.js</a> - JavaScript framework for building user interfaces.</li>
<li><a href="https://github.com/nodeca/pako" target="_blank">pako</a> - Compression library.</li>
<li><a href="https://github.com/davidshimjs/qrcodejs" target="_blank">qrcode.js</a> - QR code generation library.</li>
<li><a href="https://github.com/undecaf/zbar-wasm" target="_blank">zbar-wasm</a> - QR code scanning library.</li>
</ul>
<h2>More Information</h2>
<p>For more information, visit the <a href="https://github.com/mohankumarelec/Airgapped-QR-code-Transfer" target="_blank">GitHub repository</a>.</p>
</div>
</body>
</html>