@open-xchange/vite-plugin-proxy v0.9.2
@open-xchange/vite-plugin-proxy
An OX App Suite specific proxy for development purposes. Can connect multiple vite-dev-servers with @open-xchange/vite-plugin-ox-manifests plugins.
Install
pnpm i "@open-xchange/vite-plugin-proxy"
Options
You can provide the following options to the plugin:
proxy
An object with reverse proxy configurations, where the keys need to match the beginning of the path. Usually used to forward /api requests to a backend.
- proxykey
<string>
The key defines which paths should be proxied. Keys starting with^
will be treated as regular expressions. - proxykey.target
<string>
The target where to forward these requests to. - proxykey.ws
<boolean>
If ws is true, this will only listen to upgrade events for a websocket. Default:false
- proxykey.rewrite
<function>
A function that receives the path as parameter and returns the new path to proxy. - proxykey.prependPath
<string>
A string that is prepended for every request. If prependPath and rewrite are present, the key is first prepended and then rewrite is called. - proxykey.changeOrigin
<boolean>
Changes the origin of the host header to the target URL. Default:false
- proxykey.secure
<boolean>
Set to false to allow self-signed certificates. Default:true
frontends
An array of objects with frontends to proxy to. A frontend is defined as a server with UI-files and a /manifest
endpoint. Every vite-dev server with the @open-xchange/vite-plugin-manifest
plugin fullfills this requirement. This plugin will always add the current vite-dev server as the first entry into this array such that serving files from the local machine has always the highest priority.
- frontendsi.target
<string>
The target, where to forward requests to. - frontendsi.path
<string>
Optional parameter which will prioritize this frontend for the given path. Is like a reverse proxy configuration for frontends. To indicate a regexp, start the string with a^
. - frontendsi.secure
<boolean>
Set to false to allow self-signed certificates. Default:true
httpProxy
An object for a http proxy to be ususally used with tools like Switchy Omega
- httpProxy.target
<string>
The domain which is handled by the vite proxy. You need to make sure, that the proxy configuration is set accordingly. - httpProxy.port
<number>
The port on which the httpProxy server will listen for requests. Default8080
logLevel
One of fatal
, error
, warn
, info
, debug
, trace
, silent
. Default: warn
Example configuration
vitePluginProxy({
proxy: {
'/api': {
target: 'https://path.to.my.middleware/',
prependPath: '/appsuite',
rewrite: path => path.replace(/\/v1\//, '/v2/'),
changeOrigin: true
},
'/socket.io/appsuite': {
target: `wss://path.to.my.middleware/socket.io/appsuite`,
ws: true,
changeOrigin: true,
secure: false
}
},
frontends: [{
target: 'https://localhost:3000',
path: '/io.ox/guidedtours',
secure: false
}, {
target: 'https://localhost:3001',
path: '/io.ox/customplugin',
}],
logLevel: 'info'
}),
4 months ago
5 months ago
5 months ago
3 months ago
4 months ago
12 months ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago