-
Notifications
You must be signed in to change notification settings - Fork 40
Home
MXCuBE-WEB is the latest generation of the data acquisition software MXCuBE. It is developed as a web application and runs in any recent browser. The application is built using standard web technologies and does not require any third party plugins to be installed in order to function. Being a web application, it's naturally divided into a server and client part. The communication between the client and server are made using HTTP/HTTPS and web-sockets. It's strongly recommended to use HTTPS, SSL/TLS encrypted HTTP. The traffic passes through the conventional HTTP/HTTPS ports minimizing the need for special firewall or proxy settings to get the application to work.
The underlying beamline control layer is implemented using the library mxcubecore previously known as HardwareRepository. The mxcubecore module is compatible with both MXCuBE3 also known as MXCuBE-Web and the MXCuBE-Qt application. The earlier versions of MXCuBE3 (upto 3.2.x) uses HardwareRepository while versions after 4.x uses mxcubecore.
The install instructions for version 3 of MXCUBE-WEB can be found here (instructions 3.x)
The install instructions for version 4 can be found below.
We recommend using conda to create an isolated environment, conda can be downloaded here. All Python 3.x versions are supported.
1. Create a folder containing both mxcube-web and mxcubecore for instance
mkdir mxcube
cd mxcube
2. Clone mxcube-web and mxcubecore
git clone https://github.com/mxcube/mxcube3.git
git clone https://github.com/mxcube/mxcubecore.git
**3. Install all the dependencies ** The name of the environment are located at the top of the file conda-envrionment.yml. This can be changed if needed. This will take a few minutes
conda env create -f conda-envrionment.yml
4. Activate the environment
conda activate mxcube
If you just want to test the application and not perform any development skip a head to point 5. On the other hand you need the complete development environment inorder to develop.
To install the development and build tools for the Javascript front end. The switch --legacy-peer-deps is still needed to run everything correctly with the latest version of node. This switch can soon be removed.
D1. Install development environment
cd mxcube3/ui
npm install --legacy-peer-deps
D2. For a production build (recommended for just exploring the application)
npm run build
D3. Development build (recommended for developers)
npm run start
5. Run the mxcube server Make sure to be in the mxcube3 root folder
./mxcube3-server -r test/HardwareObjectsMockup.xml/ --static-folder ./ui/build/
For the production build open your browser and navigate to localhost:8081
google-chrome localhost:8081
For the development build open your browser and navigate to localhost:3000
google-chrome localhost:3000
All that is needed to run the application is to start the server and point your browser to http://localhost:8081, which will serve the prebuilt client (if any). The client is not built if nothing appears or you get a "404 page not found" error when browsing localhost:8081. Follow the steps in running the client to build a client or to run a development version of the client
./mxcube3-server -r test/HardwareObjectsMockup.xml/ --static-folder ./ui/build/
2018-07-09 11:41:56,208 |queue_exec|INFO | Module load, probably application start
2018-07-09 11:41:56,208 |INFO | Module load, probably application start
2018-07-09 11:41:56,338 |HWR |INFO | initializing camera object
.
.
.
2018-07-09 11:41:56,503 |HWR |INFO | Registering function Native.queue_update_result as XML-RPC function queue_update_result
2018-07-09 11:41:56,507 |HWR |INFO | Coult not initialize video from /dev/video1, error was: Cannot open video device /dev/video1, path do not exist. Make sure that the v4l2loopback kernel module is loaded (modprobe v4l2loopback). Falling back to MJPEG.
2018-07-09 11:41:56,508 |HWR |INFO | MXCuBE 3 initialized, it took 0.4 seconds
Install the necessary dependencies by issuing:
npm install
And then, run webpack in development mode:
npm start
Open a web browser a go to http://localhost:8090.
Or for generating a production bundle:
npm run build
Open a web browser a go to http://localhost:8081.