{"id":13753658,"url":"https://github.com/evenchange4/micro-medium-api","last_synced_at":"2025-03-16T08:32:53.092Z","repository":{"id":57296457,"uuid":"99572098","full_name":"evenchange4/micro-medium-api","owner":"evenchange4","description":"Microservice for fetching the latest posts of Medium with GraphQL.","archived":false,"fork":false,"pushed_at":"2018-01-15T01:34:59.000Z","size":225,"stargazers_count":140,"open_issues_count":18,"forks_count":18,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-03-13T10:39:43.288Z","etag":null,"topics":["apollo-server","docker","graphql","graphql-tools","medium","micro","microservice","now","pkg","zeit"],"latest_commit_sha":null,"homepage":"https://micro-medium-api.now.sh/graphiql","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/evenchange4.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2017-08-07T11:43:41.000Z","updated_at":"2024-09-26T02:44:27.000Z","dependencies_parsed_at":"2022-09-07T03:21:00.160Z","dependency_job_id":null,"html_url":"https://github.com/evenchange4/micro-medium-api","commit_stats":null,"previous_names":[],"tags_count":11,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/evenchange4%2Fmicro-medium-api","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/evenchange4%2Fmicro-medium-api/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/evenchange4%2Fmicro-medium-api/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/evenchange4%2Fmicro-medium-api/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/evenchange4","download_url":"https://codeload.github.com/evenchange4/micro-medium-api/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":243809865,"owners_count":20351403,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["apollo-server","docker","graphql","graphql-tools","medium","micro","microservice","now","pkg","zeit"],"created_at":"2024-08-03T09:01:26.753Z","updated_at":"2025-03-16T08:32:52.381Z","avatar_url":"https://github.com/evenchange4.png","language":"JavaScript","readme":"# Micro-medium-api\n\u003e Microservice for fetching the latest posts of Medium with GraphQL.\n\u003e\n\u003e Further reading: [\\[中文\\] Microservice 產品交付 - Dockerize 與 Zeit JavaScript 跨平台解決方案](https://medium.com/@evenchange4/microservice-%E7%94%A2%E5%93%81%E4%BA%A4%E4%BB%98-9f2954c7167d)\n\n[![Travis][travis-badge]][travis]\n[![Codecov Status][codecov-badge]][codecov]\n[![Github Tag][githubTag-badge]][githubTag]\n[![node][node]]()\n\n[![Dependency Status][dependency-badge]][dependency]\n[![devDependency Status][devDependency-badge]][devDependency]\n[![peerDependency Status][peerDependency-badge]][peerDependency]\n[![Greenkeeper badge][greenkeeper-badge]][greenkeeper]\n[![prettier][prettier-badge]][prettier]\n[![license][license-badge]][license]\n\n## Feature\n\n- Use GraphQL.\n- Dataloader for per-request memory cache.\n- Rate-limiting 1 requests per sec.\n\n## How To Use\n\n### a. Deploy to Now.sh\n\n\u003e One click deploys to △ now\n\n[![Deploy to now](https://deploy.now.sh/static/button.svg)](https://deploy.now.sh/?repo=https://github.com/evenchange4/micro-medium-api\u0026env=ORIGIN)\n\n### b. Binary executable\n\nDownload from GitHub [latest release](https://github.com/evenchange4/micro-medium-api/releases/latest).\n\n```\n$ ORIGIN=$YOUR_DOMAIN \\\n  ./micro-medium-api-macos --port $PORT\n```\n\n\u003e Note: You can run it without Node.js installed.\n\n### c. Docker image\n\nPull from [dockerhub][dockerhub].\n\n[![Docker Automated build][dockerhub-auto-badge]][dockerhub]\n[![Docker Pulls][dockerPulls-badge]][dockerhub]\n[![Docker Size][dockerSize-badge]][dockerSize]\n\n```\n$ docker pull evenchange4/micro-medium-api:latest\n$ docker run --rm -it \\\n  -p $PORT:3000 \\\n  -e \"ORIGIN=YOUR_DOMAIN\" \\\n  evenchange4/micro-medium-api:latest\n```\n\n### d. NPM CLI\n \nInstall from [npm][npm].\n \n[![npm downloads][npm-downloads]][npm]\n[![npm][npm-badge]][npm]\n \n```\n$ npm i micro-medium-api -g\n \n$ ORIGIN=$YOUR_DOMAIN \\\n  micro-medium-api --port $PORT\n```\n \n\u003e Note: You should use Node.js \u003e= 8 .\n\n\n## API\n\n### Environment variables\n\n| **ENV**   | **Required**  | **Default**  | **Description** |\n| --------- | --------- | --------- | --------- |\n| `ORIGIN`  |  | `*` | Setup `access-control-allow-origin` for CORS. |\n\n### CLI arguments\n\n```\n$ micro-medium-api --help\nUsage: micro-medium-api \u003ccommand\u003e [options]\n \nOptions:\n  -p, --port     HTTP server PORT                                [default: 3000]\n  -h, --help     Show help                                             [boolean]\n  -v, --version  Show version number                                   [boolean]\n```\n\n### GraphQL endpoint\n\n- [GET] /graphql\n- [POST] /graphql\n\n## Demo\n\n- [GraphiQL](https://micro-medium-api.now.sh/graphiql)\n- [HTTP GET example](https://micro-medium-api.now.sh/graphql?query=query%20PostQuery(%24username%3A%20String!%2C%20%24limit%3A%20Int)%20%7B%0A%20%20posts(username%3A%20%24username%2C%20limit%3A%20%24limit)%20%7B%0A%20%20%20%20title%0A%20%20%20%20firstPublishedAt%0A%20%20%20%20url%0A%20%20%20%20subtitle%0A%20%20%7D%0A%20%20%0A%20%20user(username%3A%20%24username)%20%7B%0A%20%20%20%20username%0A%20%20%20%20name%0A%20%20%20%20bio%0A%20%20%7D%0A%7D\u0026variables=%7B%0A%20%20\"username\"%3A%20\"evenchange4\"%2C%0A%20%20\"limit\"%3A%20100%0A%7D)\n- Real-World case:  [michaelhsu.tw](https://michaelhsu.tw/) [[source code](https://github.com/evenchange4/michaelhsu.tw)]\n\n\u003e Note: You should deploy your own service for production usage.\n\n## Technology Stacks\n\n- [Micro](https://github.com/zeit/micro): Asynchronous HTTP microservices.\n- [Micro-router](https://github.com/pedronauck/micro-router): A tiny and functional router for Zeit's Micro.\n- [Micro-ratelimit](https://github.com/dotcypress/micro-ratelimit): Rate-limiting middleware for micro.\n- [Graphql-tools](https://github.com/apollographql/graphql-tools): 🔧 Build and mock your GraphQL.js schema using the schema language.\n- [Graphql-server-micro](https://github.com/apollographql/apollo-server/tree/master/packages/graphql-server-micro): 🌍 GraphQL server\n- [Dataloader](https://github.com/facebook/dataloader): DataLoader is a generic utility to be used as part of your application's data fetching layer to provide a consistent API over various backends and reduce requests to those backends via batching and caching.\n- [Dockerhub][dockerhub]: Automatically deploy docker image.\n- [Now.sh](https://zeit.co/now): Realtime global deployments\n- [Pkg](https://github.com/zeit/pkg): Package your Node.js project into an executable\n- Travis: CI\n\n## Developer Guide\n\n### Requirements\n\n-   node \u003e= 8.5.0\n-   npm \u003e= 5.3.0\n-   yarn \u003e= 1.0.2\n\n```\n$ git clone https://github.com/evenchange4/micro-medium-api.git\n$ yarn install --pure-lockfile\n\n$ yarn run dev # dev server\n$ yarn start   # prod server\n$ yarn run pkg # output binary files\n```\n\n### Test\n\n```\n$ yarn run format\n$ yarn run eslint\n$ yarn run test:watch\n```\n\n### Docker\n\n```\n$ docker build -t micro-medium-api .\n\n# Push to dockerhub\n$ git push\n```\n\n\u003e Note: Multi-stage builds are a new feature in Docker 17.05.\n \n### Github release / NPM release\n \n```\n$ npm version patch\n$ git push\n```\n \n## Inspiration\n\n- https://github.com/enginebai/PyMedium\n\n## CONTRIBUTING\n\n*   ⇄ Pull requests and ★ Stars are always welcome.\n*   For bugs and feature requests, please create an issue.\n*   Pull requests must be accompanied by passing automated tests (`$ yarn run test`).\n\n## [CHANGELOG](CHANGELOG.md)\n\n## [LICENSE](LICENSE)\n\nMIT: [http://michaelhsu.mit-license.org](http://michaelhsu.mit-license.org)\n\n[travis-badge]: https://img.shields.io/travis/evenchange4/micro-medium-api/master.svg?style=flat-square\n[travis]: https://travis-ci.org/evenchange4/micro-medium-api\n[codecov-badge]: https://img.shields.io/codecov/c/github/evenchange4/micro-medium-api.svg?style=flat-square\n[codecov]: https://codecov.io/github/evenchange4/micro-medium-api?branch=master\n[node]: https://img.shields.io/node/v/micro-medium-api.svg?style=flat-square\n[npm-badge]: https://img.shields.io/npm/v/micro-medium-api.svg?style=flat-square\n[npm]: https://www.npmjs.com/package/micro-medium-api\n[npm-downloads]: https://img.shields.io/npm/dt/micro-medium-api.svg?style=flat-square\n[dependency-badge]: https://david-dm.org/evenchange4/micro-medium-api.svg?style=flat-square\n[dependency]: https://david-dm.org/evenchange4/micro-medium-api\n[devDependency-badge]: https://david-dm.org/evenchange4/micro-medium-api/dev-status.svg?style=flat-square\n[devDependency]: https://david-dm.org/evenchange4/micro-medium-api#info=devDependencies\n[peerDependency-badge]: https://david-dm.org/evenchange4/micro-medium-api/peer-status.svg?style=flat-square\n[peerDependency]: https://david-dm.org/evenchange4/micro-medium-api#info=peerDependencies\n[githubTag-badge]: https://img.shields.io/github/tag/evenchange4/micro-medium-api.svg?style=flat-square\n[githubTag]: ./CHANGELOG.md\n[license-badge]: https://img.shields.io/github/license/evenchange4/micro-medium-api.svg?style=flat-square\n[license]: http://michaelhsu.mit-license.org/\n[greenkeeper-badge]: https://badges.greenkeeper.io/evenchange4/micro-medium-api.svg\n[greenkeeper]: https://greenkeeper.io/\n[dockerhub-auto-badge]: https://img.shields.io/docker/automated/evenchange4/micro-medium-api.svg?style=flat-square\n[dockerhub]: https://hub.docker.com/r/evenchange4/micro-medium-api/\n[dockerPulls-badge]: https://img.shields.io/docker/pulls/evenchange4/micro-medium-api.svg?style=flat-square\n[dockerSize]: https://microbadger.com/images/evenchange4/micro-medium-api\n[dockerSize-badge]: https://images.microbadger.com/badges/image/evenchange4/micro-medium-api.svg\n[prettier-badge]: https://img.shields.io/badge/styled_with-prettier-ff69b4.svg?style=flat-square\n[prettier]: https://github.com/prettier/prettier\n","funding_links":[],"categories":["JavaScript","zeit"],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fevenchange4%2Fmicro-medium-api","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fevenchange4%2Fmicro-medium-api","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fevenchange4%2Fmicro-medium-api/lists"}