Skip to content

Identifi implementation built on Bitcoin code

License

Notifications You must be signed in to change notification settings

bitland/identifi

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

57 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Identifi

http://identifi.org http://slid.es/mmalmi/identifi

What

  • Distributed identity and reputation database
  • Web of trust
  • API for integration with various trust or identity dependent applications
  • Anyone can add identifiers and make statements about their relations to others
  • Anyone can add reviews with their identity
  • Credibility of statements can be evaluated by their author's reputation (history, social connections, identity verifications, reviews etc.)

Why

  • Prevent spam (by accepting messages only from trusted / socially connected senders)
  • Prevent astroturfing / sockpuppeting
  • Makes it possible to trust people you have never met
    • Utilize your good reputation in various services and situations
    • Reduces risk of trade or loan, thus reducing price
  • Ubiquitous reputation as non-violent, cost-effective and decentralized justice
    • Everyone can choose whose judgement or review to trust
    • Incentive against antisocial behavior
    • Incentive to restore trust by compensation and apology for misdeeds
  • Facilitate gift economy / time banking
  • Distributed public messaging, with trust lists instead of centralized moderator power
  • Censorship-resistance
  • Open database, vs. proprietary information silos of reputation and online identity
    • No monopoly on credit ratings

How

  • Prototype built on Bitcoin code to utilize existing crypto, network, CLI, etc. functions (but not blockchain)
  • Data package: [subject identifiers, object identifiers, message][signatures]
    • Identified by content hash
    • Signed by the entity which verified that the message originates from the named subject. Thus, all end users need not to have a crypto key of their own.
  • Flood packages throughout the network
    • Nodes can choose to accept only packages with 1) a trusted signature, 2) trusted subject
  • Crawl initial data from existing social networks and review systems

Building

Makefile.unix builds nicely with dependencies from Debian packages (same as Bitcoin + sqlite).

Other makefiles TBD.

Developing

Sqlite Manager is a nice Firefox plugin for debugging DATADIR/db.sqlite.

License

Identifi is released under the terms of the MIT license. See COPYING for more information or see http://opensource.org/licenses/MIT.

Data format

Using JSON serialization for the prototype. BSON might be more efficient to process and would enable binary fields for attachments such as images.

Suggested data format for Identifi packets:

{
	'signedData':
	{
    	'timestamp': 1373924495,
	    'author':
	    [ 	
	    	['name', 'Alice Smith'],
	    	['mbox', 'mailto:alice@example.com']
	    ],
		'recipient':
		[
    		['nick', 'Bob the Builder'],
    		['url','http://twitter.com/bob'],
    		['url','http://www.facebook.com/bob'],
    		['depiction','magnet:<photo hash>?xs=http://example.com/1.jpg']
		],
		'responseTo': ['magnet:<hash of bob's message>'],
		'type': 'review',
		'comment': 'Bought a laptop from Bob. Thanks for the trade!',
		'rating': 1,
		'maxRating': 10,
		'minRating': -10
	},
	'signatures':
	[
		{
			'signerPubKey': 'asdf1234',
			'signature': '4321fdsa'
		}
	]
}

SignedData may optionally contain additional fields.

Packets and identifiers are to be stored locally in a hash table (or maybe later in a DHT). These hashes can be refered to with magnet URIs.

Packets are digitally signed by the entity that verifies that the message originated from the claimed sender. For example, this could be a website where the sender logged in with a Facebook account, or a crawler that read the sender's message from Twitter.

Message encoding is UTF-8.

TODO

  • Improve in-built trust evaluation algorithm
  • Recalculate old trust ratings when new packets arrive
  • Improve network functions, add sanity checks
  • Remove unnecessary Bitcoin code
  • Add more signature methods
  • Write performance tests and improve efficiency
  • Crawlers
  • Visualizations
  • Trusted sites as entry points to the WoT. Let users authenticate with email, FB, pubkey, etc.

Future considerations

Use Redland triple storage and/or HDT serialization? This would enable handling of all kinds of RDF documents (standard FOAF for example) and queries by SPARQL.

Use Whanau DHT instead of a flooding network?

Freenet as data storage? Saving data is trivial, but efficient indexing needs some effort.

Use external SQL DB instead of sqlite for better multi-application access to data?

Use GPGME to integrate with PGP web of trust? Could provide a nice entry point to the Identifi WoT for many people.

Data format is quite similar to Trsst? Use the same?

Serialize in BSON to improve efficiency and enable embedded binary (images etc)?

About

Identifi implementation built on Bitcoin code

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published