pip install -r requirements.txt
DemoCodes/FreshCopy
has been created by following the steps already.- main00, main01, ... etc has been created by following the codes given in the steps.
DemoCodes/ExampleTestSSE
is an example of simulation
Searchable Symmetric Encryption enables search over encrypted data.
Order preservation gives us possibility to search over encrypted data not only by exact match but also with operators like < and >.
Solution of the problem is based on this article.
Search steps over encrypted data:
-
Create three example json data files. You can create examples if you execute python file create_patient_json.py. One of examples is shown in the picture.
-
Create 32B index and document key and save them: SSE class method generate_and_save_keys.
-
Generate 16B IVs and update document index - SSE class method update_IVs_and_doc_index.
-
Create switched document index for server - SSE class method create_switched_document_index.
-
Create inverted document index - OPE class method create_inverted_keyword_index.
-
Create index for all distinct values for every field - OPE class method create_index_of_values.
-
Encrypt inverted document index with index key and save it on server - OPE class method encrypt_index.
-
Encrypt all example documents with document key and save it on server - OPE class method encrypt_documents.
-
Search over encrypted data - OPE class methods generate_search_token and search.
-
Copy encrypted files that fit the query to user - OPE class method copy_encrypted_files_to_user.
-
Decrypt files at user with document key - OPE class method decrypt_documents.
-
Create empty folder and name it for example TestSSE.
-
Inside this directory create five more folders and name them Data, Private, Server, SSE, User.
-
Inside Private directory create empty folders named keys and IVs.
-
Inside Private directory create json file document_index.json with empty brackets {}.
-
Inside Private/IVs directory create json file ivs.json with empty brackets {}.
-
Inside SSE directory copy all files downloaded from github link https://github.com/markozeman/SSE.git.
Your directory structure should look something like this:
-
Inside SSE/src directory execute create_patient_json.py file.
-
In terminal move to SSE/src directory, start ipython and execute this commands:
from SSE import SSE
sse = SSE()
sse.generate_and_save_keys()
sse.update_IVs_and_doc_index()
After that your directory structure should look something like this:
- In terminal move to SSE/src directory, start ipython and execute this commands:
from SSE import SSE
from OPE import OPE
sse = SSE()
ope = OPE()
sse.create_switched_document_index()
ope.create_inverted_keyword_index()
After that your directory structure should look something like this:
Inverted index should look like this:
- In terminal move to SSE/src directory, start ipython and execute this commands:
from OPE import OPE
ope = OPE()
ope.create_index_of_values()
ope.encrypt_index()
ope.encrypt_documents()
- Inside User directory make two empty directories named encrypted and decrypted.
After that your directory structure should look something like this:
Encrypted file of Janez Novak should look like this:
- Now we have everything prepared to use graphical interface to search over data.
GUI - razloži, kako se zažene in uporablja.
Graphical interface gives you opportunity to search over encrypted data with simple clicking. After you click Search! button, query is parsed and execute search over encrypted data. Files that match query are copied to User/encrypted folder and then decrypted to User/decrypted folder.
We start GUI by executing GUI.py file in SSE/src directory.
In our solution we used Python 3.5.2 and Anaconda 3.