How to Add Referral Links to Your Signup Page with Alphaseek

pancy
4 min readOct 16, 2019
Your app’s early adopters or the Alphas are the most important group of users to give incentives to.

Have you ever seen one of those links you get after signing up with Airbnb or riding with Uber that you can share and get credits or a VIP invitation to use a product? They’re part of what is known as a referral campaign or invitation program, and they may look like this to a John Doe:

https://yourawesome.app/invite/johndoe

When John shares his unique link, for every user who converts (or signs up) through clicking it, John gets some kind of reward. Most often, the user he invites also gets it.

The main point of referrals is to create growth for your product. Some app uses an invitation-only tactic to drum up its VIP-ness (only those invited by current users will get access). The early Product Hunt and Superhuman used this tactic. Others have used it to gain more users and vendors. Uber uses a referral program to acquire both riders and drivers alike.

Uber referral links allow friends to invite and gift each other with ride credits.

Since it is natural for people to trust an app or product a friend refers to, it is one of the most effective and organic ways to get traction.

One less talked about but arguably very important benefit of a referral program is finding early adopters or lighthouse customers, a unique group of people who are vastly different from mainstream adopters who will play a central role in a product’s early growth (or its demise). We call them the Alphas.

Alphaseek.io

There are currently a few options to add the referral campaign workflow into your current signup, but they are infamously geared toward marketing and often scares developers and early-stage founders away. Alphaseek.io is the most developer-friendly, customizable cloud referral engine. It provides easy-to-use API endpoints to generate referral links and track users’ referral scores as users start inviting others onboard. It’s currently beta-launching and accepting signups HERE.

Alphaseek does exactly these:

  • Create referral links for your users to share
  • Track how users refer/invite friends to join/subscribe to your product.
  • Keep track of a generic scores system that’s easy to integrate to your own reward system

Getting started

Once you have retrieved your access token for your product from Alphaseek.io, you can start making calls to the API server.

Here is how you can send a request to our API in JavaScript:

Creating a referring link

// For example only, don't use this.
const accessToken = '1e6acc57-95f4-4928-997a-32f0571cc933'
const productId = 'awesomeapp-1234'

async function getAlphaseekUrlFor(userEmail) {
const res = await fetch(`https://api.alphaseek.io/v0/${productId}/users`, {
method: 'POST',
headers: new Headers({
'Authorization': 'Bearer ' + accessToken,
'Content-Type': 'application/json'
}),
body: JSON.stringify({
// Your user's email. This is required.
email: userEmail,
// Where you want the referral link to bring the referred user to.
redirectTo: 'https://yourawesomeapp.com/signup',
}),
});

res.then((res) {
return res.json();
}).catch((err) {
log.error(err);
});
}

If you’re using React, then you’ll likely place this function call in a method of the signup form component:

class SignupForm extends React.Component {

state = {
email: '',
};

onFormSubmit() {

// Save your user to your own database.

// Call to get your user his/her referral link when
// the signup form has been submitted.
const data = getAlphaseekUrlfor(this.state.email);

// You get a url like 'https://alphaseek.io/invite/32e0542'
window.alert(`Thank you for signing up, here is your link to invite friends: ${data.url}`);
}

handleEmail = (e: any) => {
this.setState({
email: e.target.value,
});
}

render() {
return (
<div>
<form action="" onSubmit={this.onFormSubmit}>
<input
type="email"
placeholder="Your email"
onChange={this.handleEmail}
value={this.state.email}
/>
</form>
</div>
);
}
}

Getting user data

Of course we want to be able to query a user to see his/her referral data and how he/she is faring. Most alphas don't stop at signup. They advocate by sharing and sharing relentlessly. It is likely that you want to reward these users with something like a free coupon or free trial period. Airtable offers $10 worth of credits for every user its alphas successfully convert.

To get an alpha’s data:

async function getUser(userEmail) {
const res = await fetch(`https://api.alphaseek.io/v0/${productId}/users/${userEmail}`, {
method: 'GET',
headers: new Headers({
'Authorization': 'Bearer ' + accessToken,
'Content-Type': 'application/json'
}),
});

res.then((res) {
return res.json();
}).catch((err) {
log.error(err);
});
}

and here is the JSON response you will expect:

{
"data": {
"user": {
"email": "janedoe@gmail.com",
"referredBy": "mikhaela@gmail.com",
"referredTo": ["johndoe@gmail.com", "elonmusk@space.x"],
"score": 2
}
}
}

You can also request users sorted based on points:

async function getFirstTenUsers() {
const res = await fetch(`https://api.alphaseek.io/v0/${productId}/users?page_size=10&desc=score`, {
method: 'GET',
headers: new Headers({
'Authorization': 'Bearer ' + accessToken,
'Content-Type': 'application/json'
}),
});
res.then((res) {
return res.json();
}).catch((err) {
log.error(err);
});
}

Announce your invitation campaign

This is where the fun begins as you start thinking about your offering strategy to provide incentives to alphas to cross the friction gap to sign up and use your product. It could be secretive invite-only beta access if you have a VIP product or some credit offering if you have a social product.

As a developer, it is sometimes tempting to write code for everything just because you can, but it is important to resist that urge and save your time to work on what's more important--your app.

You are building something to ship super fast with limited resources and help, every minute counts in building and iterating on what's core to your product. So save time writing referral logic and reinventing the wheels!

--

--

pancy

I’m interested in Web3 and machine learning, and helping ambitious people. I like programming in Ocaml and Rust. I angel invest sometimes.