如果您仅使用自动发现功能发现数据库表,则自动生成swagger文档

问题描述:

我在想如果我们只使用此处列出的自动发现功能,我们是否仍然可以为我们的Loopback API服务器自动生成Swagger API文档:如果您仅使用自动发现功能发现数据库表,则自动生成swagger文档

https://docs.strongloop.com/display/public/LB/Discovering+models+from+relational+databases

有没有人知道是否有可能?如果我们使用自动发现,我总是怀疑我们的模型的任何.json文件都会被写入到我们的服务器项目中,这会使生成文档变得困难。

原来是有可能的,要做到这一点的方法是使用脚本为所有模型编写models-x.json文件,然后在脚本完成后启动服务器!

https://docs.strongloop.com/display/public/LB/Database+discovery+API

这是自动发现标准的做法,这里是我的代码,完成此:

const loopback = require('loopback'); 
const fs = require('fs'); 
const path = require('path'); 
const async = require('async'); 

var ds = loopback.createDataSource('postgresql', { 
    'host': 'localhost', 
    'port': 5432, 
    'database': 'foo', 
    'username': 'bar', 
    'password': 'baz' 
}); 


ds.discoverModelDefinitions(function (err, models) { 

    async.each(models, function (def, cb) { 

    ds.discoverSchema(def.name, null, function (err, schema) { 
     if (err) { 
     console.error(err.stack || err); 
     cb(err); 
     } 
     else { 
     fs.writeFile(path.resolve(__dirname, 'server/models', def.name + '.json'), 
      JSON.stringify(schema), {}, cb); 
     } 
    }); 

    }, function (err) { 
    if (err) { 
     console.log(err.stack || err); 
     process.exit(1); 
    } 
    else { 
     console.log(' => Successfully wrote model data.'); 
     process.exit(0); 
    } 

    }); 
}); 
+0

你能请注明这个问题的回答 –

+0

肯定的事,这是应该做的方式 –