Skip to content

Commit

Permalink
last update didn't work
Browse files Browse the repository at this point in the history
  • Loading branch information
neyer committed Oct 25, 2014
1 parent f7d4f6e commit 81f3aa5
Show file tree
Hide file tree
Showing 2 changed files with 225 additions and 17 deletions.
187 changes: 178 additions & 9 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,9 +1,178 @@
#ddv1 IAMA (hashtag)
#ddv1 AMNOT (hashtag)
#ddv1 TRUST (URL)
#ddv1 DISTRUST (URL)
#ddv1 AGREE (URL)
#ddv1 DISAGREE (URL)
#ddv1 SAME (address, address)
#ddv1 OFFENDED (address, address?, url?)
#ddv1 FORGIVE (address, address, url?)
# dewDrop
## a formal language for social networks


# what

dewDrop is a simple formal language for use on social networks.

# why

Online harrassment is a serious problem. Sensitive discussions about important topics are easily derailed by trolls. In addition to runining the experience of a person discussing anything online, trolls can claim to be a member of any group or support any ideology, giving a non-affiliated group a bad name through false flag techniques.

With a formal language, we can aggregate statements people make in the language to do things like:

* Block users who are marked as trolls by a number of my trusted friends
* When interacting with a stranger, use this person's distance from me on the social graph as a proxy for trustworthiness
* Incentivize people to admit they have erred - a public record of you apologizing shows you are trustworthy
* Find out how many self-identified republicans support gay marriage
* Find out how many self-identified muslims support ISIS

Nobody is perfect. This is a known fact. With a public record of the times we have offended people, a person can show that work to obtain forgiveness, and succeed in doing so. At present, without a formal language or agreed upon record, people have little incentive to apologize when they've offended someone, and no way of knowing if they are dealing with a troll who wants to annoy them, or a caring person who has either misspoken or been misunderstood.

People who have a record of apologizing when they offend others, and seeking forgiveness for doing so - those are people much more worth talking to. dewDrop can help us find each other.


# how
The language can be determined by simple regular expresisons. The primitives are keyworks, hashtags, and urls. A simple parser is implemented in `parser.py`. This is the complete specification for version 1 of the dewDrop language.

## General syntax
All dewdrop messages can begin with any text; the dewDrop portion starts with #ddv1 to identify it as a dewDrop message. The next token should be a one of the verb keywords of the language. The remaining tokens following the verb should be nouns upon which the verb operates.

.* #ddv1 <VERB> <NOUN> [<NOUN> ]*

Most Nouns will be URLS - A user can be referred to with the URL of their social media account. If a dewDrop statement is made on twitter, the '@userName' syntax will be assumed to refer to that person on twitter. You can also speak about a user account at another site - like a reddit user, a facebook user, an email address, a telephone number... any protocol you wish.

The verbs are: "ISA, NOTA, AGREE, DISAGREE, TRUST, DISTRUST, SAMEAS, OFFEND, SORRY, FORGIVE, THANKS".
They are explained below:

## Group Membership
Groups in dewdrop are represented by hashtags. A person can claim to be a member of a group with the 'ISA' verb, and claim not to be a meber with the 'NOTA' verb. For example, the sentence

#ddv1 ISA #democrat

Means "The speaker of this sentence claims to be a member of the #democrat" group. Any group you want to identify with can be used as a hashtag. This way, discussions around social movements, say "#yesAllWomen", can involve people stating their identification with principles of the group. If I choose to leave a group - either becuase their values have changd, or I have - I can ussue a 'NOTA' statement:

#ddv1 NOTA #vegetarian

A person can also make statements about other people. I can claim that Ralph Nader is a #greeparty member:

#ddv1 ISA #greeparty @RalphNader

.* #ddv1 ISA (HASHTAG) [URL]
.* #ddv1 NOTA (HASHTAG) [URL]


## Statement Agreement
.* #ddv1 AGREE (URL)
.* #ddv1 DISAGREE (URL)

Agreement in dewDrop can be signalled with the AGREE verb. Disagreement can be signaled with the DISAGREE verb. A Person can agree with any URL they wish. I might agree with another statement someone has made by agreeing with the url of that statement:
#ddv1 AGREE https://twitter.com/MarkPNeyer/status/525766862949199873

I can also agree with a supreme court decision by 'agreeing' with a news article about the supreme court decision, or the wikipedia page.

When a discussion evolvs to a certain point, must likely a hashtag will be created to represent the movement. At that point, people who agree with one 'side' of the discussion will issue a 'group memebership' statement. The point of 'agremeent' statements is primarily to allow people to agree or disagree with other people's statements.

