|
4 | 4 |
|
5 | 5 | ## About
|
6 | 6 |
|
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