Skip to content

Commit a5c437b

Browse files
committed
README.md: Update to add new setup instructions
The commit adds some more information about the repository, i.e. what are its features, from where does it fetch data, and how to setup the community forms and the OAuth. Closes coala#275
1 parent a09fd30 commit a5c437b

File tree

1 file changed

+95
-24
lines changed

1 file changed

+95
-24
lines changed

README.md

+95-24
Original file line numberDiff line numberDiff line change
@@ -4,27 +4,98 @@
44

55
## About
66

7-
* This repository is a static django website;
8-
* It uses the [GCI private API](https://developers.google.com/open-source/gci/resources/downloads/TaskAPISpec.pdf)
9-
* __Attention:__ This repository only re-publishes publicly available information
10-
* Uses IGitt, supporting both GitHub & GitLab
11-
12-
## Deploy Netlify on your fork :
13-
14-
Following are the steps to deploy netlify on your forked ``community`` repository :
15-
16-
- Signup on [netlify](https://app.netlify.com/).
17-
- Click on **New site from Git**.
18-
- Choose **Git provider (Github) >** Choose a repository **< username >/community**.
19-
- Branch to deploy **master**.
20-
- Basic build settings :
21-
* Set Build command to **.ci/build.sh**.
22-
* Set Publish directory to **public**.
23-
* Click on **Show advanced >** **New variable** to add the `environment variables`.
24-
25-
After that to set the ``environment variables`` :
26-
27-
- Put **GH_TOKEN** in `Key` column and your generated `GitHub Access Token`
28-
in `Value` column.
29-
- Similarly add other `variables` like **OH_TOKEN, GL_TOKEN** if needed.
30-
- Click on **Deploy Site** to deploy the site.
7+
The repository generates an *open-source community* static website, using the
8+
publicly available information about contributors and the organization. The
9+
information used is fetched from the **Webservices API**.
10+
11+
**Features:**
12+
1. Creates a *static django website* using *django_distill*.
13+
2. Community data is being fetched from an API, named [Webservices](https://gitlab.com/coala/landing). # Ignore KeywordBear
14+
To use it, just **fork** the repository, and Change the organization
15+
name in *settings.py* file.
16+
3. Uses the [GCI private API](https://developers.google.com/open-source/gci/resources/downloads/TaskAPISpec.pdf)
17+
to fetch information about students who participated in Google Code-In
18+
with the organization.
19+
4. Uses IGitt, supporting both GitHub & GitLab
20+
5. __Attention:__ This repository only re-publishes publicly available
21+
information.
22+
23+
## Environment variables used
24+
25+
1. **``GH_TOKEN``**: A *GitHub Personal Access Token*, which can be generated
26+
from your *account settings* under the **Developer Settings**.
27+
2. **``GL_TOKEN``**: A *GitLab Personal Access Token*, which can be generated
28+
from your *account settings* under the tab **Access Tokens**.
29+
3. **``OH_TOKEN``**: An *OpenHub Personal Access Token*, which can be
30+
generated from your *account settings*.
31+
32+
## Netlify based Community Forms
33+
1. **``OSFORMS_NETLIFY_FORM_NAME``**: A form which receives submission
34+
from community *developers*, if they want to share any open-source form
35+
like a Google Doc which is to be shared with all developers or within
36+
the community.
37+
2. **``CALENDAR_NETLIFY_FORM_NAME``**: A form which receives submission
38+
from community *developers*, if they want to add an upcoming event like
39+
project related events, software releases, survey result announcements
40+
etc.
41+
3. **``MENTOR_FORM_NAME``**: A form which receives submission from
42+
community *developers*, if they want to participate as an
43+
organization mentor, who will be available to mentor projects in the
44+
summer/winter programs like Google Summer of Code, Google Code-In etc.
45+
4. **``GSOC_STUDENT_FORM_NAME``**: A form which receives submission from
46+
community *newcomers & developers*, if they had participated with the
47+
organization in Google Summer of Code and completed the proposed
48+
project.
49+
5. **``ISSUES_ASSIGN_REQUEST_FORM_NAME``**: Any contributor, who wishes to work
50+
on an issue can fill-up this form and request to get assigned on that
51+
issue.
52+
6. **``NEWCOMER_PROMOTION_REQUEST_FORM_NAME``**: Any newcomer who wishes to get
53+
the **Developer Role** in th oragnization, can fill-up the form and request
54+
the access.
55+
7. **``FEEDBACK_FORM_NAME``**: The name is self-understandable :innocent:
56+
57+
__ATTENTION DEVs:__ To use the forms, set the above mentioned environment
58+
variables. All the forms, have respective **cron-jobs** defined in
59+
**Webservices**, which processes the contributor request and check if the
60+
request is valid or not. If not valid request, the user will be sent an
61+
email informing about the validation errors.
62+
63+
## Deploy your fork on Netlify:
64+
65+
Following are the steps to deploy your forked *community* repository on Netlify:
66+
67+
1. Signup on [netlify](https://app.netlify.com/).
68+
2. Click on **New site from Git**.
69+
3. Choose the **Git provider** as *Github* and Choose your forked *community*
70+
repository, named **< username>/community**.
71+
4. Further, choose **master** branch to deploy and set the following *Basic*
72+
*build settings*:
73+
* Set Build command to **.ci/build.sh**.
74+
* Set Publish directory to **public**.
75+
* Click on **Show advanced** and add a **New variable** by choosing the
76+
option. After that, add the **required Environment variables** according
77+
to your need.
78+
* **Note:** ``GH_TOKEN`` is a required environment variable, and you must
79+
set that before your deploy the site.
80+
5. Click on **Deploy Site** to deploy the site.
81+
82+
## Want to add Netlify OAuth (GitHub and GitLab)?
83+
84+
The repository has already integrated Netlify OAuth, all is to be done is
85+
to register new GitHub and GitLab OAuth apps on your account. So, that the
86+
OAuth is set to working on your fork.
87+
88+
For registering a new GitHub OAuth App, you can follow-up the [Netlify OAuth
89+
Provider Documentation](https://www.netlify.com/docs/authentication-providers/).
90+
91+
For registering a new GitLab OAuth App,
92+
1. Go to your account Settings, and click *Applications* under
93+
the Settings (or use this [shortcut](https://gitlab.com/profile/applications)).
94+
2. After page opens, you will see a form for registering a new OAuth
95+
application.
96+
3. Enter the *name of the Application*.
97+
4. For the Redirect URI, enter ``https://api.netlify.com/auth/done``.
98+
5. And, the last one is the most important field, which is the **Scopes**. Set
99+
it according to your needs. This repository uses ***api*** scope. If you
100+
choose a different scope other than the ***api***, make sure to change it in
101+
the `static/js/main.js` JavaScript file.

0 commit comments

Comments
 (0)