Suppose Alice, who supports marriage equality may issue a statement:

@Alice: #ddv1 AMA #LGBTAlly

Now, suppose Bob says:

@Bob: you said there's no such thing as bisexual #ddv1 NOTA #LGBTAlly @Alice

Bob's statement is equivalent to him saying:

@Bob: #dd1 DISAGREE https://twitter.com/ALICE/status/1234

So now suppose more self-identified members of the group #LGBTAlly weigh in on the discussion. Some may issue AGREE statements with @Alice, and some may issue @AGREE statements with Bob. A discussion will happen, and either the #LGBTAlly group will integrate itself, and come to a conclusion, or else it won't and people who can't agree will stop associating under the same banner.

Suppose that discussion resolves itself, with @Alice agreeing that bisexuality is a natural thing, too. She may issue statements like this:

@Alice: you were right about accepting bisexuality #ddv1 SORRY @Bob

Suppose that statement has URLphttp://twitter.com/Alice/status/1235 - Bob may issue these statements:

@Bob: it's all good #ddv1 FORGIVE http://twitter.com/Alice/status/1235
@Bob: #ddv1 AGREE https://twitter.com/Alice/status/12345

As a result of this exchange, the '#LGBTAlly' has increased its integrity; the self-identified members of the group are largely in agreement with each other about what constitutes group membership, AND they have successfully resolved a conflict between two members.


## Trust and Distrust
.* #ddv1 TRUST (URL)
.* #ddv1 DISTRUST (URL)

At lower layer than disagreement is trust. I can disagree with someone, but still believe they are honestly expressing their belief. Users in dewdrop have the ability to state trust and distrust in statements or other users with the 'TRUST/DISTRUST' a verbs.

A statement of trust is not a statement of agreement. My mother my say she supports 'traditional marriage' - and although i disagree with her on this, I trust that this is an honest representation of her beliefs. If someone else comes along and says "I believe all black people are criminals" - I will disagree with this statement. I will only _disrust_ the statement if I have reason to believe that this person is trolling, or does not really believe the thing they are saying.

A healthy discussion about unpleasant topics, people will disagree and this is to be expected. It's really not possible to have a healthy discussion with someone you distrust. I suspect dewDrop users will make less frequent use of the 'DISTRUST' verb; it will be used primarily to block trolls.

If i stay I distrust someone, all of my friends can see that, and may know to stay away from that person and to ignore their messages.

The opposite statement - TRUST - implies that the person i am speaking about is an honest, genuine person. I don't agree with everyone my mom says, but i trust her. I want people who trust me to extend that trust to her - I don't expect them to agree with her, but I would be very surprised if anyone thought she were a troll.

People who are concerned about trolling or being victimed online can follow the TRUST statements issued by their friends to whatever extent they feel comfortable with. Someone who feels mostly comfortable online may say "I'll accept messages from any users whom I can reach through a TRUST-path of length 4 or less." Someone who feels less comfortable or is more worried about harassment can block or ignore users with a TRUSt-path length of more than 2 - implying they are willing to speak to trusted friends of trusted friends, but not anyone else.

The 'TRUST' statements allow us to protect each other from trolls. Anyone is free to disregard these statements, of course - but if I know I can talk to a lot of interesting people following only trusted links from friends, and I know that accepting messages from random strangers puts me at risk of serious harassment - I should have the freedom to choose whom I wish to associate with.

## Same Identity

.* #ddv1 SAME (URL) (URL)

This statement may seem small at first, but it actually gives dewDrop a lot of power. It's used to link identities together - so that I can say "this facebook account is the same as this twitter acount", this email address belongs to this account, etc. If @Eve someone creates a fake trolling account @Fred, and I'm certain it's @Eve pulling the strings, I can make this statement public:

@Bob: #ddv1 SAME @Eve @Fred


The standard mechanism for resoving these disputes applies; people who know @eve may disagree, @fred will probably disagree as well. If there are trusted friends involved that know both of us, they may want to step in to resolve this dispute.


The 'SAME' statement also allows for a unified sense of personhood to emerge from multiple social media accounts. I can make a statement about my friend on facebook, and his twitter followers will be able to make sense of the same statement.


## Offense, Apology, Forgiveness

.* #ddv1 OFFEND (URL)[, (URL)[, (URL)]]
.* #ddv1 FORGIVE (URL)[, (URL)[, (URL)]]
.* #ddv1 SORRY (URL)[, (URL)]

