Our goal is to have a transparent and traceable method for projects that want to put themselves on the Digital Life Collective map.
To make this easy for projects and to give you some visibility into the process we have adopted a simple github based approach that follows these steps:
- Clone and create a simple JSON file for the project
- Edit the file with your project details
- Submit a pull request with your project JSON file
- Members will review the project and approve the pull request
- The map "build" will pick up the new information and you are on the map!
There is no other database or repository for the data and it remains source controled in github with version history for members and interested members to see. We are using the MIT license which means others can use this data.
In the review process we will do the following:
- Check out the the project and the goals and make sure we have the right information
- Verify the information is correct
- Make sure it is aligned with the collective puprpose
- Add additional fields including date, status, and tags to make it easier to filter and find.
If you are a github whiz then all you need to do is:
- Create a file using the JSON above or the digitallifecollective.json file as your template
- Name it logically [projectName].json
- Commit and push your file into /submissions
Note: You will need to create a branch and a pull request. - Bob's you uncle!
If you need a little more detail follow these steps:
-
Download this file digitallifecollective.json
-
Open it in a text editor (not a word processor they tend to gum up the formatting)
-
Edit the contents of the file by replacing the template content with your own. Hint: the quotes and commas matter so be aware of what you edit.
-
If you need help with the formatting you can always use a handy online format checker like this one. Your file will be reviewed and formatted as part of the pull request review.
-
Now login to your github.com account and navigate to https://github.com/DigitalLifeCollective/projects/submissions
-
Click the Upload Files button and follow the instructions. Try to name things logically when you fill in the forms.
-
When you have uploaded your JSON file the next page will create a Pull Request. Again fill in the forms and submit.
-
Bob's your uncle!
This is a simple JSON strucuture that captures the information that will be used to generate the project map and other tools we create to curate the projects aligned with the Digital Life Collective.
Instructions for creating your file. Let's break down the fields:
The 'project' field is the label that will show up on the map. Try to keep this short so it displays well.
The 'website' field is the link that will be on the map to the project. Please use the full URL.
The 'description' field is shown in the side bar on the map and can include markdown embedded content such as images or video links. This can be a couple of paragraphs but should be concise.
The 'logoURL' needs to be a direct link to the image with no click through or it will not display on the map. A 400 x 400 px size works well.
{
"project":"Digital Life Collective",
"website":"https://diglife.com",
"description":"The Digital Life Collective develops, funds and supports technologies created with only the individual's needs in mind.",
"logoURL":"https://diglife.com/images/logo.png",
"twitter":"@digitallifecollective",
"email":"[email protected]",
The Digital Life Collective exists to nurture Tech We Trust. Projects should be aligned with one or more of the following purposes and should have no conflicting goals or technology:
- trust
- equality
- privacy
- decentralization
Please limit the values here to one or more from this list.
"purpose":[
"privacy",
"trust"
],
TODO: @sheldrake we need some values and definitions. We were not sure what the "stack" field in the spreadsheet meant. Should this be aligned with the decentalized stack image? We should put it in the readme or a link to it.
The 'type' field refers to the function that that your project fullfills in the larger eccosystem. The options for this filed should be:
- social
- legal
- concensus
- semantics
Please limit the values here to one or more from this list.
"type":[
"social media",
"publishing"
],
Please list any formal affiliations your project has with organizations.
"affliation":[
"MIT",
"Linux Foundation"
],
Please specify the license types that apply to your project. If there is more than one you can have mulitple values.
TODO: @sheldrake should this be a specific list or can people put any license type.
"license":[
"MIT",
"Apache 2"
],
Please provide links to the repositories and the details about the code that is in them.
"repoURL":"https://github.com/orgs/DigitalLifeCollective",
"techDetails":{
"languages":[
"python",
"java"
],
"documentationLanguages":[
"english",
"german"
]
}
}
What other elements or projects does your project require or depend on? For example, Ethereum, GNU Social, or Bitcoin.
"requires":[
"Ethereum",
"GNU Social"
],
Have we missed any critical information? You can include up to 5 'tags' that describe your project.
"tags":[
"collective",
"co-op"
],