AppSuite:Appserver: Difference between revisions
|  (Created page with "{{Stability-unstable}}  <div class="title">Appserver</div>  The <code>appserver</code> tool is used to develop and test the OX App Suite UI and its plugins with a remote backe...") |  (added categories) | ||
| Line 104: | Line 104: | ||
| Specifies the path to the zoneinfo database. On POSIX systems, the default of <code>/usr/share/zoneinfo/</code> should always work. Even on systems without the database everything should just work if <code>[[#server|--server]]</code> is specified, since any missing files will be fetched from the remote server. This option may still be useful when debugging time zone problems caused by different versions of the zoneinfo database. | Specifies the path to the zoneinfo database. On POSIX systems, the default of <code>/usr/share/zoneinfo/</code> should always work. Even on systems without the database everything should just work if <code>[[#server|--server]]</code> is specified, since any missing files will be fetched from the remote server. This option may still be useful when debugging time zone problems caused by different versions of the zoneinfo database. | ||
| [[Category:AppSuite]] | |||
| [[Category:UI]] | |||
| [[Category:Developer]] | |||
Revision as of 07:09, 28 June 2013
API status: New
The appserver tool is used to develop and test the OX App Suite UI and its plugins with a remote backend. appserver acts as a reverse HTTP proxy for an existing OX App Suite installation and injects the tested JavaScript code in its replies.
Installation
The core of appserver is a Node.js script, so if your OS does not provide a nodejs package, you will have to install it manually, either as a 3rd party package or directly from nodejs.org.
The installation of the script itself depends on whether you want to make changes to the UI or only develop an external app.
For app developers
If you are developing an app, then you only need the OX App Suite SDK version 7.4 or later. On Linux, it is installed with the package open-xchange-appsuite-dev:
sudo apt-get install open-xchange-appsuite-dev
The binaries are installed to /opt/open-xchange-appsuite-dev/bin/. To have them available in a shell, add this directory to the PATH environment variable:
export PATH=$PATH:/opt/open-xchange-appsuite-dev/bin
For UI developers
If you are a UI developer, or if the SDK is not available for your OS, you will need to clone the UI source and use the tools contained in the ui/bin directory.
git clone https://code.open-xchange.com/git/wd/frontend/web export PATH=$PATH:$(pwd)/web/ui/bin
Standalone use
In the simplest case of developing an app or a plugin, all that is needed is an existing OX App Suite installation. Point appserver to the URL of OX App Suite and to the build directory of your app. Assuming you are in the top directory of your app's source code and $builddir is not set:
appserver --server=https://www.ox.io/appsuite/ build
If there are no errors, you can point your browser to http://localhost:8337/appsuite/ to test a version of OX App Suite which includes your app. You do not need to restart anything after re-building the app, a refresh of the browser page should be enough.
Use with Apache
For more complex cases involving testing your own build of the UI, or apps which include static resources (e. g. images), a local web server is needed to serve these static resources. The following examples use the Apache HTTP Server, but any web server which can act as a reverse HTTP proxy should work (assuming the configuration and .htaccess files are adapted, of course).
First, the app or the UI is configured to build into Apache's document root, using the same directory as used by your OX App Suite server (usually appsuite/). Either symlinking the directory or setting $builddir will work. Since the latter requires granting your user write permissinos on the document root (not the appsuite directory, since it gets deleted by build-appsuite clean), symlinking might be somewhat safer. Assuming the document root is /var/www, and you are in the top directory of the app source:
sudo ln -s $(pwd)/build /var/www/appsuite
Second, configure Apache to request from appserver anything that it can't find locally. This configuration requires at least mod_rewrite and mod_proxy to be enabled. Add the following inside an eventual <VirtualHost> directive, but outside of any <Directory> directives:
RewriteEngine on
RewriteCond %{DOCUMENT_ROOT}%{REQUEST_FILENAME} !-f
RewriteRule ^/(.*)$ http://localhost:8337/$1 [NE,P]
Now, restart Apache and start appserver.
sudo apachectl restart appserver --server=https://www.ox.io/appsuite/ /var/www/appsuite
If there are no errors, you can point your browser to http://localhost/appsuite/ to test a version of OX App Suite which includes your app. You do not need to restart anything after re-building the app, a refresh of the browser page should be enough.
Reference
appserver is a reverse HTTP proxy. It accepts HTTP requests and forwards most of them to another HTTP server. There are currently two exceptions:
- api/apps/loadis served from a list of local paths. Only files which could not be found are fetched from the remote HTTP server. This allows to inject the code of a tested app without installing it on the remote server. The list of paths is specified as non-option parameters on the command line. Each path should normally have at least the subdirectories- appsand- manifests. Each injected file is looked up in the- appssubdirectory of each path, in the order in which they appear on the command line, and the first found file is used. If a file is not found in any path, and the- --serveroption is specified, the file is downloaded from the server.
- api/apps/manifests?action=configis extended by local manifests. This is necessary to enable the tested app in the UI. If no- --manifestsoptions are specified, then all files from the- manifestssubdirectory of each path are combined and added to the manifests from the remote server. Each manifest entry overrides any entries with the same- pathattribute. Similar to the priority for files, manifest entries from earlier paths override entries from later paths, and local entries override remote entries.
help
Displays a short summary of available options:
Usage: appserver [OPTION]... [PATH]...
  -h,      --help           print this help message and exit
  -m PATH, --manifests=PATH add manifests from the specified path (default:
                            the "manifests" subdirectory of every file path)
  -p PORT, --port=PORT      listen on PORT (default: 8337)
  -s URL,  --server=URL     use an existing server as fallback
  -v,      --verbose        print all files and URLs, not only errors
  -z PATH, --zoneinfo=PATH  use timezone data from the specified path
                            (default: /usr/share/zoneinfo/)
Files are searched in each PATH in order and requested from the server if not
found. If no paths are specified, the default is /var/www/appsuite/.
manifests
By default, the manifests of an app are collected and put into $builddir/manifests. Therefore, by default, appserver collects manifests from the manifests subdirectoriy of each file path. Since the destination directory for manifests can be changed by setting $manifestDir, the manifest directories can also be changed in appserver by specifying each directory with a separate --manifests option.
If at least one --manifests option is specified, the default file paths are not used for manifests at all.
port
Specifies the port to listen on. The default is 8337. This option might be useful to run multiple instances of appserver at once or when port 8337 is already in use.
server
Specifies the URL of an existing OX App Suite installation. The URL must start with http:// or https://. To make forwarding of an HTTPS URL over HTTP possible, appserver removes the Secure attribute from all cookies set by the server.
This option is required for manifest injection to work, since the intercepted request contains more data than just the manifests.
verbose
Enables verbose output. During normal operation, appserver only prints errors to its console. When this options is specified, every injected file, manifest, and every HTTP request to the server is also printed. Client requests which result in multiple local files being read are separated by an empty line.
zoneinfo
Specifies the path to the zoneinfo database. On POSIX systems, the default of /usr/share/zoneinfo/ should always work. Even on systems without the database everything should just work if --server is specified, since any missing files will be fetched from the remote server. This option may still be useful when debugging time zone problems caused by different versions of the zoneinfo database.