MOD: updated docs
This commit is contained in:
parent
3d1fed9049
commit
42333ef9a9
7
README
7
README
|
@ -3,7 +3,12 @@
|
|||
***** ***** ***** *****
|
||||
|
||||
Your Photo is your Crypto Key
|
||||
Generate a new Crypto Key to share with every photo
|
||||
-protect from photo modification
|
||||
-verify photo ownership
|
||||
-proof of photo originality, proof of photo ownership. (hash time stamp, Certified Secret tech)
|
||||
-use a photo as authentication (what you have), requires chain-of-custody, requires time stamp verify
|
||||
-generate a new key pair to share with every photo
|
||||
|
||||
|
||||
|
||||
[[ Requirements ]]
|
||||
|
|
|
@ -0,0 +1,215 @@
|
|||
[[[ Picseal ]]]
|
||||
|
||||
"crypto key sharing using your photos"
|
||||
"exif data providing photo integrity, ownership, and crypto key"
|
||||
|
||||
|
||||
[[ Formats]]
|
||||
@ http://stackoverflow.com/questions/12749858/rsa-public-key-format
|
||||
@ http://security.stackexchange.com/questions/57043/most-popular-rsa-key-format
|
||||
|
||||
DER: binary encoded format, sometimes Asn.1 BER-encoded
|
||||
PEM: base64 format of the same DER-encoded file with header&footer lines
|
||||
XML: xml format
|
||||
|
||||
-----BEGIN RSA PUBLIC KEY-----
|
||||
-----END RSA PUBLIC KEY-----
|
||||
|
||||
---- BEGIN SSH2 PUBLIC KEY ----
|
||||
---- END SSH2 PUBLIC KEY ----
|
||||
|
||||
|
||||
|
||||
[[ WolfSSL ]]
|
||||
|
||||
[ Compile Mac ]
|
||||
@ https://www.wolfssl.com/wolfSSL/Docs-wolfssl-manual-toc.html
|
||||
@ https://www.wolfssl.com/wolfSSL/Docs-wolfssl-manual-2-building-wolfssl.html
|
||||
@ https://wolfssl.github.io/wolfcrypt-py/
|
||||
|
||||
$ brew install autoconf automake libtool
|
||||
$ glibtoolize
|
||||
$ git clone https://github.com/wolfssl/wolfssl.git
|
||||
$ cd wolfssl/
|
||||
$ ./autogen.sh
|
||||
$ ./configure --help
|
||||
$ ./configure --enable-sha512
|
||||
$ make
|
||||
|
||||
|
||||
"In order to prevent conflicts with Apple's own libtool we have prepended a "g"
|
||||
so, you have instead: glibtool and glibtoolize.""
|
||||
|
||||
|
||||
|
||||
[[ gexiv2 ]]
|
||||
# gobject wrapper of the libexiv2 library (which is the engine for exiv2)
|
||||
@ https://wiki.gnome.org/Projects/gexiv2
|
||||
@ http://wiki.gnome.org/GObjectIntrospection
|
||||
@ http://wiki.gnome.org/PyGObject/IntrospectionPorting
|
||||
|
||||
# API docs
|
||||
@ http://lazka.github.io/pgi-docs/#GExiv2-0.10
|
||||
|
||||
[ XMP ]
|
||||
# adding new XMP namespaces
|
||||
@ http://dev.exiv2.org/boards/3/topics/1039
|
||||
|
||||
|
||||
[ install ubuntu ]
|
||||
$ sudo apt-get install libexiv2-dev libgexiv2-dev gir1.2-gexiv2-0.10
|
||||
|
||||
[ install mac ]
|
||||
# install globally (python2)
|
||||
$ brew install exiv2 gexiv2 pygobject3
|
||||
|
||||
# install for python3
|
||||
$ brew reinstall pygobject3 --with-python3
|
||||
|
||||
|
||||
[ build ]
|
||||
$ git clone git://git.gnome.org/gexiv2
|
||||
$ sudo apt-get install gobject-introspection
|
||||
$ sudo apt-get install glib libgirepository1.0-dev
|
||||
$ sudo apt-get install libglib2.0-dev libexiv2-dev python-gobject-dev
|
||||
$
|
||||
$ ./autogen.sh
|
||||
$ ./configure --enable-introspection
|
||||
|
||||
|
||||
|
||||
[[ EXIF ]]
|
||||
|
||||
[ exiv2 ]
|
||||
# BUILD
|
||||
http://dev.exiv2.org/projects/exiv2/wiki/How_do_I_build_Exiv2_on_the_XYZ_platform
|
||||
|
||||
[ pyexiv2 ]
|
||||
@ http://tilloy.net/dev/pyexiv2/
|
||||
|
||||
|
||||
[ exiftool]
|
||||
# perl program
|
||||
@ http://www.sno.phy.queensu.ca/~phil/exiftool/
|
||||
|
||||
$ brew install exiftool
|
||||
|
||||
|
||||
[[ exiftool]]
|
||||
# perl program
|
||||
# http://www.sno.phy.queensu.ca/~phil/exiftool/
|
||||
|
||||
$ brew install exiftool
|
||||
|
||||
|
||||
|
||||
|
||||
[[ Competitors ]]
|
||||
|
||||
[ authentication ]
|
||||
https://getclef.com/
|
||||
|
||||
|
||||
|
||||
[[ Debug ]]
|
||||
|
||||
$ exiv2 -ps image.jpg
|
||||
|
||||
|
||||
[[ Crypto ]]
|
||||
|
||||
[ Public Key ]
|
||||
|
||||
# encrypt
|
||||
@ https://pythonhosted.org/pycrypto/Crypto.Cipher.PKCS1_v1_5.PKCS115_Cipher-class.html#encrypt
|
||||
|
||||
|
||||
[ OpenSSL ]
|
||||
|
||||
openssl genrsa -out ~/myTestKey.pem -passout pass:"f00bar" -des3 2048
|
||||
openssl rsa -pubout -in ~/myTestKey.pem -passin pass:"f00bar" -out ~/myTestKey.pub
|
||||
|
||||
|
||||
[ Cryptography.io ]
|
||||
Fernet (Public Key)
|
||||
@ https://cryptography.io/en/latest/fernet/
|
||||
|
||||
|
||||
|
||||
[[ MVP Plan ]]
|
||||
|
||||
[ C ]
|
||||
libexiv --> exif read/write
|
||||
libwolfss --> crypto generation
|
||||
|
||||
[ Functions ]
|
||||
# load image file
|
||||
picseal.init(image_file)
|
||||
|
||||
# create pub/priv key pair
|
||||
# add new public key to exif
|
||||
# store priv key in memory
|
||||
picseal.add_new_key(CIPHER_TYPE)
|
||||
|
||||
# hash the image, encrypt hash with priv-key
|
||||
# hash the image & specific exif tags, encrypt hash with priv-key
|
||||
# add signatures to exif
|
||||
picseal.seal_image(HASH_TYPE)
|
||||
|
||||
# write the image with public key, and signature
|
||||
picseal.write_pub(FILE_HANDLE)
|
||||
|
||||
|
||||
# write the image with private key, and signature
|
||||
# ADD PIN??
|
||||
picseal.write_priv(FILE_HANDLE)
|
||||
|
||||
[ seal ]
|
||||
sha-512,public-key
|
||||
|
||||
|
||||
[[ Libraries ]]
|
||||
libexiv2-14 (= 0.25-2.1), libc6 (>= 2.14), libgcc1 (>= 1:4.1.1), libstdc++6 (>= 5.2)
|
||||
|
||||
|
||||
[[ Crypto ]]
|
||||
@ http://security.stackexchange.com/
|
||||
@ http://security.stackexchange.com/questions/135946/when-should-i-generate-new-public-private-keys-using-rsa
|
||||
|
||||
|
||||
|
||||
|
||||
[[ Images ]]
|
||||
|
||||
[ PIL Pillow ]
|
||||
# use pillow, a PIL fork
|
||||
@ https://github.com/python-pillow/Pillow
|
||||
@ http://pillow.readthedocs.io/en/3.0.x/handbook/tutorial.html#reading-and-writing-images
|
||||
|
||||
# no python 3 version :(
|
||||
ver 1.1.7, for Python 2.7, Nov 15 2009
|
||||
|
||||
|
||||
[[ JPG ]]
|
||||
@ http://stackoverflow.com/questions/4550296/how-to-identify-contents-of-a-byte-is-a-jpeg?rq=1
|
||||
@ https://en.wikipedia.org/wiki/Magic_number_%28programming%29
|
||||
@ http://www.effbot.org/imagingbook/image.htm#tag-Image.Image.tobitmap
|
||||
|
||||
|
||||
|
||||
[[ Testing ]]
|
||||
|
||||
|
||||
[ crypto test ]
|
||||
b'-----BEGIN PUBLIC KEY-----\nMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAnvdAyn5JuiRcoL8s+rAV\nMpoEUioB1NTV97EDG4z/R5pm89v86UkH0xeeB6OS2EacsPHmbIY6oY0IXKA+0EX6\nSZdVSya2vv36fy/CByfHgZsDUxpzMnRZLdYbITBwil7keCTOC4EfnYIMUDsvrx6s\nA+BSEbR1rUkIXMe7NJ2Qssj68lXKMOfhrJ9wUgPLVSTIiDytiX4Wd+yAuo9lUqUk\nxt7FwjEEBV5Nj0yKZp2sJZnqp+pL5dsLsYz9xKNQHonMkGuj+3IthenTkfuXm9a6\nx+Qm3B+6AN4qBd7Uz65tffS2e2OQCzSRVoqEaRUrQKvQcSfJv+w0lh4xoZs41CJE\nc8XmmJeaDqt/zYBQWWYJlvZfpq0oh3mKGmHRtNOnKQmMd+FRJj/5fUvG7WedcHt1\noAkUg1qKu/HBgPNTVN9PWaikM1fA1E8T1koCYN0ecP29Zo8SHwcL6g82ou+fGtae\nSrXW0bFKV1JbF+hF3nBzCw+xDPAXXpUGPTwSXYZa6Gvgfckk4qP17vfFaR9f+hiL\nmW8GUmgfupvbapcG189M+UB9nDUSj3557TJpqItdbH5m4FGNv9tcMRYSwIniVVxw\n+F5FuT7nhd8vC+simwyjlB3hteICya1c7tVo5rav/LBBzHYg9ywPJCdZKUvN3qRE\n4Txbp7DC99x/xZhGck2Cpj8CAwEAAQ==\n-----END PUBLIC KEY-----'
|
||||
privkey==
|
||||
b'-----BEGIN RSA PRIVATE KEY-----\n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\n-----END RSA PRIVATE KEY-----'
|
||||
text: attack at dawn
|
||||
crypt: b'A!\x81\t\xac\x87n4qw\x84\xcb\xf1\xdc\x1b\xc0\xdcjQ\xecB:A\xae\x14\xcc\xa9IpV\xa6\xc3\x10\xa2G\xc6\xae\xbbb} \xcf\x12\xfd\x92h\xb9\xd1\xc7\x80\xd9Q\xc1\xd8\x9b\x0c\x04\x14@C\xaa6\x0e\xdc\x95\xbf\xd0\x99\x0fV;i\x14\xbb\x86\xe1\xa2\xbfV]\xa4\x97t\xc7L\xc9sh\xd5\xbc6\x03\xea\xe7\x07a\x01\x08\x0e\\\x90|\xacT\xc2\xfb\xb8\xf7\xa9\xc7\x0c\x8a\xd9\xdbD\x8c\x98aWS\xdf.h\xb6\xb2H\x13\xdac\xd9\x7fM\x85\x8e\xa3\x00_\xeb\x15;\xd9J6\xc0\x99\xef\xf7\xf1D\xdb\xe8\x05\xdf\x16\xf9\x07\x13Gtv\xd9^\xcfr>\xd8w\xc6\xf0\xb8\xff\x1b\xf9rt%#\xc0\x83!\xb85\xb3X\xfd\x1a~\xd51D\x0c~3\xeb\x9fRc*\xb4\xa0\x84v?vI\xe00\xdd\x16\xc1u\x9e\xad`-P\xf8/N<83o\x8d\xb0Q\x82\xd5Z\x13\x8e\xee\xfa\xc0\x89.%\xeb\xdd\xc8.P\x03\x87\xe4C7e\xe9\xd1\x13\n\x83\xe9\x89\x0f^\xfb\xc8$\x95\x7f\xe3\x80G\xf9\x96_l\x03\x92\x01\x9e\xd1\x13\x9e\x8b\xdc-C\x02/^\xb5Nl\xcc\x7f\xb6\xb8v\x95\x998\x0c\x18?@\xaf\xaa\x1e\xea;gt\x83d(G\xefO\x1a\rq9>\xc4\xa5\x01-\xcd?q\x94\xf9\xa0\xa0\xe6}\x9aJjp\xa0\x05\xaf\xda\xf2\xc9\xd8\xf0\x1b\xbe\x0b\x80\xdc\x9c\xed\xabu\xc6\x0eT\x11\xbd8\x12\x10@\x9c\xf8\x97E\xea;\xcb\xf3\xaf\xf9\xc7\xad@\xf3#G\xc9&yE=\xa3nZ\xc7(9\xf15e\xae\xe4\xbdXmw\x98\xf5B\x885$w\x9b\x82\x89\xfa\xf6\xe9\xc9\xea\x95[22\xf4\xc9\xb9\xf9\xfb\xe2\xb4\xe8\xe7\xb2J\xc59\xac\x9e\xa9e\x13\xb4\x1c\xea\x18\xacy+\xb3\x01@$\xef\x15Ao\xb7Y\xf5]0I(\xd1\xd8E\x01^\xba\xa4W\x96D\xe5i\xf4e\x08c\xd37\x15\x1fb\xe5\xca\x9eAN^\xc0\xc8\x82\xa9\xb5N\xd2~\xc6d\xf7\xcbq\x02\x90\x1a#I\xf4\xf8\xe7i\xba\xcdQ\xeb\x87Agn\x8f'
|
||||
text: b'attack at dawn'
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
|
@ -0,0 +1,37 @@
|
|||
|
||||
|
||||
[[ JPG file parse Pseudo Code ]]
|
||||
|
||||
1) Verify File
|
||||
a. read JPG file: find record markers, save file locations
|
||||
b. verify no parsing issues
|
||||
c. save file locations for metatdate
|
||||
d. save file locations for image data
|
||||
2) Generate Hash
|
||||
a. hash all image data
|
||||
3) Digital Signature
|
||||
a. generate new public keys
|
||||
b. sign hash data with priv key
|
||||
4) Write new PicSeal Public file
|
||||
a. write encrypted original metadata
|
||||
b. write PicSeal metadata
|
||||
i. write JSON
|
||||
b. write image data
|
||||
5) Write new PicSeal Private file
|
||||
a. create thumbnail (smaller files)
|
||||
b. write PicSeal metadata (JSON)
|
||||
c. write image data
|
||||
|
||||
|
||||
[[ PicSeal Metadata ]]
|
||||
JSON Format
|
||||
|
||||
{
|
||||
"format_ver": "50",
|
||||
"pubkey_alg": "rsa",
|
||||
"pubkey_size": 4096,
|
||||
"pubkey_pem": "MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAnvdAyn5JuiRcoL8s+rAV\nMpoEUioB1NTV97EDG4z/R5pm89v86UkH0xeeB6OS2EacsPHmbIY6oY0IXKA+0EX6\nSZdVSya2vv36fy/CByfHgZsDUxpzMnRZLdYbITBwil7keCTOC4EfnYIMUDsvrx6s\nA+BSEbR1rUkIXMe7NJ2Qssj68lXKMOfhrJ9wUgPLVSTIiDytiX4Wd+yAuo9lUqUk\nxt7FwjEEBV5Nj0yKZp2sJZnqp+pL5dsLsYz9xKNQHonMkGuj+3IthenTkfuXm9a6\nx+Qm3B+6AN4qBd7Uz65tffS2e2OQCzSRVoqEaRUrQKvQcSfJv+w0lh4xoZs41CJE\nc8XmmJeaDqt/zYBQWWYJlvZfpq0oh3mKGmHRtNOnKQmMd+FRJj/5fUvG7WedcHt1\noAkUg1qKu/HBgPNTVN9PWaikM1fA1E8T1koCYN0ecP29Zo8SHwcL6g82ou+fGtae\nSrXW0bFKV1JbF+hF3nBzCw+xDPAXXpUGPTwSXYZa6Gvgfckk4qP17vfFaR9f+hiL\nmW8GUmgfupvbapcG189M+UB9nDUSj3557TJpqItdbH5m4FGNv9tcMRYSwIniVVxw\n+F5FuT7nhd8vC+simwyjlB3hteICya1c7tVo5rav/LBBzHYg9ywPJCdZKUvN3qRE\n4Txbp7DC99x/xZhGck2Cpj8CAwEAAQ==",
|
||||
"image_sig": "6acda44a9e492ddcc0e6ddadbdbd2cc20fdbb06a9264f36268b03aff921332919edb541d9bcdafa2b958276fb553682e5b67d92a127ec8d5d89b29774db86c50",
|
||||
"metadata_sig": ""
|
||||
}
|
||||
|
|
@ -12,7 +12,7 @@
|
|||
* add option "-e" to encrypt file
|
||||
* add option "-ex" to export the key to .PEM file
|
||||
* add visual stamp to the file so that a picseal photo can be recognized
|
||||
|
||||
* use block-chain for "certified secret" technology, insert hash signature into block-chain
|
||||
|
||||
|
||||
|
||||
|
|
Loading…
Reference in New Issue