TLDR: Back in 2015 I had mapped out an entire API for an Address application, The idea is meh, but some of the detailing here and the diagrams I am still a big fan of.
Jul 19, 2015
Summary
TLDR: Idea for a web app that allows you to login and save your address. Then have the ability to connect your addresses across multiple sites in a centralized fashion. Think facebook connect for addresses. Every site that needs your address (think e-commerce) would have a “connect” button that would assign an address from a possible list. Third-party apps would request your latest address whenever they want to send you something.
The web is a vibrant and thriving place. While there may be a ton of advancement happening every day to make our lives easier, some of the things we do everyday are still traditional and repetitive. One of those things is managing and distributing our physical addresses. How can we make managing addresses easier across the entire web? This document is a specification for a service to rectify this very issue.
Current Problems
- Every site stores your address on it’s own servers. That means it’s decentralized. Let’s say you move where you live, you can’t just update your address in one place and have this change for every site. If you signup for a new service you have to type the whole thing in again.
- When you place an order online, if you enter the wrong address (which would happen less frequently with this service) you have an allotted amount of time before that order ships, I call this time the
buffer time
. This service aims to help manage this with a high level of efficiency and detail. Currently the only way to change an address on most sites is to get in touch with a person directly, and have them check if the orders been processed by a fulfillment warehouse and manually update an address if not. Some sites do urge that you verification your address in anorder confirmation
email. Some provide a way to change your address programmatically after order creation. But still thebuffer time
isn’t standardized, and it’s not the same for every site. - Privacy. When using the service you’ll be able to list who has had access to an address, when, what address, and how frequently. You can even block other users, apps, or sites, from requesting your latest address.
- Have you ever wanted to send someone physical mail and you didn’t know their address? Have you ever needed to ask for addresses in bulk? Need to seend out wedding invitiaions? How do you manage all of that? This service aims to fix this, have your address in the system? Great! All you need to do is grant access to other users. Not in yet? Add it for the first time, then grant access.
Definitions
App
Whenever I refer to App
I mean everything written in this document including the finished software and the idea. Usually referred to as “the App
“.
Request
The term Request
is used a lot in the following sections. It may mean to send something digitally, like “sending a request”, which is the same as “sending the data”. And it may also mean to ask for something digitally as well, as in “request the address”, which is the same as “ask for the data”.
User
A User
is a person, just like you and me. They have the ability to create a Third-Party-App
or a Site
.
- They can ask a
User
for aAddress
.
- Can
User
Thomas Reggi
access your address to send you mail?
App-Api
The App-Api
publicly available (through oAuth and cryptography) set of urls on the server that allow a Third-Party-App
to connect to the App
. When connected the Third-Party-App
has access to Actions
and Data
. For instance making a request to the endpoint http://App.com/api/address/thomasreggi.json
would get the Addresses
for the Userthomasreggi
in the .json
format.
Third-Party-App
A Third-Party-App
is a software created as a service that utilizes the App-Api
to interact with the App
. They can contain their own Addresses
.
The numbered line is the privilege and the line below is what the User
would approve or decline.
- They can ask a
User
for aAddress
.
- Can
Third-Party-App
Example App
access your address to send you mail?
- They can ask a
User
for aAddress
for aUser
.
- Can
Third-Party-App
Example App
give your address toUser
Thomas Reggi
so they can to send you mail?
- They can ask a
User
for aAddress
on behalf of aUser
.
- Can
Third-Party-App
Example App
send you mail on behalf ofUser
Thomas Reggi
?
Site
A Site
is a Third-Party-App
where the url has been verified. For example if an employee at jcrew.com
wanted to integrate the App
into their store, they would want to be represented as jcrew.com
so they would follow the steps for TXT Record Domain Verification. Without this feature if someone squatted on the Third-Party-App
name jcrew
then the real jcrew
would be out of luck. Plus the verification means we could show the visually show that the Site
is a verfied which midigates Phishing.
The options are the same, the message is a little different.
- They can ask a
User
for aAddress
.
- Can
Site
amazon.com
access your address to send you mail?
- They can ask a
User
for aAddress
for aUser
.
- Can
Site
amazon.com
give your address toUser
Thomas Reggi
so they can to send you mail?
- They can ask a
User
for aAddress
on behalf of aUser
.
- Can
Site
amazon.com
send you mail on behalf ofUser
Thomas Reggi
?
Amazon is the perfect example for this because they allow all three. Not all sites need all three, but that’s ok.
Here’s where Amazon correlates.
- Buy something from Amazon. (ex. Kindle)
- Buy something from a Amazon seller, where they manage their inventory. (ex. Used Book)
- Buy something from a Amazon seller, where amazon fulfillment manages their inventory.
Below are mockups that describe different webpages and the flow from one page to the next. Each square is a page, they move from left to right, you might need to scroll to the right to see some of them.
Mockups
App
Homepage & Dashboard
- View Homeapge
- Login or signup. If already logged in redirect’s to next page.
- View dashboard
+---------------------------+ +---------------------------+ +---------------------------+
| | |Mail App: Login | |Mail App: Dashboard |
| | +---------------------------+ +---------------------------+
| MAIL APP | | | | |
| | | Username: | | - Addresses |
| [signup] [Login] | | +-----------------------+ | | * new / update |
| | | +-----------------------+ | | - Manage Requests |
+---------------------------+==>| Password: |==>| |
| * organize your addresses | | +-----------------------+ | | |
| across all sites | | +-----------------------+ | | |
| * update all your sites | | | | |
| at once | | [sign-up] or [login] | | |
| * easily request address | | | | |
+---------------------------+ +---------------------------+ +---------------------------+
User
to User
Request
- Request addresses from user email (will be asked to signup / login)
- Shows list of Pending Requests.
These Events lead to User-to-User Authorize
+---------------------------+ +---------------------------+
|Mail App: Request Address | |Mail App: Requests |
+---------------------------+ +---------------------------+
| | | |
| Email:[************] | | Email | Status | Addr |
| --or-- | | +-----|--------|--------+ |
| Username:[*********] | | +-----|--------|--------+ |
| --or-- |==>| +-----|--------|--------+ |
| [Upload User Sheet] | | +-----|--------|--------+ |
| | | +-----|--------|--------+ |
| [submit] | | |
| | | |
| | | |
+---------------------------+ +---------------------------+
User
to User
Authorize
These events are the effect from [User
-to-User
Request](https://github.com/reggi/writing/blob/master/2015-07-19-address-api.md#user-to-user-request)
- User receiving email message to provide access to their address
- Login or signup. If already logged in redirect’s to next page.
- Approve and select address or deny request.
+---------------------------+ +---------------------------+ +---------------------------+
|gmail.com | |Mail App: Login | |Mail App: Authorize |
+---------------------------+ +---------------------------+ +---------------------------+
| | | | | | |
| | user thomasreggi | | Username: | | user thomasreggi |
| | would like to | | +-----------------------+ | | would like to |
| | access your address | | +-----------------------+ | | access your address |
| | |==>| Password: |==>| |==> ?
| | [login] | | +-----------------------+ | | * [approve] |
| | | | +-----------------------+ | | - [address dropdown] |
| | | | | | - [auto-accept requests] |
| | | | [sign-up] or [login] | | * [decline] |
| | | | | | |
+----+----------------------+ +---------------------------+ +---------------------------+
Site
to User
Request-Authorize
User
is checking out on a website and needs to connect address, signs in.- Login to the
App
, if not already logged in. - Approve
Site
and select address or deny request.
+---------------------------+ +---------------------------+ +---------------------------+
| | |Mail App: Login | |Mail App: Authorize |
| jcrew.com Checkout | +---------------------------+ +---------------------------+
| +-----------------------+ | | | | |
| | | Username: | | site jcrew.com |
| item 1 ............ 10.00 | | +-----------------------+ | | would like to |
| item 2 ............ 10.00 | | +-----------------------+ | | access your address |
| |==>| Password: |==>| |==> (Redirect back to cart)
| Connect your address | | +-----------------------+ | | * [approve] |
| | | +-----------------------+ | | - [address dropdown] |
| [sign in] | | | | - [auto-accept requests] |
| | | [sign-up] or [login] | | * [decline] |
| | | | | |
+---------------------------+ +---------------------------+ +---------------------------+
Site
for User
to User
Request-Authorize
User
is checking out on a website and needs to connect address, signs in.- Login to the
App
, if not already logged in. - Approve and select address or deny request.
+---------------------------+ +---------------------------+ +---------------------------+
| | |Mail App: Login | |Mail App: Authorize |
| Ebay.com Checkout | +---------------------------+ +---------------------------+
| +-----------------------+ | | | | user thomasreggi |
| | | Username: | | via site amazon.com |
| item 1 ............. 3.00 | | +-----------------------+ | | would like to |
| | | +-----------------------+ | | access your address |
| |==>| Password: |==>| |==> (Redirect back to cart)
| Connect your address | | +-----------------------+ | | * [approve] |
| | | +-----------------------+ | | - [address dropdown] |
| [sign in] | | | | - [auto-accept requests] |
| | | [sign-up] or [login] | | * [decline] |
| | | | | |
+---------------------------+ +---------------------------+ +---------------------------+
Third-Party-App
on behalf of User
for User
This is an idea for an Third-Party-App
called Send Mail
.
- The landing page to the
Third-Party-App
with login button. - Login to the
App
, if not already logged in. - Approve or decline the
Third-Party-App
that will send mail on your behalf. - Craft a message, enter the email address of the recipient, or the
User
.
- These Events lead to
[User
-to-User
Authorize](https://github.com/reggi/writing/blob/master/2015-07-19-address-api.md#user-to-user-authorize)
- View pending messages.
- If the
User
doesn’t have an account they will be prompted to make an account. - If the
User
has auto-approved messages from you as a user, or auto-accepts mail from this app it will be auto accepted. - If the status of a message is approved then the senders address is in the system and mail can be sent. Pay to send it.
tl;dr This is an idea for a Third-Party-App that allows you to proxy mail and sends it on the behalf of another User. The Third-Party-App is responsible for sending the mail. Which means that the SenderUser never sees the RecipientUser’s address (just make sure the Third-Party-App’s return address is on the envelope’).
This Third-Party-App
would allow a User
to send another User
mail without the sender ever getting hold of the recipients address. I thought of this app in tandem with a physical business. The idea being that the creator of this Third-Party-App
would be the proxy mail between the two users. This Third-Party-App
would do the mailing on behalf of a customer. All that’s really needed to pull this off is a list of all letters to mail for the day, a box of envelopes with two plastic windows and a ream of 8.5”x11” paper. Using the App-Api
the creator can export a all the PDF letters for a day, fold the, stamp the envelopes, and mail them. In this case someone would need to pay the Third-Party-App
creator to mail the letter. If under some promotion this may be able to be to funded by the Fan’s recipient in bulk. Say Neil Degrasse Tyson or Bill Nye was running a promotion (ideally taking questions about scientific inquiries) then all mail to him would be paid for by a third party and not the sender. There are also less involved ways of sending physical mail, there are many api’s that already exist that allow you to do it. This Third-Party-App
could also be harnessed to send people in your contacts (that you have the email of).
+---------------------------+ +---------------------------+ +---------------------------+ +---------------------------+ +---------------------------+
| | |Mail App: Login | |Mail App: Authorize | |SENDMAIL: Craft Msg | |SENDMAIL: Pending Msgs |
| | +---------------------------+ +---------------------------+ +---------------------------+ +---------------------------+
| SENDMAIL | | | | | | | | |
| | | Username: | | app SENDMAIL | | Send-to:[johnny@apl.com] | | To|Status--|Send |
| [sign-up-with-mail-app] | | +-----------------------+ | | would like to send | | Message Body: | | +-|Approved|[pay $2]----+ |
| | | +-----------------------+ | | mail on your behalf | | +-----------------------+ | | +-|--------|------------+ |
+---------------------------+==>| Password: |==>| |==>| |Dear, Johnny Ive | |==>| +-|--------|------------+ |
| * we send a physical | | +-----------------------+ | | * [approve] | | |I <3 You!!! | | | |
| letter on your behalf | | +-----------------------+ | | * [decline] | | | -tom | | | |
| * all happens without | | | | | | | | | | |
| someone exposing their | | [sign-up] or [login] | | | | +-----------------------+ | | |
| address to a sender | | | | | | [send] | | |
+---------------------------+ +---------------------------+ +---------------------------+ +---------------------------+ +---------------------------+
API
Here’s a bit of technical flow of how I’d see the API working. But first a primer on what we’re collecting.
There are two main distinctions about the App
.
- This is a service that allows a user to store their address in one centralized place.
- This is a service that allows a user to store addresses and keep track of what mail they’re getting.
There’s a lot of phrasing like wants to access you address
above, or would like to access your address
. But why? Why would anyone want your address? It’s most-likley to send you something. The idea is that instead of just innocently accessing an address the wording should probably be changed to wants to send you something
. Regardless of the wording there’s another psychological hump my developer brain needs to get over. Why would an site like jcrew.com
request your address more than once? Once they have it they can do whatever they want with it. They can even sell it to another third party. The only reason I can rationally think they’d need to request it again is to see if the address has been changed. This is perfectly valuable. If we’re collecting information every time they make a request to get the address about why the third-party needs. Then we have information about every package, parcel, or letter a person is receiving. Most importantly we have real-time data.
The way I see it is the service would be a bit of both. In the case for user-to-user address request I’m not gonna log back in and update that I sent you something. I’m just gonna take the address and run. But in the case of an e-commerce store, it’s not that much more work to send information programmatically.
What is a webhook
?
Before we dive in I just wanted to define webhook
. A webhook
allows for a Third-Party-App
to subscribe to a specific event. What does that mean?
A Third-Party-App
is software that runs on a server. It could have urls like /api/subscribe-webhook/address.json
and whenever someone (or another server) visits that page the Third-Party-App
knows, and can run specific software. So essentially a webhook
is a way for two servers to talk to each other securely.
Let me give an analogy.
Let’s say your a comic book aficionado
and you always like to get the most recent comic book from the comic book shop
as soon as it arrives. You pickup the telephone and tell the clerk give me a call whenever an issue of a specific comic comes in (lets say superman
). The clerk says, alright, will do, and hangs up the phone. You wait patiently with your phone on and close by for a call. Ring! Ring! You pickup the phone, and it’s the clerk and he tells you there’s a new comic in, issue #23 just arrived.
In this analogy the comic book aficionado
is the Third-Party-App
, the comic book shop
is the App
. The act of making the call and telling the clerk what comic you’d like is called subscribing to a webhook
. The webhook
is the superman
comic. The clerk saying alright is the subscribing process being a success. You waiting patiently is the Third-Party-App
having an open url and being able to accept requests to it’s server. You picking up the phone is the Third-Party-App
responding to the webhook
request. Lastly the clerk telling you what issue is the webhook payload
.
What’s the alternative to this anology? If the comic book shop
clerk wasn’t so nice to give you a call, and assuming they still had a telephone. You would have to call everyday, perhaps even multiple times a day. That’s pretty inefficient and time-consuming. When it’s code you can make these kinds of requests a thousand times a minute, this means a lot of requests come back with no new data. This is what most servers and still do back when RSS was all the rage and it’s really inefficient.
/get-address.json
When a third party requests an address for instance on the checkout page of a store, I click the button and provide access. There’s information that goes along with that request. The store needs to provide some information.
buffer_time
Remember when I mentioned buffer time
the time that it takes for a store, vendor, supplier to ship something? This is where that comes in. If you go to mockup for Site
to User
Request-Authorize the buffer time
would be displayed to the user in page 3, it would say something like. You have 3 days to change your address.
This all allows for the following. When an address is updated by the user then they will be shown a list of authorized Third-Party-Apps
(and Sites
) where the buffer time
is still open, a webhook
can be sent to these Third-Party-Apps
(and Sites
). For example if I buy something from jcrew.com
and use the App
, submit my address and feel like changing my address from my home
to the office
retro-activley after purchase, I can do so if there is still buffer time.
Again this would only work if the Third-Party-App
has buffer_time
enabled and is subscribed to update address webhook
.
message
The message
is a required (perhaps not for User
-User
) field that is visible to the user for every request.
Example
Request:
{
"message": "Ordered Teddy Bear",
"buffer_time": 259200 // 3 days in seconds
}
Response:
{
"id": "1234567890qwertyuio1234567890",
}
/mail_sent.json
The mail sent
request must be sent sometime following a get address
request. AnThird-Party-App
(or Site
) will not be able to request an updated address until they send this request.
id
Id
is a required field, the App
or site must store the id and use it for this.
tracking
Tracking information can be inserted into this request and will be shown to the user.
Example
Request:
{
"id": "1234567890qwertyuio1234567890",
"tracking_numbers" : ["1Z2345"],
"tracking_company" : "null",
"tracking_urls" : ["http://www.google.com/search?q=1Z2345"]
}
Response:
{}
Dashboard
Managing parcel / address requests
From this menu you can access each request ideally filter out some of this information so you can better manage it.
Features:
- filter out information from each request
- Search for specific
User
/Site
/App
- If
buffer time
is available be able to route the parcel to another address.
- Site "jcrew.com" requested your latest address.
* This happened on September 12th, 2015 at 10:01am.
* The request was auto-approved on September 12th, 2015 at 10:01am.
* The address selected was "Office", which at the time was set to:
* 1 Infinite Loop, Cupertino CA 95014
* Future requests from "jcrew.com" will remain auto-approved.
* Parcel is shipped, you have 2.3 hours left to change your address.
- User "thomasreggi" requested your address.
* This happened on September 9th, 2015 at 9:41pm.
* The request was approved on September 9th, 2015 at 3:31pm.
* The address selected was "Office", which at the time was set to:
* 1 Infinite Loop, Cupertino CA 95014
* Future requests from "thomasreggi" will be auto-approved.
* Parcel has been shipped, tracking code:
* http://www.dhl.com/search?q=1Z2345
- User "iSelliPhone" requested your address.
* This request was via ebay.com.
* This happened on September 8th, 2015 at 4:41pm.
* The request was approved on September 8th, 2015 at 4:41pm.
* The address selected was "Home", which at the time was set to:
* Rush Medical Group, 1221 North Washington Street, Livingston, AL 35470
* Future requests from "iSelliPhone" will not be auto-approved.
* Parcel has been shipped
Managing addresses
- "Office"
* 1 Infinite Loop, Cupertino CA 95014
- "Home"
* Rush Medical Group, 1221 North Washington Street, Livingston, AL 35470
- "Parents House"
* California Hospital Medical Center, 1401 South Grand Avenue, Los Angeles, CA 90015
If I edit one, I would see the following.
(- Edit address form shown)
(If there is available `Third-Party-App` (or `Site`) with `buffer time` this would show)
- This will send a reqeust to update your address across the following sites.
- Site "jcrew.com" parcel "Red pants" with buffer time of 2 hours 3 minutes
- Site "ebay.com" for user "iSelliPhone" parcel "iphone 19" with buffer time of 1 hour 29 minutes
>>> [update]
If I want to delete one I’d have to map the old address to another existing one.
- To delete "Office" please select another address to map these parcels to
* "Home"
* "Parents House" < Select
(If there is available `Third-Party-App` (or `Site`) with `buffer time` this would show)
- This will send a reqeust to update your address across the following sites.
- Site "jcrew.com" parcel "Red pants" with buffer time of 2 hours 3 minutes
- Site "ebay.com" for user "iSelliPhone" parcel "iphone 19" with buffer time of 1 hour 29 minutes
>>> [update]
Now all requests for “Office” will go to “Parents House”. Note that webhooks
aren’t sent to every authorized Third-Party-App
(and Site
) on delete and update. Webhooks
would only be sent to Third-Party-Apps
(and Sites
) that have webhooks
enabled and in which there is a buffer time
for a specific product.
Conclusion
I, like many this day and age, love the idea of modularizing everything, breaking things up into tiny manageable bits, rather then a full-fledged large system. Does the same go for your data and the things we do online? I for one don’t wanna put my address in every time I need to purchase something. Most browsers and lastpass have form-fillers where you can save your address and auto populate it, this doesn’t help with globally updating, but it works. Then there’s the awkward-ness of asking someone for their address. How do you do that if you have to ask 100 people for their address to send them a wedding invitation? That’s a simple weekend app waiting to happen.
Do we want all this data in one place? The last thing we want is someone getting hold of the addresses of a specific demographic of people, and doing something malicious. With this data all in one system, security is really important.
Why hasn’t this been done yet? Is it not all the way there? Is it not worth just managing addreses? Google, Facebook, Amazon could all easily implement this and it would be adopted fast.
Is there no money in the idea? I’m not sure about this one, yes you’re providing a vast network capable of supplying data to most of the web. With that data comes a lot of information.
Is there no interest in addresses? Because I think the contrary, especially with the prospect of drones flying around delivering packages for people. Imagine an in-flight re-route message to a drone carrying a package? That would be pretty cool.