People upset each other. This happens, and its part of the world. By keeping a record of those we have upset, and those who we've forgiven, we can all help each other get a better gauge of who are are. If i run into a stranger on twitter who really upsets me, and i see from his record that friends of friends have all been upset by this guy, but for every single one, he's apologized and they've forgiven him - it suggets that he may be worth talking to.

If someone else has offended far fewer people, but has never apologized or been forgiven - it suggests that his offense to me is'nt going to change, and I should probably ignore him.


The syntax for 'offend' is :
#ddv1 OFFEND (person who did the offense) (person who felt offended) (description of the offense)


So, If @bob simply wants to say "@Alice has offended me" he can do this

@Bob #ddv1 OFFEND @Alice

Perhaps bob thinks Alice has offended his mother. Then he might say this:

@Bob #ddv1 OFFEND @Alice, @BobsMama

If there wre a specific tweet Alice had written, say with address 'http://t.co/123', he might state:

@Bob #ddv1 OFFEND @Alice @Bob http://t.co/123


Maybe alice didn't realize that this was a problem. She might start by immediately apologizing to show good faith:

@Alice i'm not sure what happened lets talk #ddv1 SORRY @Bob

And then she and Bob talk a while, until they found out that Alice made a joke about potato farming, and bob's mother was eaten by a potato. At the end of the conversation, bob says


@Bob: most people don't know the danger of spuds #ddv1 FORGIVE @alice
@Bob: i know i overreacted a bit #ddv1 THANKS @alice


And now everyone feels better! Hooray!


## Thanks

dewDrop members can say thanks to each other. Isn't that cool? A user who's gotten lots of 'thanks' from friends of friends is probably trustworthy - but again, that is up to you to decide. The point of dewDrop is merely to give people the ability to speak formally, in a way that there statements can be aggregated into a collective whole. You'll no longer be a drop in the ocean, but an edge in a proof. Thanks!

.* #ddv1 THANKS (URL)[, (URL)]


# warning

I have no idea how this will turn out, but i have some intuition. Suppose you shorted bitcoins in 2010, selling 10,000 bitcoins you didn't for $0.10 apiece. You'd earn yourself a profit of $1,000 - and if you didn't pay them back, you'd be $3,000,000 in debt today. I really think this kind of network could change the world. If you defect against people trying to make the world better, by trolling us - you are standing in the way of human progress. We are building a record book that essentially blocks trolls from the public discourse - is trolling that group of people really a good idea?

55 changes: 47 additions & 8 deletions parser.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,15 @@


def get_tokens(raw_text):
return raw_text.split("")
words = raw_text.split("")

index = 0
try:
index = words.index(DDV1_TOKEN):
raise ValueError:
return []
return words[index:]


def is_valid_dddv1(tokens):
return len(tokens) and tokens[0] = DDV1_TOKEN
Expand All @@ -16,17 +24,28 @@ def get_statement_type(tokens):
return len(tokens) > 2 and tokens[1]


def parse_iama(tokens):
def parse_isa(tokens):
should_be_hashtag = tokens[2]

if HASHTAG_REGEX.match(should_be_hashtag):
return True
if not HASHTAG_REGEX.match(should_be_hashtag):
return None
if len(tokens) > 3:
if not URL_REGEX.match(tokens[3])
return None
return True


def parse_amnot(tokens):
def parse_isnot(tokens):
should_be_hashtag = tokens[2]

if HASHTAG_REGEX.match(should_be_hashtag):
return True
if not HASHTAG_REGEX.match(should_be_hashtag):
return None

if len(tokens) > 3:
if not URL_REGEX.match(tokens[3])
return None

return True

def parse_trust(tokens):
should_be_url = tokens[2]
Expand Down Expand Up @@ -62,7 +81,7 @@ def parse_same(tokens):
return True


def parse_offended(tokens):
def parse_offend(tokens):
url1 tokens[2]

if not URL_REGEX.match(url1):
Expand All @@ -76,6 +95,18 @@ def parse_offended(tokens):
if not URL_REGEX.match(tokens[4]):
return None
return True

def parse_sorry(tokens):

if not URL_REGEX.match(tokens[2]):
return None

if len(tokens) > 3:
if not URL_REGEX.match(tokens[3]):
return None

return True


def parse_forgive(tokens):

Expand All @@ -89,6 +120,14 @@ def parse_forgive(tokens):
if len(tokens) > 4:
if not URL_REGEX.match(tokens[4])
return None
return True


def parse_thanks(tokens):
if not URL_REGEX.matches(tokens[2]):
return None
if len(tokens) > 3:
if not URL_REGEX.matches(tokens[3]):
return None
return True

0 comments on commit 81f3aa5

Please sign in to comment.