# cnpmjs.org **Repository Path**: fullstack_admin/cnpmjs.org ## Basic Information - **Project Name**: cnpmjs.org - **Description**: No description available - **Primary Language**: Unknown - **License**: MIT - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-06-24 - **Last Updated**: 2024-06-28 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README cnpmjs.org ======= [![npm version][npm-image]][npm-url] [![build status][travis-image]][travis-url] [![Test coverage][codecov-image]][codecov-url] [![Known Vulnerabilities][snyk-image]][snyk-url] [![npm download][download-image]][download-url] [npm-image]: http://cnpmjs.org/badge/v/cnpmjs.org.svg?style=flat-square [npm-url]: http://cnpmjs.org/package/cnpmjs.org [travis-image]: https://img.shields.io/travis/cnpm/cnpmjs.org.svg?style=flat-square [travis-url]: https://travis-ci.org/cnpm/cnpmjs.org [codecov-image]: https://codecov.io/gh/cnpm/cnpmjs.org/branch/master/graph/badge.svg [codecov-url]: https://codecov.io/gh/cnpm/cnpmjs.org [snyk-image]: https://snyk.io/test/npm/cnpmjs.org/badge.svg?style=flat-square [snyk-url]: https://snyk.io/test/npm/cnpmjs.org [download-image]: https://img.shields.io/npm/dm/cnpmjs.org.svg?style=flat-square [download-url]: https://npmjs.org/package/cnpmjs.org ![logo](https://raw.github.com/cnpm/cnpmjs.org/master/logo.png) ## Description Private npm registry and web for Enterprise, base on [koa](http://koajs.com/), MySQL and [Simple Store Service](https://github.com/cnpm/cnpmjs.org/wiki/NFS-Guide). Our goal is to provide a low cost maintenance, easy to use, and easy to scale solution for private npm. ## What can you do with `cnpmjs.org`? * Build a private npm for your own enterprise. ([alibaba](http://www.alibaba.com/) is using `cnpmjs.org` now) * Build a npm mirror. (we use it to build a mirror in China: [https://npm.taobao.org/](https://npm.taobao.org/)) ## Features * **Support "scoped" packages**: [npm/npm#5239](https://github.com/npm/npm/issues/5239) * **Support [CORS](http://en.wikipedia.org/wiki/Cross-origin_resource_sharing)** * **Simple to deploy**: only need `mysql` and a [simple store system](https://github.com/cnpm/cnpmjs.org/wiki/NFS-Guide). * **Low cost and easy maintenance**: `package.json` info can store in MySQL, MariaDB, SQLite or PostgreSQL. tarball(tgz file) can store in Amazon S3 or other object storage service. * **Automatic synchronization**: automatically sync from any registry specified. support two sync modes: - Sync all modules from upstream - Only sync the modules after first access. * **Manual synchronization**: automatic synchronization may has little delay. you can sync manually on web page. * **Customized client**: we provide a client [cnpm](https://github.com/cnpm/cnpm) to extend `npm` with more features(`sync` command, [gzip](https://github.com/npm/npm-registry-client/pull/40) support). And it is easy to wrap for your own registry which build with `cnpmjs.org`. * **Compatible with npm client**: you can use the official npm client with `cnpmjs.org`. you only need to change the registry in client config. * **Support http_proxy**: if you're behind a firewall, you can provide a http proxy for cnpmjs.org. ## Docs * [How to deploy](https://github.com/cnpm/cnpmjs.org/wiki/Deploy) * cnpm client: [cnpm](https://github.com/cnpm/cnpm), `npm install -g cnpm` * [Sync packages through `http_proxy`](https://github.com/cnpm/cnpmjs.org/wiki/Sync-packages-through-http_proxy) * [Migrating from 1.x to 2.x](https://github.com/cnpm/cnpmjs.org/wiki/Migrating-from-1.x-to-2.x) * [New features in 2.x](https://github.com/cnpm/cnpmjs.org/wiki/New-features-in-2.x). * [wiki](https://github.com/cnpm/cnpmjs.org/wiki) ## Develop on your local machine ### Dependencies * [node](http://nodejs.org) >= 8.0.0 * Databases: only required one type * [sqlite3](https://npm.taobao.org/package/sqlite3) >= 3.0.2, we use `sqlite3` by default * [MySQL](http://dev.mysql.com/downloads/) >= 5.6.16, include `mysqld` and `mysql cli`. I test on `mysql@5.6.16`. * MariaDB * PostgreSQL ### Clone code and run test ```bash # clone from git $ git clone https://github.com/cnpm/cnpmjs.org.git # install dependencies $ make install # test $ make test # coverage $ make test-cov # update dependencies $ make autod # start server with development mode $ make dev ``` ### Dockerized cnpmjs.org Installation Guide Cnpmjs.org shipped with a simple but pragmatic Docker Compose configuration.With the configuration, you can set up a MySQL backend cnpmjs.org instance by executing just one command on Docker installed environment. #### Preparation * [Install Docker](https://www.docker.com/community-edition) * [Install Docker Compose](https://docs.docker.com/compose/install/) (Docker for Mac, Docker for Windows include Docker Compose, so most Mac and Windows users do not need to install Docker Compose separately) * (Optional) Speed up Docker images downloading by setting up [Docker images download accelerator](https://yq.aliyun.com/articles/29941) #### Dockerized cnpmjs.org control command Make sure your current working directory is the root of this GitHub repository. ##### Run dockerized cnpmjs.org ```bash $docker-compose up ``` This command will build a Docker image using the current code of repository. Then set up a dockerized MySQL instance with data initialized. After Docker container running, you can access your cnpmjs.org web portal at http://127.0.0.1:7002 and npm register at http://127.0.0.1:7001. #### Run cnpmjs.org in the backend ```bash $docker-compose up -d ``` #### Rebuild cnpmjs.org Docker image ```bash $docker-compose build ``` #### Remove current dockerized cnpmjs.org instance The current configuration set 2 named Docker Volume for your persistent data. If you haven't change the repository directory name, them will be "cnpmjsorg_cnpm-files-volume" & "cnpmjsorg_cnpm-db-volume". Be Careful, the following commands will remove them. ```bash $docker-compose rm $docker volume rm cnpmjsorg_cnpm-files-volume $docker volume rm cnpmjsorg_cnpm-db-volume ``` You can get more information about your data volumes using the below commands: ```bash $docker volume ls // list all of your Docker volume $docker volume inspect cnpmjsorg_cnpm-files-volume $docker volume inspect cnpmjsorg_cnpm-db-volume ``` ## How to contribute * Clone the project * Checkout a new branch * Add new features or fix bugs in the new branch * Make a pull request and we will review it ASAP Tips: make sure your code is following the [node-style-guide](https://github.com/felixge/node-style-guide). ## Top contributors [![0](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/images/0)](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/links/0) [![1](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/images/1)](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/links/1) [![2](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/images/2)](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/links/2) [![3](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/images/3)](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/links/3) [![4](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/images/4)](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/links/4) [![5](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/images/5)](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/links/5) [![6](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/images/6)](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/links/6) [![7](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/images/7)](https://sourcerer.io/fame/fengmk2/cnpm/cnpmjs.org/links/7) ## Sponsors - [![阿里云](https://static.aliyun.com/images/www-summerwind/logo.gif)](http://click.aliyun.com/m/4288/) (2016.2 - now) ## License [MIT](LICENSE.txt)