j3d*_*j3d 6 scala swagger swagger-ui swagger-play2
我能够通过Play设置Swagger并尝试Swagger-ui ......我必须说它真的很棒.
使用ApiOperation,ApiImplicitPara等记录我的控制器的操作很容易,并且按预期工作.
然而,由于我对Swagger的了解有限,我在为类型的隐式参数定义模式时遇到了问题body.我想要映射到隐式参数的类如下所示:
@ApiModel(value "User", description = "Represents an user")
class User private(private var json: JsValue) {
private def setValue(key: JsPath, value: JsValue) = {
value match {
case JsNull => json.transform(key.json.prune).map(t => json = t)
case _ => json.transform((__.json.update(key.json.put(value)))).map(t => json = t)
}
}
def asJson = json
@ApiModelProperty(value = "User's id", dataType = "String", required = false)
def id_= (v: Option[String]) = setValue((__ \ 'id), Json.toJson(v))
def id = json as (__ \ 'id).readNullable[String]
@ApiModelProperty(value = "User's email address", dataType = "String", required = true)
def email = json as (__ \ 'email).read[String]
def email_= (v: String) = setValue((__ \ 'email), Json.toJson(v))
@ApiModelProperty(value = "User's firstName", dataType = "String", required = true)
def firstName = json as (__ \ 'firstName).read[String]
def firatName_= (v: String) = setValue((__ \ 'firstName), Json.toJson(v))
...
}
object User {
def apply(
id: Option[String],
email: String,
firstName: String,
): JsResult[User] = apply(Json.obj(
"id" -> id,
"email" -> email,
"firstName" -> firstName,
...
))
}
Run Code Online (Sandbox Code Playgroud)
我的模型类的内部表示是JSON ...然后我只提供读取/修改内部JSON的getter和setter - 这个解决方案让我可以非常快速地处理JSON,并且我可以按原样将对象传递给MongoDB.
问题是Swagger为上面的类生成的模型是这样的:
User {
json(JsValue),
id(String): User's id,
email(String): User's email,
firstName(String): User's first name,
...
}
Run Code Online (Sandbox Code Playgroud)
如何防止Swagger json加入模型?
小智 1
尝试这个:
@ApiModelProperty(required = false, hidden = true)
def asJson = json
Run Code Online (Sandbox Code Playgroud)