From a12cd5c373e061c76cbeb11bf9005d155b8524c2 Mon Sep 17 00:00:00 2001 From: hamlakshan Date: Mon, 1 Jul 2019 11:46:39 +0530 Subject: [PATCH] INTGW-602: added WUM changes to jaggery components --- .../src/main/publisher/modules/api/add.jag | 2 +- .../main/publisher/modules/search/search.jag | 6 +- .../site/blocks/api-doc/ajax/get.jag | 20 +- .../site/blocks/item-design/ajax/add.jag | 339 +++----- .../publisher/site/blocks/listing/block.jag | 9 +- .../publisher/site/blocks/tag/ajax/tag.jag | 4 +- .../site/blocks/tiers/ajax/tiers.jag | 4 +- .../site/blocks/usage/ajax/usage.jag | 4 +- .../blocks/users-api/ajax/subscriptions.jag | 4 +- .../conf/locales/jaggery/locale_default.json | 6 +- .../site/conf/locales/jaggery/locale_en.json | 7 +- .../publisher/site/themes/wso2/css/custom.css | 47 ++ .../wso2/templates/item-add/js/item-add.js | 15 +- .../wso2/templates/item-add/template.jag | 27 +- .../templates/item-design/js/api-design.js | 60 +- .../wso2/templates/item-design/template.jag | 67 +- .../item-implement/js/api-implementation.js | 22 +- .../templates/item-implement/template.jag | 30 +- .../wso2/templates/item-manage/template.jag | 52 +- .../wso2/templates/life-cycles/template.jag | 13 +- .../wso2/templates/page/base/js/jagg.js | 1 + .../store/src/main/store/jagg/jagg.jag | 11 +- .../src/main/store/jagg/jaggery_oidc_acs.jag | 30 +- .../main/store/modules/application/add.jag | 8 +- .../main/store/modules/application/list.jag | 29 + .../main/store/modules/application/module.jag | 13 +- .../main/store/modules/application/update.jag | 31 + .../main/store/modules/manager/manager.jag | 15 +- .../src/main/store/modules/manager/module.jag | 3 + .../main/store/modules/subscription/add.jag | 32 + .../main/store/modules/subscription/key.jag | 85 +- .../main/store/modules/subscription/list.jag | 77 +- .../store/modules/subscription/module.jag | 21 +- .../store/site/blocks/api-doc/ajax/get.jag | 32 +- .../site/blocks/api/api-listing-all/block.jag | 5 +- .../application-add/ajax/application-add.jag | 3 +- .../application/application-edit/block.jag | 4 +- .../ajax/application-list.jag | 28 + .../ajax/application-remove.jag | 28 + .../ajax/application-update.jag | 61 ++ .../application/application-view/block.jag | 10 +- .../ajax/subscription-add.jag | 207 ++++- .../ajax/subscription-list.jag | 91 ++- .../ajax/subscription-remove.jag | 4 +- .../site/blocks/user/login/ajax/login.jag | 2 +- .../conf/locales/jaggery/locale_default.json | 6 +- .../site/conf/locales/jaggery/locale_en.json | 6 +- .../main/store/site/themes/wso2/.gitignore | 2 + .../main/store/site/themes/wso2/css/.Rhistory | 0 .../store/site/themes/wso2/css/component.css | 726 ++++++++++++++++++ .../store/site/themes/wso2/css/custom.css | 43 ++ .../store/site/themes/wso2/js/applications.js | 23 +- .../js/cloud-enjoyhint-script-data.js | 6 +- .../templates/api/api-info/js/api-info.js | 4 +- .../wso2/templates/api/api-info/template.jag | 46 +- .../api/api-listing-all/template.jag | 58 +- .../templates/api/documentation/download.jag | 16 +- .../api/documentation/view/template.jag | 4 +- .../wso2/templates/api/overview/template.jag | 2 +- .../api/swagger/swagger/dist/.Rhistory | 0 .../swagger/swagger/dist/favicon-16x16.png | Bin 445 -> 665 bytes .../swagger/swagger/dist/favicon-32x32.png | Bin 1141 -> 628 bytes .../api/swagger/swagger/dist/index.html | 145 ++-- .../swagger/swagger/dist/oauth2-redirect.html | 9 +- .../swagger/swagger/dist/swagger-ui-bundle.js | 84 +- .../swagger/dist/swagger-ui-bundle.js.map | 2 +- .../dist/swagger-ui-standalone-preset.js | 9 +- .../dist/swagger-ui-standalone-preset.js.map | 2 +- .../api/swagger/swagger/dist/swagger-ui.css | 3 +- .../api/swagger/swagger/dist/swagger-ui.js | 5 +- .../swagger/swagger/dist/swagger-ui.js.map | 2 +- .../wso2/templates/api/swagger/template.jag | 6 +- .../application-add/js/application-add.js | 8 +- .../application-edit/js/application-edit.js | 9 +- .../application/application-edit/template.jag | 5 +- .../application/application-keys/template.jag | 18 +- .../application-list/js/application.js | 9 +- .../application/application-list/template.jag | 9 +- .../application/application-view/template.jag | 44 +- .../comment/comment-list/template.jag | 2 +- .../wso2/templates/forum/js/forum-list.js | 2 +- .../wso2/templates/menu/actions/template.jag | 4 +- .../wso2/templates/page/base/js/jagg.js | 1 + .../templates/stats/apiCallType/js/stats.js | 44 +- .../templates/stats/apiCallType/template.jag | 3 +- .../subscription/subscribed-apis/template.jag | 3 + .../subscription-authapp-main/template.jag | 4 +- .../subscription-authapp-main/template.jag | 2 +- .../subscription-authapp-main/template.jag | 2 + .../subscription-list-element/js/authapp.js | 4 +- .../subscription-list-element/template.jag | 11 +- .../subscription-list/js/subscription-list.js | 3 +- 92 files changed, 2329 insertions(+), 636 deletions(-) create mode 100644 components/jaggery-apps/store/src/main/store/site/themes/wso2/.gitignore create mode 100644 components/jaggery-apps/store/src/main/store/site/themes/wso2/css/.Rhistory create mode 100644 components/jaggery-apps/store/src/main/store/site/themes/wso2/templates/api/swagger/swagger/dist/.Rhistory diff --git a/components/jaggery-apps/publisher/src/main/publisher/modules/api/add.jag b/components/jaggery-apps/publisher/src/main/publisher/modules/api/add.jag index 252142af4..4c76f47be 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/modules/api/add.jag +++ b/components/jaggery-apps/publisher/src/main/publisher/modules/api/add.jag @@ -792,7 +792,7 @@ var isScopeExist = function (scope, username, roleName) { } catch (e) { log.error(e.message); return { - error:e + error:true }; } }; diff --git a/components/jaggery-apps/publisher/src/main/publisher/modules/search/search.jag b/components/jaggery-apps/publisher/src/main/publisher/modules/search/search.jag index 2775eea86..51c805719 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/modules/search/search.jag +++ b/components/jaggery-apps/publisher/src/main/publisher/modules/search/search.jag @@ -1,9 +1,9 @@ <% -var searchAPIs = function (username,apiName, start, end) { +var searchAPIs = function (username,query, start, end) { var i,api,apis,length, result, log = new Log(), provider = jagg.module("manager").getAPIProviderObj(); try { - result = provider.searchPaginatedAPIs(username, apiName, start, end); + result = provider.searchPaginatedAPIs(username, query, start, end); if (log.isDebugEnabled()) { log.debug("searchAPI : " + stringify(apis)); } @@ -56,4 +56,4 @@ var searchAccessTokens = function (query) { }; } }; -%> \ No newline at end of file +%> diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/blocks/api-doc/ajax/get.jag b/components/jaggery-apps/publisher/src/main/publisher/site/blocks/api-doc/ajax/get.jag index 292e62730..a24367338 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/blocks/api-doc/ajax/get.jag +++ b/components/jaggery-apps/publisher/src/main/publisher/site/blocks/api-doc/ajax/get.jag @@ -78,12 +78,20 @@ var log = new Log(); PrivilegedCarbonContext.getThreadLocalCarbonContext().setTenantDomain(tenantDomain, true); } - var APIUtil = Packages.org.wso2.carbon.apimgt.impl.utils.APIUtil; - var apiUtil = new APIUtil(); - var swaggerPath = apiUtil.getOpenAPIDefinitionFilePath(apiNameVal, apiVersionVal, providerVal); - var registry = carbon.server.osgiService('org.wso2.carbon.registry.core.service.RegistryService').getGovernanceUserRegistry(jagg.getUser(), tenantID); - url = swaggerPath + "swagger.json"; - data = registry.get(url); + var APIUtil = Packages.org.wso2.carbon.apimgt.impl.utils.APIUtil; + var apiUtil = new APIUtil(); + var swaggerPath = apiUtil.getOpenAPIDefinitionFilePath(apiNameVal, apiVersionVal, providerVal); + var user = jagg.getUser(); + if (user && user.username) { + var MultitenantUtils = Packages.org.wso2.carbon.utils.multitenancy.MultitenantUtils; + username = MultitenantUtils.getTenantAwareUsername(user.username); + } else { + username = "wso2.anonymous.user"; + } + var registry = carbon.server.osgiService('org.wso2.carbon.registry.core.service.RegistryService') + .getGovernanceUserRegistry(username, tenantID); + url = swaggerPath + "swagger.json"; + data = registry.get(url); } finally { if (isTenantFlowStarted) { PrivilegedCarbonContext.endTenantFlow(); diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/blocks/item-design/ajax/add.jag b/components/jaggery-apps/publisher/src/main/publisher/site/blocks/item-design/ajax/add.jag index 175c04db5..e1c96fe9c 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/blocks/item-design/ajax/add.jag +++ b/components/jaggery-apps/publisher/src/main/publisher/site/blocks/item-design/ajax/add.jag @@ -50,6 +50,11 @@ var parseSwaggerDefinition = function (swagger) { return swaggerJson; } +var isSupportedOpenAPIVersion = function (version) { + // support for 3.0.x versions + return /^3\.0\.\d{1,}$/.test(version); +} + if(jagg.isCSRFTokenValid()) (function () { response.contentType = "text/plain; charset=UTF-8"; @@ -61,6 +66,8 @@ if(jagg.isCSRFTokenValid()) site = require("/site/conf/site.json"), msg = require("/site/conf/ui-messages.jag"), parser = new SwaggerParser(), + supportedSwaggerVersion = "2.0", + supportedOpenAPIVersion = "3.0.x", supportedHTTPMethods = ["get", "put", "post", "delete", "patch", "head", "options"]; if(jagg.getUser() == null){ @@ -74,8 +81,7 @@ if(jagg.isCSRFTokenValid()) var type = request.getParameter("type"); var swagger = null; var wsdl = null; - var supportedSwaggerVersion = "2.0"; - var supportedOpenAPIVersion = "3.0.0"; + var wsdlFile = null; var apiDefinitionVersion = request.getParameter("apiDefinitionVersion"); if(type == "rest"){ @@ -92,7 +98,7 @@ if(jagg.isCSRFTokenValid()) //released yet. var apiDefinition = parseSwaggerDefinition(swagger); if (apiDefinition.openapi) { - if (apiDefinition.openapi != supportedOpenAPIVersion) { + if (!isSupportedOpenAPIVersion(apiDefinition.openapi.trim())) { print({ error: true, message: "Unsupported OpenAPI version provided. Please re-import with OpenAPI " + @@ -150,7 +156,7 @@ if(jagg.isCSRFTokenValid()) if (apiDefinition.openapi) { //Supported Open API Version check - if (apiDefinition.openapi != supportedOpenAPIVersion) { + if (!isSupportedOpenAPIVersion(apiDefinition.openapi.trim())) { print({ error: true, message: "Unsupported OpenAPI version provided. Please re-import with OpenAPI " + @@ -204,11 +210,14 @@ if(jagg.isCSRFTokenValid()) } else if(type == "soap"){ var url = request.getParameter("wsdl-url"); - var file = request.getFile("wsdl-file"); + wsdlFile = request.getFile("wsdl-file"); var import_type = request.getParameter("import-definition"); var passThrough = request.getParameter("soap-options-pass-thru"); var rest = request.getParameter("soap-options-rest"); wsdl = "soap"; + if(wsdlFile) { + wsdl = wsdlFile.getName(); + } if(url){ wsdl = url.trim(); } @@ -222,191 +231,8 @@ if(jagg.isCSRFTokenValid()) if(resp) { mappingJson = JSON.parse(resp); session.put("mappingJson", mappingJson); - var names={},parameters=[]; - var definitions = {}; - for(var i = 0; i < mappingJson.length; i++) { - var responses = {},verb={},status={},description={},definition={}; - var httpverb = mappingJson[i].httpVerb.toLowerCase(); - var path = "/" + mappingJson[i].name; - description["description"] = ""; - status["200"] = description; - responses.tags = []; - responses.parameters = []; - responses["responses"]=status; - responses.tags.push(mappingJson[i].name); - var count = 0; - var properties = {}; - for(var j = 0; j < mappingJson[i].parameters.length; j++) { - var parameter = {}; - parameter.description = ""; - var type = mappingJson[i].parameters[j].dataType; - var isArray = mappingJson[i].parameters[j].isArray; - if(mappingJson[i].parameters[j].isComplexType) { - if(count == 0) { - parameter.in = "body"; - parameter.name = "Payload"; - var def = "#/definitions/" + mappingJson[i].name; - var ref = {}, typeObj = {}; - ref["$ref"] = def; - typeObj["type"] = "object"; - parameter.schema = ref; - - var defN = "#/definitions/" + mappingJson[i].parameters[j].name; - var refN = {}, typeNObj = {}; - refN["$ref"] = defN; - typeNObj["type"] = "object"; - - if(!definitions[mappingJson[i].name]) - definitions[mappingJson[i].name] = {}; - if(!definitions[mappingJson[i].parameters[j].name]) - definitions[mappingJson[i].parameters[j].name] = {}; - definitions[mappingJson[i].name] = typeObj; - definitions[mappingJson[i].parameters[j].name] = typeNObj; - var bodyParam = {}; - bodyParam[mappingJson[i].parameters[j].name] = refN; - definitions[mappingJson[i].name].properties = bodyParam; - } - var property = {}; - property.type = type; - if(isArray) { - property.type = "array"; - var itemType = {}; - itemType["type"] = type; - property.items = itemType; - properties[mappingJson[i].parameters[j].name] = property; - } else { - var root; - var buildTree = function(obj, parent) { - for(var k in obj) { - if(obj[k].wsdlComplexType && obj[k].wsdlComplexType.paramList) { - root = parent; - buildTree(obj[k].wsdlComplexType.paramList,obj[k]); - } else { - if(!definitions[mappingJson[i].parameters[j].name]) - definitions[mappingJson[i].parameters[j].name] = {}; - - if(root && root.name && parent.name) { - var rootDef = "#/definitions/" + root.name; - var parentDef = "#/definitions/" + parent.name; - if(!definitions[mappingJson[i].parameters[j].name].properties) { - definitions[mappingJson[i].parameters[j].name].properties = {}; - definitions[mappingJson[i].parameters[j].name].properties[root.name] = {}; - definitions[mappingJson[i].parameters[j].name].properties[root.name]["$ref"] = rootDef; - } - if(!definitions[root.name]) { - definitions[root.name] = {}; - definitions[root.name].type = "object"; - definitions[root.name].properties = {} - } - if(!definitions[parent.name]) { - definitions[parent.name] = {}; - definitions[parent.name].type = "object"; - definitions[parent.name].properties = {}; - } - if(parent.name != root.name) { - if(!definitions[root.name].properties[parent.name]) { - definitions[root.name].properties[parent.name] = {}; - } - if(!definitions[root.name].properties[parent.name]["$ref"]) { - definitions[root.name].properties[parent.name]["$ref"] = {}; - definitions[root.name].properties[parent.name]["$ref"] = parentDef; - } - } - if(!definitions[parent.name].properties[obj[k].name]) { - if(obj[k].isArray) { - definitions[parent.name].type = 'array'; - definitions[parent.name].items = {}; - definitions[parent.name].items.type = obj[k].dataType; - } else { - definitions[parent.name].properties[obj[k].name] = {}; - if(obj[k].dataType == 'int') { - definitions[parent.name].properties[obj[k].name].type = 'integer'; - } else { - definitions[parent.name].properties[obj[k].name].type = obj[k].dataType; - } - if(parent.name != root.name) { - definitions[parent.name].properties[obj[k].name]["x-path"] = root.name + "/" + parent.name + "/" + obj[k].name; - } else { - definitions[parent.name].properties[obj[k].name]["x-path"] = parent.name + "/" + obj[k].name; - } - } - } - - } else if(parent.name) { - var parentDef = "#/definitions/" + parent.name; - if(!definitions[parent.name]) { - definitions[parent.name] = {}; - definitions[parent.name].type = "object"; - definitions[parent.name].properties = {}; - } - if(!definitions[parent.name].properties[obj[k].name]) { - if(obj[k].isArray) { - definitions[parent.name].type = 'array'; - definitions[parent.name].items = {}; - definitions[parent.name].items.type = obj[k].dataType; - } else { - definitions[parent.name].properties[obj[k].name] = {}; - if(obj[k].dataType == 'int') { - definitions[parent.name].properties[obj[k].name].type = 'integer'; - } else { - definitions[parent.name].properties[obj[k].name].type = obj[k].dataType; - } - definitions[parent.name].properties[obj[k].name]["x-path"] = mappingJson[i].parameters[j].name + "/" + parent.name + "/" + obj[k].name; - } - } - if(!definitions[mappingJson[i].parameters[j].name].properties) { - definitions[mappingJson[i].parameters[j].name].properties = {}; - } - if(!definitions[mappingJson[i].parameters[j].name].properties[parent.name]) { - definitions[mappingJson[i].parameters[j].name].properties[parent.name] = {}; - definitions[mappingJson[i].parameters[j].name].properties[parent.name]["$ref"] = {}; - } - definitions[mappingJson[i].parameters[j].name].properties[parent.name]["$ref"] = parentDef; - - } else { - if(obj[k].isArray) { - definitions[mappingJson[i].parameters[j].name].type = 'array'; - definitions[mappingJson[i].parameters[j].name].items = {}; - definitions[mappingJson[i].parameters[j].name].items.type = obj[k].dataType; - } else { - if(!definitions[mappingJson[i].parameters[j].name].properties) { - definitions[mappingJson[i].parameters[j].name].properties = {}; - } - if(!definitions[mappingJson[i].parameters[j].name].properties[obj[k].name]) { - definitions[mappingJson[i].parameters[j].name].properties[obj[k].name] = {}; - } - if(obj[k].dataType == 'int') { - definitions[mappingJson[i].parameters[j].name].properties[obj[k].name].type = 'integer'; - } else { - definitions[mappingJson[i].parameters[j].name].properties[obj[k].name].type = obj[k].dataType; - } - definitions[mappingJson[i].parameters[j].name].properties[obj[k].name]["x-path"] = mappingJson[i].parameters[j].name + "/" + obj[k].name; - } - } - } - } - }; - buildTree(mappingJson[i].parameters[j].wsdlComplexType.paramList, - mappingJson[i].parameters[j].wsdlComplexType.paramList); - } - //definitions[mappingJson[i].parameters[j].name].properties = properties; - count++; - } else { - parameter.in = "query"; - parameter.name = mappingJson[i].parameters[j].name; - parameter.type = type; - } - - if(parameter.in) { - parameters.push(parameter); - responses.parameters.push(parameter); - } - } - verb[httpverb]=responses; - names[path]=verb; - } - session.put("paths", names); - session.put("definitions", definitions); + session.put("paths", mappingJson.paths); + session.put("definitions", mappingJson.definitions); } else { log.error("error occurred while soap to rest conversion.") } @@ -435,6 +261,13 @@ if(jagg.isCSRFTokenValid()) session.put("swagger",swagger); session.put("wsdl", wsdl); } + if(wsdlFile) { + session.put("ws",null); + session.put("swagger",swagger); + session.put("wsdl-file", wsdlFile); + } else { + session.remove("wsdl-file"); + } print({ error: false, @@ -471,9 +304,14 @@ if(jagg.isCSRFTokenValid()) return; } + var wsdlFile = request.getFile("wsdl-file"); + if(wsdlFile == null) { + wsdlFile = session.get("wsdl-file"); + } + //try to read the wsdl content from the url var wsdlUrl = request.getParameter("wsdl"); - if (wsdlUrl != null) { + if (wsdlFile == null && wsdlUrl != null) { if (!wsdlUrl.match(org.wso2.carbon.apimgt.impl.APIConstants.API_WSDL_RESOURCE_LOCATION)) { try { org.wso2.carbon.apimgt.impl.utils.APIUtil.isWSDL2Document(wsdlUrl); @@ -491,6 +329,15 @@ if(jagg.isCSRFTokenValid()) //If API not exist create result = mod.checkIfResourceExists(apiData); if(!result){ + // Check logged in user try to create api with different user name. + if(jagg.getUser().username != apiData.provider) { + obj = { + error:true, + message:"Not allowed to add APIs with different provider name other than logged in user." + }; + print(obj); + return; + } result = mod.createAPI(apiData); if (result.error==true) { obj = { @@ -511,6 +358,7 @@ if(jagg.isCSRFTokenValid()) apiData.visibility = request.getParameter("visibility"); apiData.visibleRoles = request.getParameter("roles","UTF-8"); apiData.wsdl = request.getParameter("wsdl"); + apiData.wsdlFile = wsdlFile; apiData.accessControl = request.getParameter("accessControl"); apiData.accessControlRoles = request.getParameter("accessControlRoles", "UTF-8"); apiData.additionalProperties = request.getParameter("additionalProperties", "UTF-8"); @@ -526,8 +374,10 @@ if(jagg.isCSRFTokenValid()) } if(isSoapToRestApi) { mappingJson = session.get("mappingJson"); - var sequenceGenerator = Packages.org.wso2.carbon.apimgt.impl.soaptorest.SequenceGenerator; - sequenceGenerator.generateSequences(stringify(apiData), stringify(mappingJson)); + if (mappingJson) { + var sequenceGenerator = Packages.org.wso2.carbon.apimgt.impl.soaptorest.SequenceGenerator; + sequenceGenerator.generateSequencesFromSwagger(apiData.swagger,stringify(apiData)); + } } } if (result.error == true) { @@ -609,8 +459,19 @@ if(jagg.isCSRFTokenValid()) } apiData.endpointUTPassword = decodedPassword.toString(); } else { - apiData.endpointUTPassword = session.get(request.getParameter("name", "UTF-8") + "-" + - request.getParameter("version") + "-epPassword"); + var encryptedPasswordFromSession = session.get(request.getParameter("name", "UTF-8") + "-" + + request.getParameter("version") + "-epPassword"); + if (encryptedPasswordFromSession) { + + var byteArray = CryptoUtil.getDefaultCryptoUtil().base64DecodeAndDecrypt(encryptedPasswordFromSession); + var decodedPassword = ""; + for(var index = 0; index < byteArray.length; index += 1) { + decodedPassword += String.fromCharCode(byteArray[index]); + } + apiData.endpointUTPassword = decodedPassword.toString(); + } else { + apiData.endpointUTPassword = encryptedPasswordFromSession; + } } apiData.endpoint_config= request.getParameter("endpoint_config","UTF-8"); apiData.destinationStats= request.getParameter("destinationStats","UTF-8"); @@ -920,23 +781,52 @@ if(jagg.isCSRFTokenValid()) print(apiDefinitionVersion); } else if (request.getMethod() === 'POST' && action === 'validateSwagger') { var swagger = request.getParameter("swaggerDefinition"); - var swaggerDeserializationResult = parser.readWithInfo(swagger); - var swaggerObj = swaggerDeserializationResult.getSwagger(); - var swaggerErrors = swaggerDeserializationResult.getMessages(); - if (swaggerErrors.size() > 0) { - print({ - error: true, - message: "API swagger definition is invalid. Please fix the suggested validation issues" - }); - return; - } else { - var swaggerJSON = JSON.parse(swagger); - if (swaggerJSON.paths) { - var swaggerPaths = swaggerJSON.paths; - for (var pathKey in swaggerPaths) { - var path = swaggerPaths[pathKey]; - for(var httpMethod in path){ - if(supportedHTTPMethods.indexOf(httpMethod.toLowerCase()) === -1){ + var apiDefinition = parseSwaggerDefinition(swagger); + + if (apiDefinition.swagger) { + var swaggerDeserializationResult = parser.readWithInfo(swagger); + var swaggerObj = swaggerDeserializationResult.getSwagger(); + var swaggerErrors = swaggerDeserializationResult.getMessages(); + + //Supported swagger version check + if (swaggerObj.swagger != supportedSwaggerVersion) { + print({ + error: true, + message: "Unsupported swagger version provided. Please re-import with swagger " + supportedSwaggerVersion + }); + return; + } + + if (swaggerErrors.size() > 0) { + print({ + error: true, + message: "API swagger definition is invalid. Please fix the suggested validation issues" + }); + return; + } else { + var swaggerJSON = JSON.parse(swagger); + if (swaggerJSON.paths) { + var swaggerPaths = swaggerJSON.paths; + for (var pathKey in swaggerPaths) { + var path = swaggerPaths[pathKey]; + var globalParametersDefined = false; + var httpMethodsDefined = false; + for (var httpMethod in path) { + if (httpMethod == "parameters") { + globalParametersDefined = true; + continue; + } else if (supportedHTTPMethods.indexOf(httpMethod.toLowerCase()) === -1) { + print({ + error: true, + message: "The HTTP method '" + httpMethod + "' provided for resource '" + pathKey + "' is invalid" + + }); + return; + } else { + httpMethodsDefined = true; + } + } + if (globalParametersDefined && !httpMethodsDefined) { print({ error: true, message: "The HTTP method '" + httpMethod + "' provided for resource '" + pathKey + "' is invalid" @@ -946,11 +836,36 @@ if(jagg.isCSRFTokenValid()) } } } + print({ + error: false + }) + } + } else if (apiDefinition.openapi){ + //Supported Open API Version check + if (!isSupportedOpenAPIVersion(apiDefinition.openapi.trim())) { + print({ + error: true, + message: "Unsupported OpenAPI version provided. Please re-import with OpenAPI " + + supportedOpenAPIVersion + }); + return; + } + + if (apiDefinition.info == null || apiDefinition.paths == null) { + print({ + error: true, + message: "Required property 'info' or 'paths' are not provided" + }); + return; } print({ error: false }) + } else { + print({error: true, message: "Invalid Open API definition provided"}); + return; } + } else { print({ error:true, diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/blocks/listing/block.jag b/components/jaggery-apps/publisher/src/main/publisher/site/blocks/listing/block.jag index e0eb87008..46143b9a1 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/blocks/listing/block.jag +++ b/components/jaggery-apps/publisher/src/main/publisher/site/blocks/listing/block.jag @@ -33,6 +33,9 @@ jagg.block("listing", { var currentPage = page; var start = itemsPerPage*(page-1); if (query) { + if (query.indexOf(':') == -1) { + query = "content:" + query; + } mod = jagg.module("search"); result = mod.searchAPIs(null,query,String(start),String(itemsPerPage)); apis = null; @@ -51,7 +54,11 @@ jagg.block("listing", { if (result.response != null) { apis = result.response.apis; length = result.response.totalLength; - error = result.error; + if (!result.error) { + error = result.error; + } else { + error = true; + } message = result.message; mode = "listing"; } diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/blocks/tag/ajax/tag.jag b/components/jaggery-apps/publisher/src/main/publisher/site/blocks/tag/ajax/tag.jag index 33607767e..3990aafee 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/blocks/tag/ajax/tag.jag +++ b/components/jaggery-apps/publisher/src/main/publisher/site/blocks/tag/ajax/tag.jag @@ -13,7 +13,7 @@ include("/jagg/jagg.jag"); result = mod.getAllTags(); if (result.error) { obj = { - error:result.error, + error:true, message:msg.error.backendError(action) }; } else { @@ -31,4 +31,4 @@ include("/jagg/jagg.jag"); }); } }()); -%> \ No newline at end of file +%> diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/blocks/tiers/ajax/tiers.jag b/components/jaggery-apps/publisher/src/main/publisher/site/blocks/tiers/ajax/tiers.jag index 51bf00d2a..28e5e4a42 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/blocks/tiers/ajax/tiers.jag +++ b/components/jaggery-apps/publisher/src/main/publisher/site/blocks/tiers/ajax/tiers.jag @@ -28,7 +28,7 @@ if(jagg.isCSRFTokenValid()) result = mod.updateTierPermissions(tierPermission); if (result.error) { obj = { - error:result.error, + error:true, message:result.message }; } else { @@ -48,4 +48,4 @@ if(jagg.isCSRFTokenValid()) } }()); %> -%> \ No newline at end of file +%> diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/blocks/usage/ajax/usage.jag b/components/jaggery-apps/publisher/src/main/publisher/site/blocks/usage/ajax/usage.jag index c3e6bc660..a08b2e0d4 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/blocks/usage/ajax/usage.jag +++ b/components/jaggery-apps/publisher/src/main/publisher/site/blocks/usage/ajax/usage.jag @@ -21,7 +21,7 @@ include("/jagg/jagg.jag"); result = mod.getProviderAPIVersionUsage(provider, apiName); if (result.error) { obj = { - error:result.error, + error:true, message:msg.error.backendError(action) }; } else { @@ -94,4 +94,4 @@ include("/jagg/jagg.jag"); } } }()); -%> \ No newline at end of file +%> diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/blocks/users-api/ajax/subscriptions.jag b/components/jaggery-apps/publisher/src/main/publisher/site/blocks/users-api/ajax/subscriptions.jag index 04893d922..f88d033ff 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/blocks/users-api/ajax/subscriptions.jag +++ b/components/jaggery-apps/publisher/src/main/publisher/site/blocks/users-api/ajax/subscriptions.jag @@ -27,7 +27,7 @@ if(jagg.isCSRFTokenValid()) result = mod.updateSubscription(api, appId,newStatus); if (result.error) { obj = { - error:result.error, + error:true, message:result.message }; } else { @@ -44,4 +44,4 @@ if(jagg.isCSRFTokenValid()) } } }()); -%> \ No newline at end of file +%> diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/conf/locales/jaggery/locale_default.json b/components/jaggery-apps/publisher/src/main/publisher/site/conf/locales/jaggery/locale_default.json index 4b2fe1d31..ee1f0d57c 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/conf/locales/jaggery/locale_default.json +++ b/components/jaggery-apps/publisher/src/main/publisher/site/conf/locales/jaggery/locale_default.json @@ -549,7 +549,9 @@ "Visible to my Domain": "Visible to my Domain", "WADL": "WADL", "WSDL": "WSDL", + "WSDL Archive/File": "WSDL Archive/File", "WSDL Endpoint": "WSDL Endpoint", + "WSDL Url" : "WSDL Url", "WSO2 API Manager uses HTTP Head to check the validity of the endpoint.": "WSO2 API Manager uses HTTP Head to check the validity of the endpoint.", "WSO2 API Publisher Home": "WSO2 API Publisher Home", "WSO2 copyright": "WSO2 copyright", @@ -645,5 +647,7 @@ "Delete Task" : "Delete Task", "Authorization Header": "Authorization Header", "Here a custom authorization header can be defined as a replacement to the default Authorization header used to send a request. If a value is specified here, that will be used as the header field to send the access token in a request to consume the API": "A custom authorization header can be defined here as a replacement to the default Authorization header used to send a request. If a value is specified here, it will be used as the header field to send the access token in a request to consume the API", - "You have selected Microgateways for this API. The mediation policies selected here will not be applied in Microgateway environments.":"You have selected Microgateways for this API. The mediation policies selected here will not be applied in Microgateway environments." + "You have selected Microgateways for this API. The mediation policies selected here will not be applied in Microgateway environments.":"You have selected Microgateways for this API. The mediation policies selected here will not be applied in Microgateway environments.", + "Deprecate old versions after publish the API": "Deprecate old versions after publish the API", + "Requires re-subscription when publish the API": "Requires re-subscription when publish the API" } diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/conf/locales/jaggery/locale_en.json b/components/jaggery-apps/publisher/src/main/publisher/site/conf/locales/jaggery/locale_en.json index bcc5627aa..823cc121c 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/conf/locales/jaggery/locale_en.json +++ b/components/jaggery-apps/publisher/src/main/publisher/site/conf/locales/jaggery/locale_en.json @@ -545,7 +545,9 @@ "Visible to my Domain": "Visible to my Domain", "WADL": "WADL", "WSDL": "WSDL", + "WSDL Archive/File": "WSDL Archive/File", "WSDL Endpoint": "WSDL Endpoint", + "WSDL Url" : "WSDL Url", "WSO2 API Manager uses HTTP Head to check the validity of the endpoint.": "WSO2 API Manager uses HTTP Head to check the validity of the endpoint.", "WSO2 API Publisher Home": "WSO2 API Publisher Home", "WSO2 copyright": "WSO2 copyright", @@ -616,5 +618,8 @@ "You must select a mediation policy to download": "You must select a mediation policy to download.", "Error while retrieving the selected mediation policy": "Error while retrieving the selected mediation policy.", "API swagger definition is invalid" : "API swagger definition is invalid", - "Error while updating API swagger definition" : "Error while updating API swagger definition" + "Error while updating API swagger definition" : "Error while updating API swagger definition", + "Download Document" : "Download Document", + "View Document" : "View Document", + "Document" : "Document" } diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/css/custom.css b/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/css/custom.css index 1da5498d3..884648b10 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/css/custom.css +++ b/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/css/custom.css @@ -160,6 +160,53 @@ input.ep-field{ min-width:155px; } +.document-match-icon { + position:center; + opacity:1; +} + +.square-element .document-match-icon{ + display:block; + background:rgba(0, 0, 0, 0.3); + width:100%; + height:100%; + position:absolute; +} + +.square-element .document-match-icon i{ + padding:2px; + font-size:6vw; + position:absolute; + top:30%; + left:30%; + width:40%; + height:40%; +} + +.thumbnail .square-element{ + background-color:white; +} + +.app-data #document-match{ + margin-bottom: 0px +} + +.app-data #doc-name a{ + color:#ce8c2f; +} + +.app-data #document-type-label{ + text-transform: capitalize; +} + +.app-data #document-type-label{ + text-transform: capitalize; +} + + + + + /* ============================================================================= * Wso2.telco styles diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-add/js/item-add.js b/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-add/js/item-add.js index 9bfa9da76..29490dfb0 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-add/js/item-add.js +++ b/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-add/js/item-add.js @@ -147,7 +147,8 @@ $( document ).ready(function() { $("#startFromExistingSOAPEndpoint").click(function(){ var wsdlURL = $('#wsdl-url').val(); - if (wsdlURL.trim() == "" || wsdlURL.toLowerCase().indexOf("wsdl") < 0) { + var wsdlFile = $('#wsdl-file').val(); + if ( wsdlFile.trim() == "" && (wsdlURL.trim() == "" || wsdlURL.toLowerCase().indexOf("wsdl") < 0)) { $('#wsdl-url').addClass('error'); $('.wsdlError').show(); console.log("Wrong endpoint."); @@ -231,6 +232,18 @@ $( document ).ready(function() { }); }); + $('input[type=radio][name=wsdl-options-select]').change(function() { + if(this.value === 'url') { + $('#wsdl-url-section').show(); + $('#wsdl-file-section').hide(); + $('input[name=soap-options-rest]').attr("disabled",false); + } else if(this.value === 'archive') { + $('#wsdl-url-section').hide(); + $('#wsdl-file-section').show(); + $('input[name=soap-options-rest]').attr("disabled",true); + } + }); + $('.toggleContainers .controls').hide(); $('.toggleRadios input[type=radio]').prop('checked', false); $('.toggleRadios input[type=radio]').click(function(){ diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-add/template.jag b/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-add/template.jag index 11a0b8a6b..f4c7cdb05 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-add/template.jag +++ b/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-add/template.jag @@ -95,11 +95,36 @@
"> +
+
+ + +
+
-
+
+
diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-design/js/api-design.js b/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-design/js/api-design.js index bb7cacd26..67d472ee1 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-design/js/api-design.js +++ b/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-design/js/api-design.js @@ -154,15 +154,17 @@ function APIDesigner(){ if(this.soap_resource_created == undefined){ var soapRestMapping = JSON.parse($('#sequenceMapping').val()); var soapRestOutMapping = JSON.parse($('#sequenceOutMapping').val()); - var resourceDetails = $.trim($(this).parent().text().replace(/[\t\n]+/g,'')); - resourceDetails = resourceDetails.replace(/\s/g,''); - var method = resourceDetails.substring(0, resourceDetails.indexOf("/")); - var path = resourceDetails.substring(resourceDetails.indexOf("/") + 1, resourceDetails.indexOf("+")); - var key = path + "_" + method; - var inSeqContent = soapRestMapping[key].content; - var outSeqContent = soapRestOutMapping[key].content; - event.data.render_soap_to_rest_resource($(this).parent().next().find('.resource_body'), inSeqContent, outSeqContent, key); - this.soap_resource_created = true; + var resourceDetailsArr = $(this).parent().data("path").split("."); + if(resourceDetailsArr.length > 3) { + var method = resourceDetailsArr[3]; + var path = resourceDetailsArr[2].substring(1); + var key = path + "_" + method; + var inSeqContent = soapRestMapping[key].content; + var outSeqContent = soapRestOutMapping[key].content; + event.data.render_soap_to_rest_resource($(this).parent().next().find('.resource_body'), inSeqContent, + outSeqContent, key); + this.soap_resource_created = true; + } $(this).parent().next().find('.resource_body').show(); } else{ @@ -289,7 +291,7 @@ APIDesigner.prototype.check_if_resource_exist = function(path, method){ } APIDesigner.prototype.load_api_base_document = function (api_doc_version) { - if (api_doc_version == supportedOpenAPI3Version){ + if (this.is_supported_openapi_version(api_doc_version)){ this.load_api_document(openapi3_api_doc); } else{ this.load_api_document(swagger2_api_doc); @@ -298,7 +300,7 @@ APIDesigner.prototype.load_api_base_document = function (api_doc_version) { APIDesigner.prototype.is_openapi3 = function () { var isOpenAPI3 = false; - if (this.api_doc.openapi != undefined && this.api_doc.openapi == supportedOpenAPI3Version) { + if (this.api_doc.openapi != undefined && this.is_supported_openapi_version(this.api_doc.openapi.trim())) { isOpenAPI3 = true; } return isOpenAPI3; @@ -332,6 +334,11 @@ APIDesigner.prototype.add_default_resource = function(){ $("#add_resource").trigger('click'); } +APIDesigner.prototype.is_supported_openapi_version = function (version) { + // support for 3.0.x versions + return /^3\.0\.\d{1,}$/.test(version); +} + APIDesigner.prototype.get_scopes = function() { var options = [{ "value": "" , "text": "" }]; if (this.api_doc != undefined) { @@ -527,7 +534,8 @@ APIDesigner.prototype.init_controllers = function(){ var paramName = API_DESIGNER.api_doc.paths[operations][operation]['parameters'][i]['name']; // @todo: param_string - jagg.message({content: 'Do you want to delete the parameter ' + paramName + ' ?', + jagg.message({content: 'Do you want to delete the parameter ' + + Handlebars.Utils.escapeExpression(paramName) + ' ?', type: 'confirm', title: i18n.t("Delete Parameter"), okCallback: function () { API_DESIGNER = APIDesigner(); @@ -1136,7 +1144,19 @@ APIDesigner.prototype.render_resource = function(container){ }; APIDesigner.prototype.query = function(path){ - return JSONPath(path, this.api_doc); + var operation = JSONPath(path, this.api_doc); + // Check for $ref element in all available parameters and resolve to actual definition else return inline definition + if (operation[0].parameters) { + operation[0].parameters = operation[0].parameters.map(function (param) { + if (param["$ref"] !== undefined) { + return this.query(param["$ref"].replace("#","$").replace(/\//g,"."), this.api_doc)[0]; + } else { + return param; + } + }.bind(this)); + } + + return operation; } APIDesigner.prototype.add_resource = function(resource, path){ @@ -1378,6 +1398,7 @@ $(document).ready(function(){ title: i18n.t("Resource not specified"), anotherDialog:true, okCallback:function(){ + $('#messageModal').modal('hide'); var designer = APIDesigner(); designer.add_default_resource(); $("#design_form").submit(); @@ -1494,6 +1515,17 @@ $(document).ready(function(){ output.src = URL.createObjectURL(this.files[0]); } }); + + if($("#wsdl").val()) { + var wsdlInputVal = $("#wsdl").val(); + if(wsdlInputVal.endsWith(".zip")) { + $("#fileUploadSection").show(); + $("#wsdlurlInputSection").hide(); + + } else { + $("#fileUploadSection").hide(); + } + } }); var thisID; @@ -1629,7 +1661,7 @@ var getSoapToRestPathMap = function () { var designer = new APIDesigner(); designer.load_api_document(swagger2_api_doc); $("#wsdl-content").hide(); - $(".resource_create").hide(); + $(".resource_create").show(); $('#resource_details').show(); $('#soap-swagger-editor').show(); isSoapView = true; diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-design/template.jag b/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-design/template.jag index 66ba6673a..c1fd957b5 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-design/template.jag +++ b/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-design/template.jag @@ -113,6 +113,9 @@ id="design_form" enctype="multipart/form-data" action="<%= jagg.url("/site/blocks/item-design/ajax/add.jag?" + apiUrlId ) %>"> + <% if (session.get("paths")) {%> + + <%}%>
@@ -391,6 +394,7 @@ <% if(session.get("wsdl") || ( api && api.wsdl )) { var wsdl = session.get("wsdl"); + var wsdlFile = session.get("wsdl-file"); if(api && api.wsdl){ wsdl = api.wsdl; } @@ -412,10 +416,27 @@
- -
- -
+
+ +
+ +
+
+ + + + +
@@ -423,7 +444,9 @@ - + <% if (api && api.wsdl && api.templates[0][0] != "/*") {%> + + <% } %> @@ -832,20 +855,22 @@ {{#each doc.paths}} {{# each this}} - - - - - - - + {{#if this.responses}} + + + + + + + + {{/if}} {{/each}} {{/each}}
- {{ @key }} - {{ path }}{{ summary }} - - - - -
+ {{ @key }} + {{ path }}{{ summary }} + + + + +
@@ -861,9 +886,9 @@ var designer = APIDesigner(); designer.load_api_document(data); $("#swaggerUpload").modal('hide'); - if(typeof $("#rest-paths").val() != "undefined" && $("#rest-paths").val() != "null") { + if ($("#soapToRestCheck").val() === "true") { $("#wsdl-content").hide(); - $(".resource_create").hide(); + $(".resource_create").show(); $('#resource_details').show(); $('#soap-swagger-editor').show(); isSoapView = true; diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-implement/js/api-implementation.js b/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-implement/js/api-implementation.js index 3f75ad5c0..68998aec4 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-implement/js/api-implementation.js +++ b/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-implement/js/api-implementation.js @@ -254,9 +254,18 @@ $(document).ready(function(){ }); }); $("#prototype_form").submit(); - return false; - }); - + return false; + }); + + $("#savePrototypeBtn").click(function(e){ + var n = noty({ + theme: 'wso2', + text: $('#save-prototype-success').text(), + layout:'top', + type:'success', + timeout : '1000' + }); + }); if( $("#toggleCorsPrototyped").attr('checked') ) { $('#corsTablePrototyped').show(); @@ -298,7 +307,7 @@ $(document).ready(function(){ else { $('#toggleSequence').parent().next().hide(); } - + $('#upload_sequence').attr('disabled','disabled'); $('.toggleRadios input[type=radio]').click(function(){ if (typeof jsonFile != 'undefined') { @@ -318,7 +327,7 @@ $(document).ready(function(){ }); $('#upload_sequence').click(function () { - + $('#upload_sequence').buttonLoader('start'); var type = $(".modal-body #flow_id").val(); uploadSequence(type); @@ -427,7 +436,6 @@ var hideMsg = function () { $('#apiSaved').hide("slow"); } - function showGatewayFailure(message) { if (message.split("||")[1] == "warning") { var environmentsFailed = JSON.parse(message.split("||")[0]); @@ -461,7 +469,7 @@ function showGatewayFailure(message) { } else { - jagg.message({content: responseText.message, type: "error"}); + jagg.message({content: message, type: "error"}); } } diff --git a/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-implement/template.jag b/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-implement/template.jag index 28b6ebb8c..caf6a8278 100644 --- a/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-implement/template.jag +++ b/components/jaggery-apps/publisher/src/main/publisher/site/themes/wso2/templates/item-implement/template.jag @@ -761,7 +761,7 @@
- +
@@ -888,6 +888,16 @@
+ +