Webix Jet and Cross-origin resource sharing

Hi all

How can i enable Webix Jet to do Cross-origin resource sharing ?

Thanks in advance

if you have a problem with Access-Control-Allow-Origin header, then you have to make some adjustments related to CORS on server side.

the rest part is same as normal ajax requests.

Hi and thanks for you reply

i tried to follow this link node.js - Why doesn't adding CORS headers to an OPTIONS route allow browsers to access my API? - Stack Overflow and would have found this for example this code :smile:
“var cors = require(‘cors’)
var app = express()
app.use(cors())”

But i don’t know which file i have to change webpack.config.js ? or other

thanks in advance

what is your backend (OS, framework)?

Hi
i have installed Webix Jet in Ibm i (AS400) that run NodeJs V6.9.1
thanks

Hi
I Have tried to insert webpack.config.js file (at the end) this line:
"devServer: { headers: { ‘Access-Control-Allow-Origin’ } } " , but the error remains.

Instead if i insert this line:
"devServer: { headers: { ‘Access-Control-Allow-Origin’: '* ’ } } " ,
when i run npm start, i receive this error:
“devServer: { headers: { ‘Access-Control-Allow-Origin’: '* ’ } }
SyntaxError: Unexpected token :
at Object.exports.runInThisContext (vm.js:76:16)
…”

Thanks …
P.S. where i can find documentation how to customize webpack server?

devServer: {
    ...
    headers: {
        'Access-Control-Allow-Origin': '*',
        'Access-Control-Allow-Credentials': 'true' //just in case
    }
}

should work

Hi integral …

many thanks for your reply, but the problem remains !!

anyother idea?

thanks in advance

here my complete webpack.config.js

var path = require(“path”);
var webpack = require(“webpack”);

module.exports = function(env) {

var pack = require("./package.json");
var ExtractTextPlugin = require("extract-text-webpack-plugin");
var production = !!(env && env.production === "true");
var babelSettings = {
	extends: path.join(__dirname, '/.babelrc')
};

var config = {
	entry: "./sources/myapp.js",
	output: {
		path: path.join(__dirname, "codebase"),
		publicPath:"/codebase/",
		filename: "myapp.js"
	},
	devtool: "inline-source-map",
	module: {
		rules: [
			{
				test: /\\.js$/,
				loader: "babel-loader?" + JSON.stringify(babelSettings)
			},
			{
				test: /\\.(svg|png|jpg|gif)$/,
				loader: "url-loader?limit=25000"
			},
			{
				test: /\\.(less|css)$/,
				loader: ExtractTextPlugin.extract("css-loader!less-loader")
			}
		]
	},
	resolve: {
		extensions: [".js"],
		modules: ["./sources", "node_modules"],
		alias:{
			"jet-views":path.resolve(__dirname, "sources/views"),
			"jet-locales":path.resolve(__dirname, "sources/locales")
		}
	},
	
	devServer: {
	      headers: {
	          'Access-Control-Allow-Origin': '*',
	          'Access-Control-Allow-Credentials': 'true' //just in case
	      }
	  }, 
	
	plugins: [
		new ExtractTextPlugin("./myapp.css"),
		new webpack.DefinePlugin({
			VERSION: `"${pack.version}"`,
			APPNAME: `"${pack.name}"`,
			PRODUCTION : production
		})
	]
	  


};

if (production) {
	config.plugins.push(
		new  webpack.optimize.UglifyJsPlugin({
			test: /\\.js$/
		})
	);
}

console.log('Config--> ' ,  config);

return config;

}

Hi

Solved not to take account of my last message

thanks for your time / help

Hi giocot,

I guess you want your Jet App (which is served by webpack on port 8080) send AJAX/REST requests to your server running on another port (let’s say 8081) and providing data, that should be displayed in a webix widget. Is this correct? Then you need to change configuration in your server script, not in webpack.

Assuming your server is written in node, a very basic script would be:

var Express = require(‘Express’);
var app = new Express;
// CORS Header
app.use( function(request,response,next) {
response.header(“Access-Control-Allow-Origin”, “*”);
response.header(“Access-Control-Allow-Headers”, “Origin, X-Requested-With, Content-Type, Accept”);
next();
});
// API
app.get(’/endpoint’, function(request,response) { … });
app.post(’/endpoint’, function(request,response) { … });

app.listen(8081);