From fd6f5b07932eaa1b34e50737e92c6dbe00610c18 Mon Sep 17 00:00:00 2001 From: "Matt (IPv4) Cowley" Date: Sun, 14 Jun 2020 19:47:29 +0100 Subject: [PATCH] Add docs (#177) * Create README.md * Create LICENSE * Create library-request.md * Create FUNDING.yml * Update LICENSE * Create CONTRIBUTING.md * Update CONTRIBUTING.md * Create update-request.md * Update update-request.md * Update README.md * Update CONTRIBUTING.md * Update CONTRIBUTING.md * Update library-request.md * Update CONTRIBUTING.md --- .github/FUNDING.yml | 3 + .github/ISSUE_TEMPLATE/library-request.md | 25 ++ .github/ISSUE_TEMPLATE/update-request.md | 23 ++ CONTRIBUTING.md | 282 ++++++++++++++++++++++ LICENSE | 22 ++ README.md | 128 ++++++++++ 6 files changed, 483 insertions(+) create mode 100644 .github/FUNDING.yml create mode 100644 .github/ISSUE_TEMPLATE/library-request.md create mode 100644 .github/ISSUE_TEMPLATE/update-request.md create mode 100644 CONTRIBUTING.md create mode 100644 LICENSE create mode 100644 README.md diff --git a/.github/FUNDING.yml b/.github/FUNDING.yml new file mode 100644 index 000000000..09b230f50 --- /dev/null +++ b/.github/FUNDING.yml @@ -0,0 +1,3 @@ +github: [MattIPv4] +open_collective: cdnjs +patreon: cdnjs diff --git a/.github/ISSUE_TEMPLATE/library-request.md b/.github/ISSUE_TEMPLATE/library-request.md new file mode 100644 index 000000000..32c4cd351 --- /dev/null +++ b/.github/ISSUE_TEMPLATE/library-request.md @@ -0,0 +1,25 @@ +--- +name: cdnjs Library Request +about: Request a new library to be added to cdnjs +title: "Add: xxx" +labels: "🏷 Library Request" +--- + + + + + + + + +**Library name:** xxx + +**Library license (include link):** xxx + +**Library source (NPM package or Git repo):** xxx diff --git a/.github/ISSUE_TEMPLATE/update-request.md b/.github/ISSUE_TEMPLATE/update-request.md new file mode 100644 index 000000000..c0598d849 --- /dev/null +++ b/.github/ISSUE_TEMPLATE/update-request.md @@ -0,0 +1,23 @@ +--- +name: cdnjs Update Request +about: Request a library with a bad or missing auto-update config to be updated +title: "Update: xxx" +labels: "📦 Update Request" +--- + + + + + + +**Library name:** xxx + +**Library JSON file link:** https://github.com/cdnjs/packages/blob/master/packages/x/xxx.json + +**Library source (NPM package or Git repo):** xxx + +**Files to include:** xxx diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md new file mode 100644 index 000000000..4c2e21bd0 --- /dev/null +++ b/CONTRIBUTING.md @@ -0,0 +1,282 @@ +

+ < cdnjs > +

+ +

The #1 free and open source CDN built to make life easier for developers.

+ +--- + +## Table of Contents + +* [Overview](#overview) +* [Policy, rules and guidelines](#policy-rules-and-guidelines) +* [Configuring library auto-update](#configuring-library-auto-update) + * [Auto-update overview](#auto-update-overview) + * [Auto-update config](#auto-update-config) +* [Creating a new library on cdnjs](#creating-a-new-library-on-cdnjs) + * [Fork the cdnjs repository](#fork-the-cdnjs-repository) + * [Make changes to your fork](#make-changes-to-your-fork) + * [Follow the existing library conventions](#follow-the-existing-library-conventions) + * [Making changes using your browser](#making-changes-using-your-browser) + * [Create a pull request](#create-a-pull-request) + * [Fixing any CI errors](#fixing-any-ci-errors) + * [Reviewing and merging](#reviewing-and-merging) + +## Overview + +[`cdnjs/packages`](http://github.com/cdnjs/packages) is the GitHub repository that contains the package JSON files that control all the libraries available on [cdnjs.cloudflare.com](http://cdnjs.cloudflare.com). + +cdnjs relies on user-submitted pull requests and automatic updating to populate and update libraries. With hundreds of contributors and thousands of commits, it is very important that new libraries are added to cdnjs using the correct procedure. + +Libraries that are actively maintained on [npm](https://www.npmjs.com/) or in a git repository with tagged releases can be configured to be automatically updated. + +Libraries that do not have a way to provide automatic updates are no longer supported in cdnjs as we are moving away from the need to maintainers to work with the repository that contains the full set of assets for cdnjs, which can be found in [`cdnjs/cdnjs`](http://github.com/cdnjs/cdnjs). + +## Policy, rules and guidelines + +cdnjs will host any production version of any JavaScript (JS) or Cascading Style Sheets (CSS) library, subject to appropriate licence permissions. + +cdnjs will host a specific subset of file types, which include JS, TS, CSS, SCSS, JSON, WASM, SWF, images, audio. +The full list of supported extensions can be requested through the cdnjs API: [api.cdnjs.com/whitelist](https://api.cdnjs.com/whitelist) + +New libraries are required to meet a basic popularity level to be hosted on cdnjs, to avoid wasting maintainer time. +For NPM packages, the base level for popularity is 800 downloads or more per month. +For GitHub repositories the requirement is normally 200 stars. +These requirements are at the discretion of cdnjs maintainers when adding libraries to cdnjs. + +## Configuring library auto-update + +### Auto-update overview + +Libraries that are actively maintained on [npm](https://www.npmjs.com/) or in a git repository with tagged releases can be configured to be automatically updated. A cdnjs auto-update script runs at scheduled intervals to check for new versions for cdnjs libraries on the relevant npm packages and git repositories as configured in each library's JSON file in this repository. + +Each cdnjs library has a JSON file. This file contains required and sometimes optional information about how the library works. Auto-update is configured in the library's JSON file alongside other library information. + +### Auto-update config + +- `autoupdate` is the top-level property that all autoupdate config options are contained within + - `source` should be either `npm` for a NPM-based auto-update package, or `git` to indicate git-based auto-updating + - `target` is the NPM package name, or the git url for the git repo to be used for updating + - `fileMap` contains an array of a single object that houses the information on what files cdnjs should copy + - `basePath` is the path in the git repository or NPM package that we will start exploring from + - `files` indicates the file(s) to copy and can be named (e.g. `lodash.min.js`) or [globs](https://do.co/glob-tool) (e.g. `*.js`). + +#### NPM-based auto-update example + +```js + "autoupdate": { + "source": "npm", + "target": "function-plot", + "fileMap": [ + { + "basePath": "dist", + "files": [ + "**/*" + ] + } + ] + } +``` + +The example parses the `function-plot` tarball, which has this structure: + +```text +|__dist +| |__function-plot.js +| |__utils +| | |__plotter.js +|__bower.json +|__index.js +|__site.js +|__package.json +|__README.md +|__lib +| |__... +|__node_modules +| |__... +|__sandbox +| |__... +``` + +The auto-update process will locate `dist` (specified in `basePath`) and copy `**/*` (specified in `files`) to cdnjs, removing the `dist` path. The resulting files in cdnjs will be: + +```text +|__ajax + |__libs + |__function-plot + |__x.y.z + |__function-plot.js + |__utils + |__plotter.js +``` + +...where `x.y.z` is the library version number, extracted from the `package.json` on npmjs. + +#### Git-based auto-update example + +```js + "autoupdate": { + "source": "git", + "target": "git://github.com/mikehostetler/amplify.git", + "fileMap": [ + { + "basePath": "lib", + "files": [ + "*" + ] + } + ] + } +``` + +The example parses the `mikehostetler/amplify` git repository, which has this structure: + +```text +|__demo +| |__... +|__docs +| |__... +|__external +| |__... +|__lib +| |__amplify-vsdoc.js +| |__amplify.core.js +| |__amplify.core.min.js +| |__amplify.js +| |__amplify.min.js +| |__amplify.request.js +| |__amplify.request.min.js +| |__amplify.store.js +| |__amplify.store.min.js +|__src +| |__... +|__test +| |__... +|__.gitignore +|__.jshintrc +|__GPL-LICENSE.txt +|__MIT-LICENSE.txt +|__bower.json +|__build.json +|__header.js +|__package.json +|__readme.md +|__test-jquery-versions.js +|__test-server.js +|__testswarm.json +``` + +The auto-update process will locate `lib` (specified in `basePath`) and copy `*` (specified in `files`) to cdnjs, removing the `lib` path. The resulting files in cdnjs will be: + +```text +|__ajax + |__libs + |__amplify + |__x.y.z + |__amplify-vsdoc.js + |__amplify.core.js + |__amplify.core.min.js + |__amplify.js + |__amplify.min.js + |__amplify.request.js + |__amplify.request.min.js + |__amplify.store.js + |__amplify.store.min.js +``` + +...where `x.y.z` is the library version number, based on the tagged release found in the git repository. + +## Creating a new library on cdnjs + +Changes to cdnjs happen with the following process: + +* Fork the cdnjs/packages repository on your GitHub account +* Make the required changes to the forked repository +* Raise a pull request with appropriate information +* Remove your forked repository (or branch if you plan to contribute again) after merge + +If these steps are followed, and everything works out, the process for adding a library is usually efficient and your library will go live soon afterwards. + +### Fork the cdnjs repository + +To fork the repository via your browser, visit this link: + +[https://github.com/cdnjs/packages/fork](https://github.com/cdnjs/packages/fork) + +Select your GitHub account for the destination and wait for the forking process to complete. +Assuming you saw no errors, you should be able to access your fork of cdnjs from your own GitHub account: + +https://github.com/your-github-username/packages + +Please make sure to fork cdnjs/packages, NOT cdnjs/cdnjs, as we only accept pull requests adding library JSON files to the cdnjs/packages repository. +cdnjs/cdnjs is now a robot-only repository and does not accept PRs. + +### Make changes to your fork + +Change are made to your fork of cdnjs. These changes contribute to a pull request, which may be merged after review by the cdnjs maintainers. + +Changes to your fork can be made in GitHub using your browser, or on your computer using a `git` command line or graphical user interface. + +* If you intend to make a _single, simple contribution_ to cdnjs you will likely find the browser experience more straightforward. + +* If you intend to make _numerous contributions_ to cdnjs, you may find a local clone of your forked repository a better route. + +### Follow the existing library conventions + +When adding a new library, please refer to existing libraries in the repository, preferring more recently added ones as a source of truth for the preferred structure for a library JSON file. + +### Making changes using your browser + +The GitHub website provides an easy-to-use interface to add libraries. + +In your fork of cdnjs, navigate to the `packages` directory of the repository: + +https://github.com/your-github-username/packages/tree/master/packages + +From here, you can then click the 'Create new file' button in the bar above the file list. + +You can then define the name for the library JSON file, as well as the directory. If you type in `a/a-library.json` as the name, GitHub will automatically create or move you to the `a` directory and then create the file named `a-library.json`. + +In the file contents you should include your basic library JSON data, based on the conventions set by existing libraries and following the above guidance on a valid auto-update configuration. + +### Create a pull request + +Once you have added your content to your file, you need to commit this and then create a PR. + +If you're using the GitHub browser interface, below the file content will be a set of inputs for controlling the commit. + +For the commit message, it should follow the standard following format so we can easily tracking libraries being added: + +`Add my-library-name w/ npm/git auto-update`, where `my-library-name` is replaced with the name of the library (should match the JSON file name), and `npm/git` is replaced with the choice matching the auto-update config in the JSON file. + +A commit description is not required, though if an issue requesting this library to be added exists, it may be useful to add `Resolves ` to the description so that GitHub tracks the PR in the issue. + +Please do NOT commit to the `master` branch, instead choose to create a new branch and again give it a sensible name, such as `add-my-library-name`. + +Finally, press the 'Propose new file' button to commit the new file and begin the process of creating a PR. + +On the PR creation page, please fill out the provided template with the requested information about the library and then press the button to create the pull request. +cdnjs maintainers will then review your pull request as soon as they can. + +### Fixing any CI errors + +To help with ensuring all library JSON files added to cdnjs are of a standard format and contain a valid auto-update configuration as well as other information about the library, we have an automated CI that will review your JSON file in the PR. + +If the CI finds any issues with your JSON file it will mark itself as failed and add an annotation to the JSON file in the pull request 'Files' tab with information about the issues it found. + +Please edit your JSON file either in the GitHub browser interface or via your local clone to resolve issues highlighted. +If you are unsure, please ask a cdnjs maintainer for help and we'll happily work with you to get your PR ready to merge. + +### Reviewing and merging + +As soon as your PR is passing the CI, and when a maintainer has time, they will manually review your pull request to ensure no issues have slipped past the automated CI. + +Once the maintainer is happy that your PR is ready to go, they will merge it. +You can then delete your fork (or branch if you plan to contribute again). + +Thank you for contributing to cdnjs! + +The cdnjs auto-updating logic runs roughly once per hour. +It will detect any newly added JSON files and populate the 10 most recent versions it can find into the cdnjs/cdnjs repository. + +Once this is done, the files should shortly after be available on the CDN, though it may take a while longer for them to appear on our website as this doesn't automatically update as often. diff --git a/LICENSE b/LICENSE new file mode 100644 index 000000000..f48516d93 --- /dev/null +++ b/LICENSE @@ -0,0 +1,22 @@ +The MIT License (MIT) + +Copyright (c) 2011-2020 cdnjs + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/README.md b/README.md new file mode 100644 index 000000000..da67ed034 --- /dev/null +++ b/README.md @@ -0,0 +1,128 @@ +

+ < cdnjs > +

+ +

The #1 free and open source CDN built to make life easier for developers.

+ +--- + +

+ + PRs Welcome + + + MIT License + + + Community + +

+ +

+ + GitHub Sponsors + + + Open Collective + + + Patreon + +

+ +--- + +## Table of Contents + +* [Introduction](#introduction) + * [Other Repositories](#other-repositories) +* [Support Us](#support-us) + * [Become a contributor](#become-a-contributor) + * [Donate and support us](#donate-and-support-us) +* [Contributing](#contributing) +* [latest version URL support](#latest-version-url-support) +* [API usage](#api-usage) +* [Contributors](#contributors) +* [Sponsors](#sponsors) +* [License](#license) + +## Introduction + +This is the "human" repository for cdnjs, where all JSON package files that control the libraries hosted on cdnjs are stored. For all assets hosted on cdnjs, please see the robot-only [`cdnjs/cdnjs`](https://github.com/cdnjs/cdnjs) repository. + +cdnjs is a free and open source project to organize and provide popular front-end web development resources to developers via a fast CDN infrastructure, powered by Cloudflare, without usage limitations and fees. We want to help individual library/framework developers distribute their projects, and web developers supercharge their websites! With our great free CDN service, developers can focus on their projects and website development. Developers no longer have to spend time worrying about how to set-up a CDN for projects or website assets. We hope to make web development easier, as well as your websites and the WWW faster and safer. + +Currently, cdnjs is the #1 free and open source CDN built to make life easier for developers and is rated No. 2 ([ref](https://w3techs.com/technologies/overview/content_delivery/all)) overall in web front-end CDN services and has great performance. We fully support [https](https://en.wikipedia.org/wiki/HTTPS), [SPDY](https://en.wikipedia.org/wiki/SPDY), [http/2.0](https://http2.github.io/), and [SRI](https://www.w3.org/TR/SRI/). These will **boost** and **secure** your website with zero configuration. *(Note: You'll still need to take care of server-side and application layer security issues. We make it better, but we can't help you too much if you implement a bad practice.)* + +### Other Repositories + +For the full set of library assets that are hosted on cdnjs, please take a look at the robot-only [`cdnjs/cdnjs`](https://github.com/cdnjs/cdnjs) repository. + +For our website, please refer to the [`cdnjs/new-website`](https://github.com/cdnjs/new-website) repository. + +For the cdnjs API, please refer to the [`cdnjs/api-server`](https://github.com/cdnjs/api-server) repository. + +For the full cdnjs branding and brand-related assets/guidelines, please see the [`cdnjs/brand`](https://github.com/cdnjs/brand) repository. + +For our monthly CDN stats and usage reports, check out the [`cdnjs/cf-stats`](https://github.com/cdnjs/cf-stats) repository. + +You can find all our repositories at [github.com/cdnjs](https://github.com/cdnjs/)! + +## Support Us! + +If you love 💖 what we are doing and would like to help us make the project better, please consider the following options: + +### Become a contributor + +Help us with the core of the service by adding and updating libraries based on requests in [issues](https://github.com/cdnjs/packages/issues) here, or by writing better [documentation](docs) on how the cdnjs project works. + +### Donate and support us + +#### GitHub Sponsors + +GitHub now has their very own system for supporting developers on their platform, GitHub Sponsors. Please consider donating to any of the people involved in keeping cdnjs operational to help support what we do: + + - [MattIPv4](https://github.com/sponsors/MattIPv4) + +#### Open Collective & Patreon + +We also have [Open Collective](https://opencollective.com/cdnjs) and [Patreon](https://www.patreon.com/cdnjs) pages set up so that you can donate there too if these are platforms you prefer. We really appreciate your help. 😊 + +## Contributing + +To contribute to cdnjs, please refer to our [CONTRIBUTING.md](https://github.com/cdnjs/packages/blob/master/CONTRIBUTING.md) document. This contains most of the information you might need to get involved either with adding a libarry to cdnjs or helping the project grow in other ways! If you need further information, please [create an issue](https://github.com/cdnjs/packages/issues/new). + +**Working on your first Pull Request?** Learn how from this *free* series: [An Introduction to Open Source ](https://www.digitalocean.com/community/tutorial_series/an-introduction-to-open-source) + +Want to chat with other users of the cdnjs service and some of the team before making your contribution? You can join our [community Discourse forum](https://cdnjs.discourse.group/) where you can post questions and interact with us! + +## Latest version URL support + +Please note that cdnjs does not provide a `latest` version URL for a library, due to the following considerations: + +1. Your website might break if there are any compatibility issues or bugs coming from upstream. It's not a good idea to use it in the production environment. Both jQuery CDN and Google CDN don't provide this feature. +2. The `latest` URL feature also has cache and performance issues. This conflicts with what we are trying to do - make your website load as fast as possible. +3. Security issues have become more and more important nowadays. For example, Great Cannon attacked GitHub via malicious JavaScript ([ref1](https://citizenlab.org/2015/04/chinas-great-cannon/), [ref2](https://arstechnica.com/security/2015/04/meet-great-cannon-the-man-in-the-middle-weapon-china-used-on-github/)) during April 2015. One of the techniques to prevent this kind of attack is [Subresource Integrity (SRI)](https://developer.mozilla.org/en-US/docs/Web/Security/Subresource_Integrity). We have been supporting this feature for a long time. The `latest` URL feature, however, totally conflicts with the SRI technique. + +## API usage + +See the [API page](https://cdnjs.com/api) on our website for more information on working with the cdnjs.com API. + +## Contributors + +Please see the GitHub provided contributors page: [github.com/cdnjs/packages/graphs/contributors](https://github.com/cdnjs/packages/graphs/contributors). + +## Sponsors + +cdnjs wouldn't be the success that it is today without our sponsors' kind support. These companies currently support cdnjs: + +* [Cloudflare](https://www.cloudflare.com/?utm_source=cdnjs&utm_medium=link&utm_campaign=cdnjs) +* [DigitalOcean](https://www.digitalocean.com/?utm_source=cdnjs&utm_medium=link&utm_campaign=cdnjs) +* [Algolia](https://www.algolia.com/?utm_source=cdnjs&utm_medium=link&utm_campaign=cdnjs) +* [Heroku](https://www.heroku.com/?utm_source=cdnjs&utm_medium=link&utm_campaign=cdnjs) + +If you are interested in becoming a sponsor, please feel free to contact us! + +## License + +Each library is released under its own license. This cdnjs repository is published under [MIT license](LICENSE).