npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

egg-connector-remote

v2.0.2

Published

Egg remote REST API connector like loopback

Downloads

78

Readme

egg-connector-remote

NPM version build status Test coverage David deps Known Vulnerabilities npm download

使用配置json的方式快速构建 restful api, 以及相应的 swagger 生成文件。类似于 loopback

依赖说明

swagger.json 规则来自于 https://editor.swagger.io//?_ga=2.41951072.471192285.1510301833-940518916.1510301833#/

依赖的 egg 版本

egg-connector-remote 版本 | egg 1.x --- | --- 1.x | 😁 0.x | ❌

依赖的插件

未依赖

开启插件

// config/plugin.js
exports.connectorRemote = {
  enable: true,
  package: 'egg-connector-remote',
};

功能

  1. 通过配置生成 swagger.json 的信息,配置语法 参考 loopback http://loopback.io/doc/en/lb3/Define-model-relations.html
  2. 增加 registerRemote 全局方法. 自动处理 model 和 ctrl 的关系
  3. 增加 access 访问控制 同 loopback
  • 仅适用 role

使用场景

  • 类似 loopback 的 rest方式暴露出 swagger.json

详细配置

  // 默认配置
  const defaultConfig = {
    modelsPath: 'model.models',
    swaggerDefinition: {
      info: { // API informations (required)
        title: 'theone.io', // Title (required)
        version: '1.0.0', // Version (required)
        description: 'swagger service description', // Description (optional)
      },
      basePath: '/api/v1',
    },
    registerRemote: true, // 开启注册 remote 功能
    accessRemoteDefinition: {
      enable: true, // 默认 false, 是否开启访问控制
      getMatchFunc: function() => {}, // role 的 Model, 获取验证的方法。
    },
  };

单元测试

npm run test

feature

  1. [x] config2swagger: 使用 model.setting 的配置生成 swagger相关文件。
  2. [x] remote:自动处理 Model.setting 和 ctrl 的关系以及路由的关系
  3. [x] Test parameter: 自动校验输入输出参数
  4. [x] access controller: 访问控制, 权鉴设置
  5. [] 动态增加 remote
  6. [] 增加beforeRemote 和 afterRemote

提问交流

请到 egg issues 异步交流。

附件

  1. 复数lib - 强迫症患者使用

License

MIT

发布

npm login
npm publish