2015-10-03 04:04:31 +08:00
# Contributing to N1 Core
Thank you for contributing!!
N1 core is the foundation our community uses to build email extensions with the
modern web.
2015-10-03 04:24:39 +08:00
You currently need an early invitation code to get setup on N1. Sign up
2015-10-03 04:04:31 +08:00
[here ](https://invite.nylas.com ) to request one. Drop us a line saying you'd
2015-10-03 04:24:39 +08:00
like to contribute to N1 core and we'll get you set up immediately.
2015-10-03 04:04:31 +08:00
# Getting Started
2015-10-03 09:48:34 +08:00
Once you have an invitation code:
2015-10-03 04:04:31 +08:00
git clone https://github.com/nylas/N1.git
cd N1
script/bootstrap
2015-10-05 20:08:53 +08:00
Read the [getting started guides ](http://nylas.com/N1/docs/ ).
2015-10-03 09:48:34 +08:00
2015-10-03 04:04:31 +08:00
# Running N1 Core
./N1.sh --dev
2015-10-03 04:24:39 +08:00
Once the app boots, you'll be prompted to enter your early invitation code and
2015-10-03 04:04:31 +08:00
email credentials.
2015-10-03 04:24:39 +08:00
Our early invitation codes are designed control access to our production mail sync
2015-10-03 04:04:31 +08:00
engine while we roll out N1. However, the sync engine is [open
source](https://github.com/nylas/sync-engine) and you can set it up yourself to
begin using N1 immediately. Follow instructions on the [sync
engine](https://github.com/nylas/sync-engine) repository.
# Testing N1 Core
./N1.sh --test
This will run the full suite of automated unit tests. We use [Jasmine 1.3 ](http://jasmine.github.io/1.3/introduction.html ).
It runs all tests inside of the `/spec` folder and all tests inside of
`/internal_packages/**/spec`
2015-10-06 02:24:14 +08:00
2015-10-08 08:18:41 +08:00
# Pull requests
We require all authors sign our [Contributor License
Agreement](https://www.nylas.com/cla.html) before pull requests (even
minor ones) can be accepted. (It's similar to other projects, like NodeJS
Meteor, or React). I'm really sorry, but Legal made us do it.
## Commit Format
We decided to not impose super strict commit guidelines on the community.
We're trusting you to be thoughtful, responsible, committers.
We do have a few heuristics:
- Keep commits fairly isolated. Don't jam lots of different functionality
in 1 squashed commit. `git bisect` and `git cherry-pick` should still be
reasonable things to do.
- Keep commits fairly significant. DO `squash` all those little file
changes and "fixmes". Don't make it difficult to browse our history.
Play the balance between this idea and the last point. If a commit
doesn't deserve your time to write a long thoughtful message about, then
squash it.
- Be hyper-descriptive in your commit messages. I care less about what
you did (I can read the code), **I want to know WHY you did it** . Put
that in the commit body (not the subject). Itemize the major semantic
changes that happened.
- Read "[How to Write a Git Commit Message](http://chris.beams.io/posts/git-commit/)" if you haven't already (but don't be too prescriptivist about it!)
2015-10-07 05:31:00 +08:00
# Building
Once you've checked out N1 and run `script/bootstrap` , you can create a packaged
version of the application by running `script/build` . Note that the builds
available at [https://nylas.com/N1 ](https://nylas.com/N1 ) include licensed
fonts, sounds, and other improvements. If you're just looking to run N1, you
should download it there!
2015-10-06 02:24:14 +08:00
# Running Against Open Source Sync Engine
N1 needs to fetch mail from a running instance of the [Nylas Sync
Engine](https://github.com/nylas/sync-engine). The Sync Engine is what
2015-10-08 04:54:02 +08:00
abstracts away IMAP, POP, and SMTP to serve your email on any provider
2015-10-06 02:24:14 +08:00
through a modern, RESTful API.
By default the N1 source points to our hosted version of the sync-engine;
however, the Sync Engine is open source and you can run it yourself.
1. Go to https://github.com/nylas/sync-engine for instructions on how to
get the Sync Engine running on a Vagrant virtual machine.
1. Open up `src/flux/nylas-api.coffee` and change the `@APIRoot` variable
to point to your Sync Engine instance.
1. After you've linked accounts to the Sync Engine, populate your
2015-10-07 10:05:02 +08:00
`~/.nylas/config.cson` as follows. You can get a list of connected accounts
and their attributes from the /accounts endpoint (ex. `http://localhost:5555/accounts` ):
2015-10-06 02:24:14 +08:00
2015-10-06 02:26:33 +08:00
"*":
nylas:
accounts: [
{
server_id: "{ACCOUNT_ID_1}"
object: "account"
account_id: "{ACCOUNT_ID_1}"
name: "{YOUR NAME}"
provider: "{PROVIDER_NAME}"
email_address: "{YOUR_EMAIL_ADDRESS}"
organization_unit: "{folder or label}"
id: "{ACCOUNT_ID_1}"
}
{
server_id: "{ACCOUNT_ID_2}"
object: "account"
account_id: "{ACCOUNT_ID_2}"
name: "{YOUR_NAME}"
provider: "{PROVIDER_NAME}"
email_address: "{YOUR_EMAIL_ADDRESS}"
organization_unit: "{folder or label}"
id: "{ACCOUNT_ID_2}"
}
]
accountTokens:
{ACCOUNT_ID_1}: "{ACCOUNT_ID_1}"
{ACCOUNT_ID_2}: "{ACCOUNT_ID_2}"
2015-10-08 08:18:41 +08:00
Note: `{ACCOUNT_ID_1}` refers to the database ID of the `Account` object
you create when setting up the Sync Engine. The JSON above should match
fairly closely with the Sync Engine `Account` object.