@ytsaurus/ui v1.84.0
YTsaurus platform interface
User interface for a YTsaurus platform cluster.
How to work with the repo
First of all you have to provide clusters-config.json file with description of your cluster, the file should be placed in the root of the repository (see clusters-config.json.example).
Additionally you have to provide secrets/yt-interface-secret.json file with a token of a special user (UIRobot) for some service requests like handling settings and other, example:
{
  // common oauth token, the token is used if there is no cluster-specific token in the file
  "oauthToken": "special-user-secret-tocken",
  "cluster_id1": {
    // cluster_id1 specific oauth token
    "oauthToken": "cluster1-special-user-secret-token"
  },
  "cluster_id2": {
    // cluster_id2 specific oauth token
    "oauthToken": "cluster2-special-user-secret-token"
  }
}Development
To run the development environment you need to prepare and run nginx:
- Install nginx
- Copy file deploy/nginx/yt.development.conf.exampleto/etc/nginx/sites-enabled/yt.development.conf
- Modify /etc/nginx/sites-enabled/yt.development.conf- change server_name
- replace all /path/to/the/repoto correct path
 
- change 
- sudo systemctl restart nginx
Install required dependencies:
$ npm deps:installA simple way to start development is using your local-yt cluster. The command bellow suggests to start local-yt cluster as docker-container:
$ npm run dev:localmodeAnother way is to provide clusters-config.json and run the command like:
$ npm run dev:appDevelopment without nginx
You also could run application without nginx, right on localhost port. All that you need to do is specify port:
LOCAL_DEV_PORT=8080 YT_AUTH_ALLOW_INSECURE=true ALLOW_PASSWORD_AUTH=true npm run dev:ossDocker
There is ability to build docker-image:
$ docker build . -t ytsaurus-ui:my-tagAll application files in a resulting docker-image will be placed in /opt/app, so you have to mount /opt/app/cluster-config.json and /opt/app/secrets/yt-interface-secret.json.
Environment variables
- YT_AUTH_ALLOW_INSECURE- if defined allows insecure (over http) authentication, do not use it for production
- ALLOW_PASSWORD_AUTH- If defined, the app requires a password for cluster access
Feature flags
There is yt-api command get_supported_feature and it is a good place to describe some features. But some cases require ability to turn on/off a feature manually on a cluster. Such feature flags are placed placed in:
- //sys/@ui_config(values affects all users)
- //sys/@ui_config_dev_overrides(values affects only developers)
(see more detail in YTFRONT-2804)
It is supposed that a user is developer on a cluster if he has write access to admins group of the cluster.
Available flags (default values are highlighted in bold):
| Flag name | Allowed values | Description | 
|---|---|---|
| enable_per_bundle_tablet_accounting | true, false | Allows editing of resources of tablets through BundleEditorDialog YTFRONT-2851 | 
| enable_per_account_tablet_accounting | false, true | Allows editing of resources of tablets through AccountEditorDialog YTFRONT-2851 | 
| per_bundle_accounting_help_link | null, url as string | Help link for resources of tablets to display from AccountEditorDialog about moving the resources to bundles YTFRONT-2851 | 
| enable_maintenance_api_nodes | null, boolean | Allows to use add_maintenance/remove_maintenancecommands fromComopnents/Nodespage YTFRONT-3792 | 
| enable_maintenance_api_proxies | null, boolean | Allows to use add_maintenance/remove_maintenancecommands fromComponents/HTTP ProxiesandComponents/RPC Proxiespages YTFRONT-3792 | 
| chyt_controller_base_url | null, url as string | Base url for chyt-controller | 
| livy_controller_base_url | null, url as string | Base url for spyt-controller | 
| job_trace_url_template | null, {title: string; url_template: string; enforce_for_trees?: Array<string>} | If defined adds Job traceitem to meta-table onJob/Detailspage for a job witharchive_features/has_trace == trueand for jobs from a tree inenforce_for_trees, example:{title: 'Open im MyProfiling', url_template: 'https://my.profiling.service/{cluster}/{operationId}/{jobId}', enforce_for_trees: ['tree-with-traces'] } | 
| query_tracker_default_aco | null, {stage1: string; stage2: string; } | Sets the default ACO in Query Tracker requests for each stage | 
Configuration
By default the application uses base configuration from path_to_dist/server/configs/common.js file. The behavior might be adjusted through APP_ENV and APP_INSTALLATION environment variables, see README.config.md for more details.
Migration
v1.17.0
- YT_AUTH_CLUSTER_IDenvironment variable has been replaced by- ALLOW_PASSWORD_AUTH.
- config.ytAuthClusteroption has been replaced by- config.allowPasswordAuth.
How to run e2e on local machine
Here is an example of run & update of screenshot tests:
# Prerequsites: install docker and YTsaurus CLI
# https://www.docker.com/products/docker-desktop/
# https://ytsaurus.tech/docs/en/api/cli/install
# Terminal 1: launch local dev mode on 8080 port
LOCAL_DEV_PORT=8080 npm run dev:localmode:e2e
# Terminal 2: init local cluster
npm run e2e:localmode:init
# Terminal 2: mount repo in docker image and prepare everyting for tests run
# Make sure that you specify correct BASE_URL for e2e tests
# For linux use http://localhost:8080
# For macos use http://host.docker.internal:8080
print "Enter base url of your development stand: "; \
read BASE_URL; \
docker run --rm --network host -it -w /work \
    -v $(pwd):/work \
    -e BASE_URL=${BASE_URL} \
    "ghcr.io/gravity-ui/node-nginx:ubuntu20-nodejs18" \
    /bin/bash -c '
            cd tests 
            npm ci 
            npx playwright install --with-deps chromium
            cd ..
            npm run e2e:localmode:screenshots:update
'7 months ago
8 months ago
9 months ago
9 months ago
8 months ago
8 months ago
8 months ago
8 months ago
9 months ago
10 months ago
10 months ago
10 months ago
10 months ago
11 months ago
11 months ago
11 months ago
11 months ago
11 months ago
11 months ago
11 months ago
12 months ago
11 months ago
11 months ago
12 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
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year 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
2 years 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
2 years 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
2 years 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
2 years 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
2 years 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
2 years 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
2 years 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
2 years 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
2 years 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
2 years ago
2 years ago
2 years ago
2 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago