mirror of
https://thingvellir.net/git/overte
synced 2025-03-27 23:52:03 +01:00
2139 lines
79 KiB
JSON
2139 lines
79 KiB
JSON
{
|
|
"version": 2.7,
|
|
"settings": [
|
|
{
|
|
"name": "metaverse",
|
|
"label": "Networking / Directory Services",
|
|
"settings": [
|
|
{
|
|
"name": "access_token",
|
|
"label": "Access Token",
|
|
"help": "This is your OAuth access token to connect this domain-server with your Directory Services account. <br/>It can be generated by clicking the 'Connect Account' button above.<br/>You can also go to the Security page of your account on your Directory Server and generate a token with the 'domains' scope and paste it here.",
|
|
"advanced": true,
|
|
"backup": false
|
|
},
|
|
{
|
|
"name": "id",
|
|
"label": "Domain ID",
|
|
"help": "This is your Directory Services domain ID. If you do not want your domain to be registered in the Directory Services you can leave this blank.",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "automatic_networking",
|
|
"label": "Automatic Networking",
|
|
"help": "This defines how other users will be able to reach your domain-server.<br/>If you don't want to deal with any network settings, use full automatic networking.",
|
|
"default": "full",
|
|
"type": "select",
|
|
"options": [
|
|
{
|
|
"value": "full",
|
|
"label": "Full: update both the IP address and port to reach my server"
|
|
},
|
|
{
|
|
"value": "ip",
|
|
"label": "IP Only: update just my IP address, I will open the port manually"
|
|
},
|
|
{
|
|
"value": "disabled",
|
|
"label": "None: use the network information I have entered for this domain at the Directory Server."
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "local_port",
|
|
"label": "Local UDP Port",
|
|
"help": "This is the local port your domain-server binds to for UDP connections.<br/>Depending on your router, this may need to be changed to unique values for each domain-server in order to run multiple full automatic networking domain-servers in the same network. You can use the value 0 to have the domain-server select a random port, which will help in preventing port collisions.",
|
|
"default": "40102",
|
|
"type": "int",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "enable_packet_verification",
|
|
"label": "Enable Packet Verification",
|
|
"help": "Enable secure checksums on communication that uses the Directory Services protocol. Increases security with possibly a small performance penalty.",
|
|
"default": true,
|
|
"type": "checkbox",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "enable_metadata_exporter",
|
|
"label": "Enable Metadata HTTP Availability",
|
|
"help": "Allows your domain's metadata to be accessible on the public internet via direct HTTP connection to the domain server.",
|
|
"default": false,
|
|
"type": "checkbox",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "metadata_exporter_port",
|
|
"label": "Metadata Exporter HTTP Port",
|
|
"help": "This is the port where the Metadata exporter accepts connections. It listens both on IPv4 and IPv6 and can be accessed remotely, so you should make sure to restrict access with a firewall as needed.",
|
|
"default": "9704",
|
|
"type": "int",
|
|
"advanced": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"label": "Networking / Crash Reporting",
|
|
"name": "crash_reporting",
|
|
"restart": true,
|
|
"assignment-types": [ 0, 1, 3, 4, 5, 6 ],
|
|
"settings": [
|
|
{
|
|
"name": "enable_crash_reporter",
|
|
"label": "Enable Crash Reporter",
|
|
"help": "Enable the automatic submission of crash reports to Overte e.V. This will help us find bugs and improve the code. Crash data will only be shared with developers trusted by Overte e.V., and will only be used to aid in development.",
|
|
"default": false,
|
|
"type": "checkbox",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "custom_crash_url",
|
|
"label": "Custom crash URL",
|
|
"help": "If this is set, it overrides the internal crash reporting URL. This can be used for instance to direct crash reports to Sentry.",
|
|
"default": "",
|
|
"type": "string",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "custom_crash_token",
|
|
"label": "Custom crash token",
|
|
"help": "This is a token that identifies the thing sending a crash report, such as a product name and version number. If not set, the compile time default will be used.",
|
|
"default": "",
|
|
"type": "string",
|
|
"advanced": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "webrtc",
|
|
"label": "Networking / WebRTC",
|
|
"settings": [
|
|
{
|
|
"name": "enable_webrtc",
|
|
"label": "Enable WebRTC Client Connections",
|
|
"help": "Allow web clients to connect over WebRTC data channels.",
|
|
"type": "checkbox",
|
|
"default": false,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "enable_webrtc_websocket_ssl",
|
|
"label": "Enable WebRTC WebSocket SSL",
|
|
"help": "Use secure WebSocket (wss:// protocol) for WebRTC signaling channel. If \"on\", the key, cert, and CA files are expected to be in the local Overte app directory, in a /domain-server/ subdirectory with filenames overte-cert.key, overte-cert.crt, and overte-crt-ca.crt.",
|
|
"type": "checkbox",
|
|
"default": false,
|
|
"advanced": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "authentication",
|
|
"label": "Networking / WordPress OAuth2",
|
|
"settings": [
|
|
{
|
|
"name": "enable_oauth2",
|
|
"label": "Enable OAuth2 Authentication",
|
|
"help": "Allow a WordPress-based (miniOrange) OAuth2 service to assign users to groups based on their role with the service.",
|
|
"default": false,
|
|
"type": "checkbox",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "oauth2_url_path",
|
|
"label": "Authentication URL",
|
|
"help": "The URL that the Interface will use to login via OAuth2.",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "wordpress_url_base",
|
|
"label": "WordPress API URL Base",
|
|
"help": "The URL base that the domain server will use to make WordPress API calls. Typically \"https://oursite.com/wp-json/\". However, if using non-pretty permalinks or otherwise get a 404 error then try \"https://oursite.com/?rest_route=/\".",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "plugin_client_id",
|
|
"label": "WordPress Plugin Client ID",
|
|
"help": "This is the client ID from the WordPress plugin configuration.",
|
|
"advanced": true,
|
|
"backup": false
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"label": "Monitoring",
|
|
"name": "monitoring",
|
|
"restart": false,
|
|
"settings": [
|
|
{
|
|
"name": "enable_prometheus_exporter",
|
|
"label": "Enable Prometheus Exporter",
|
|
"help": "Enable a Prometheus exporter to make it possible to gather stats about the mixers that are available in the <a href='/'>Nodes</a> tab with a <a href='https://prometheus.io/'>Prometheus</a> server. This makes it possible to keep track of long-term domain statistics for graphing, troubleshooting, and performance monitoring.",
|
|
"default": false,
|
|
"type": "checkbox",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "prometheus_exporter_port",
|
|
"label": "Prometheus TCP Port",
|
|
"help": "This is the port where the Prometheus exporter accepts connections. It listens both on IPv4 and IPv6 and can be accessed remotely, so you should make sure to restrict access with a firewall as needed.",
|
|
"default": "9703",
|
|
"type": "int",
|
|
"advanced": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"label": "Paths",
|
|
"html_id": "paths",
|
|
"restart": false,
|
|
"settings": [
|
|
{
|
|
"name": "paths",
|
|
"label": "Paths",
|
|
"help": "Clients can enter a path to reach an exact viewpoint in your domain.<br/>Add rows to the table below to map a path to a viewpoint.<br/>The index path ( / ) is where clients will enter if they do not enter an explicit path.",
|
|
"type": "table",
|
|
"content_setting": true,
|
|
"can_add_new_rows": true,
|
|
"key": {
|
|
"name": "path",
|
|
"label": "Path",
|
|
"placeholder": "/"
|
|
},
|
|
"columns": [
|
|
{
|
|
"name": "viewpoint",
|
|
"label": "Viewpoint",
|
|
"placeholder": "/0,0,0"
|
|
}
|
|
]
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "descriptors",
|
|
"label": "Description",
|
|
"restart": false,
|
|
"help": "This data will be queryable from your server. It may be collected by the Directory Services and used to share your domain with others.",
|
|
"settings": [
|
|
{
|
|
"name": "world_name",
|
|
"label": "Name",
|
|
"advanced": true,
|
|
"help": "The name of your domain (256 character limit)."
|
|
},
|
|
{
|
|
"name": "description",
|
|
"label": "Description",
|
|
"advanced": true,
|
|
"help": "A description of your domain (256 character limit)."
|
|
},
|
|
{
|
|
"name": "thumbnail",
|
|
"label": "World Thumbnail",
|
|
"advanced": true,
|
|
"help": "A link to the thumbnail that is publicly accessible from the internet."
|
|
},
|
|
{
|
|
"name": "images",
|
|
"label": "World Images",
|
|
"advanced": true,
|
|
"type": "table",
|
|
"can_add_new_rows": true,
|
|
"help": "URLs to images that visually describe your world to potential visitors.",
|
|
"numbered": false,
|
|
"columns": [
|
|
{
|
|
"name": "image",
|
|
"label": "Image URL",
|
|
"can_set": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "maturity",
|
|
"label": "Maturity",
|
|
"advanced": true,
|
|
"help": "A maturity rating, available as a guideline for content on your domain.",
|
|
"default": "unrated",
|
|
"type": "select",
|
|
"options": [
|
|
{
|
|
"value": "unrated",
|
|
"label": "Unrated"
|
|
},
|
|
{
|
|
"value": "everyone",
|
|
"label": "Everyone"
|
|
},
|
|
{
|
|
"value": "teen",
|
|
"label": "Teen (13+)"
|
|
},
|
|
{
|
|
"value": "mature",
|
|
"label": "Mature (17+)"
|
|
},
|
|
{
|
|
"value": "adult",
|
|
"label": "Adult (18+)"
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "contact_info",
|
|
"label": "World Administrative Contact",
|
|
"advanced": true,
|
|
"help": "Contact information to reach server administrators for assistance (256 character limit)."
|
|
},
|
|
{
|
|
"name": "managers",
|
|
"label": "World Managers / Administrators",
|
|
"advanced": true,
|
|
"type": "table",
|
|
"can_add_new_rows": true,
|
|
"help": "Usernames of managers that administrate the domain.",
|
|
"numbered": false,
|
|
"columns": [
|
|
{
|
|
"name": "manager",
|
|
"label": "Username",
|
|
"can_set": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "tags",
|
|
"label": "Tags",
|
|
"advanced": true,
|
|
"type": "table",
|
|
"can_add_new_rows": true,
|
|
"help": "Common categories under which your domain falls.",
|
|
"numbered": false,
|
|
"columns": [
|
|
{
|
|
"name": "tag",
|
|
"label": "Tag",
|
|
"can_set": true
|
|
}
|
|
]
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "security",
|
|
"label": "Security",
|
|
"restart": false,
|
|
"settings": [
|
|
{
|
|
"name": "http_username",
|
|
"label": "HTTP Username",
|
|
"help": "Username used for basic HTTP authentication.",
|
|
"backup": false
|
|
},
|
|
{
|
|
"name": "http_password",
|
|
"label": "HTTP Password",
|
|
"type": "password",
|
|
"help": "Password used for basic HTTP authentication. Leave this alone if you do not want to change it.",
|
|
"password_placeholder": "******",
|
|
"value-hidden": true,
|
|
"backup": false
|
|
},
|
|
{
|
|
"name": "verify_http_password",
|
|
"label": "Verify HTTP Password",
|
|
"type": "password",
|
|
"help": "Must match the password entered above for change to be saved.",
|
|
"value-hidden": true
|
|
},
|
|
{
|
|
"name": "approved_safe_urls",
|
|
"label": "Approved Script and QML URLs (Not Enabled)",
|
|
"help": "These URLs will be sent to the Interface as safe URLs to allow through the whitelist if the Interface has this security option enabled.",
|
|
"placeholder": "",
|
|
"default": "",
|
|
"advanced": false
|
|
},
|
|
{
|
|
"name": "maximum_user_capacity",
|
|
"label": "Maximum User Capacity",
|
|
"help": "The limit on how many users can be connected at once (0 means no limit). Avatars connected from the same machine will not count towards this limit.",
|
|
"placeholder": "0",
|
|
"default": "0",
|
|
"advanced": false
|
|
},
|
|
{
|
|
"name": "maximum_user_capacity_redirect_location",
|
|
"label": "Redirect to Location on Maximum Capacity",
|
|
"help": "The location to redirect users to when the maximum number of avatars are connected.",
|
|
"placeholder": "",
|
|
"default": "",
|
|
"advanced": false
|
|
},
|
|
{
|
|
"name": "ac_subnet_whitelist",
|
|
"label": "Assignment Client IP address Whitelist",
|
|
"type": "table",
|
|
"can_add_new_rows": true,
|
|
"help": "The IP addresses or subnets of ACs that can connect to this server. You can specify an IP address or a subnet in CIDR notation ('A.B.C.D/E', Example: '10.0.0.0/24'). Local ACs (localhost) are always permitted and do not need to be added here.",
|
|
"numbered": false,
|
|
"advanced": true,
|
|
"columns": [
|
|
{
|
|
"name": "ip",
|
|
"label": "IP Address",
|
|
"type": "ip",
|
|
"can_set": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "standard_permissions",
|
|
"type": "table",
|
|
"label": "Domain-Wide User Permissions",
|
|
"help": "Indicate which types of users can have which <a data-toggle='tooltip' data-html=true title='<p><strong>Domain-Wide User Permissions</strong></p><ul><li><strong>Connect</strong><br />Sets whether a user can connect to the domain.</li><li><strong>Avatar Entities</strong><br />Sets whether a user can use avatar entities on the domain.</li><li><strong>Lock / Unlock</strong><br />Sets whether a user change the “locked” property of an entity (either from on to off or off to on).</li><li><strong>Rez</strong><br />Sets whether a user can create new entities.</li><li><strong>Rez Temporary</strong><br />Sets whether a user can create new entities with a finite lifetime.</li><li><strong>Write Assets</strong><br />Sets whether a user can make changes to the domain’s asset-server assets.</li><li><strong>Ignore Max Capacity</strong><br />Sets whether a user can connect even if the domain has reached or exceeded its maximum allowed agents.</li><li><strong>Get and Set Private User Data</strong><br>Sets whether a user can get and set the privateUserData entity property.</li></ul><p>Note that permissions assigned to a specific user will supersede any parameter-level permissions that might otherwise apply to that user. Additionally, if more than one parameter is applicable to a given user, the permissions given to that user will be the sum of all applicable parameters. For example, let’s say only localhost users can connect and only logged in users can lock and unlock entities. If a user is both logged in and on localhost then they will be able to both connect and lock/unlock entities.</p>'>domain-wide permissions</a>.",
|
|
"caption": "Standard Permissions",
|
|
"can_add_new_rows": false,
|
|
"groups": [
|
|
{
|
|
"label": "Type of User",
|
|
"span": 1
|
|
},
|
|
{
|
|
"label": "Permissions <a data-toggle='tooltip' data-html='true' title='<p><strong>Domain-Wide User Permissions</strong></p><ul><li><strong>Connect</strong><br />Sets whether a user can connect to the domain.</li><li><strong>Avatar Entities</strong><br />Sets whether a user can use avatar entities on the domain.</li><li><strong>Lock / Unlock</strong><br />Sets whether a user change the “locked” property of an entity (either from on to off or off to on).</li><li><strong>Rez</strong><br />Sets whether a user can create new entities.</li><li><strong>Rez Temporary</strong><br />Sets whether a user can create new entities with a finite lifetime.</li><li><strong>Write Assets</strong><br />Sets whether a user can make changes to the domain’s asset-server assets.</li><li><strong>Ignore Max Capacity</strong><br />Sets whether a user can connect even if the domain has reached or exceeded its maximum allowed agents.</li><li><strong>Replace Content</strong><br>Sets whether a user can replace entire content sets by wiping existing domain content.</li><li><strong>Get and Set Private User Data</strong><br>Sets whether a user can get and set the privateUserData entity property.</li></ul><p>Note that permissions assigned to a specific user will supersede any parameter-level permissions that might otherwise apply to that user. Additionally, if more than one parameter is applicable to a given user, the permissions given to that user will be the sum of all applicable parameters. For example, let’s say only localhost users can connect and only logged in users can lock and unlock entities. If a user is both logged in and on localhost then they will be able to both connect and lock/unlock entities.</p>'>?</a>",
|
|
"span": 11
|
|
}
|
|
],
|
|
"columns": [
|
|
{
|
|
"name": "permissions_id",
|
|
"label": ""
|
|
},
|
|
{
|
|
"name": "id_can_connect",
|
|
"label": "Connect",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez_avatar_entities",
|
|
"label": "Avatar Entities",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_adjust_locks",
|
|
"label": "Lock / Unlock",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez",
|
|
"label": "Rez",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez_tmp",
|
|
"label": "Rez Temporary",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_write_to_asset_server",
|
|
"label": "Write Assets",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_connect_past_max_capacity",
|
|
"label": "Ignore Max Capacity",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_kick",
|
|
"label": "Kick Users",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_replace_content",
|
|
"label": "Replace Content",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_get_and_set_private_user_data",
|
|
"label": "Get and Set Private User Data",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_view_asset_urls",
|
|
"label": "View Asset URLs",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
}
|
|
],
|
|
"non-deletable-row-key": "permissions_id",
|
|
"non-deletable-row-values": [ "localhost", "anonymous", "logged-in" ],
|
|
"default": [
|
|
{
|
|
"id_can_connect": true,
|
|
"id_can_rez_avatar_entities": true,
|
|
"permissions_id": "anonymous"
|
|
},
|
|
{
|
|
"id_can_connect": true,
|
|
"id_can_rez_avatar_entities": true,
|
|
"permissions_id": "friends"
|
|
},
|
|
{
|
|
"id_can_connect": true,
|
|
"id_can_rez_avatar_entities": true,
|
|
"id_can_adjust_locks": true,
|
|
"id_can_connect_past_max_capacity": true,
|
|
"id_can_kick": true,
|
|
"id_can_replace_content": true,
|
|
"id_can_rez": true,
|
|
"id_can_rez_tmp": true,
|
|
"id_can_write_to_asset_server": true,
|
|
"id_can_get_and_set_private_user_data": true,
|
|
"id_can_view_asset_urls": true,
|
|
"permissions_id": "localhost"
|
|
},
|
|
{
|
|
"id_can_connect": true,
|
|
"id_can_rez_avatar_entities": true,
|
|
"permissions_id": "logged-in"
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "group_permissions",
|
|
"type": "table",
|
|
"caption": "Permissions for Users in Groups",
|
|
"help": "For groups that are provided from WordPress you need to denote them by putting an \"@\" symbol in front of each item, e.g., \"@silver\".",
|
|
"categorize_by_key": "permissions_id",
|
|
"can_add_new_categories": true,
|
|
"can_add_new_rows": false,
|
|
"new_category_placeholder": "Add Group",
|
|
"new_category_message": "Save and reload to see ranks",
|
|
"groups": [
|
|
{
|
|
"label": "Rank",
|
|
"span": 1
|
|
},
|
|
{
|
|
"label": "Permissions <a data-toggle='tooltip' data-html='true' title='<p><strong>Domain-Wide User Permissions</strong></p><ul><li><strong>Connect</strong><br />Sets whether users in specific groups can connect to the domain.</li><li><strong>Avatar Entities</strong><br />Sets whether users in specific groups can use avatar entities on the domain.</li><li><strong>Lock / Unlock</strong><br />Sets whether users in specific groups can change the “locked” property of an entity (either from on to off or off to on).</li><li><strong>Rez</strong><br />Sets whether users in specific groups can create new entities.</li><li><strong>Rez Temporary</strong><br />Sets whether users in specific groups can create new entities with a finite lifetime.</li><li><strong>Rez Temporary</strong><br />Sets whether users in specific groups can create new entities with a finite lifetime.</li><li><strong>Write Assets</strong><br />Sets whether users in specific groups can make changes to the domain’s asset-server assets.</li><li><strong>Ignore Max Capacity</strong><br />Sets whether user in specific groups can connect even if the domain has reached or exceeded its maximum allowed agents.</li><li><strong>Replace Content</strong><br>Sets whether a user can replace entire content sets by wiping existing domain content.</li><li><strong>Get and Set Private User Data</strong><br>Sets whether a user can get and set the privateUserData entity property.</li></ul><p>Permissions granted to a specific user will be a union of the permissions granted to the groups they are in, as well as permissions from the previous section. Group permissions are only granted if the user doesn’t have their own row in the per-account section, below.</p>'>?</a>",
|
|
"span": 12
|
|
}
|
|
],
|
|
"columns": [
|
|
{
|
|
"name": "permissions_id",
|
|
"label": "Group Name",
|
|
"readonly": true,
|
|
"hidden": true
|
|
},
|
|
{
|
|
"name": "rank_id",
|
|
"label": "Rank ID",
|
|
"readonly": true,
|
|
"hidden": true
|
|
},
|
|
{
|
|
"name": "rank_order",
|
|
"label": "Rank Order",
|
|
"readonly": true,
|
|
"hidden": true
|
|
},
|
|
{
|
|
"name": "rank_name",
|
|
"label": "",
|
|
"readonly": true
|
|
},
|
|
{
|
|
"name": "group_id",
|
|
"label": "Group ID",
|
|
"readonly": true,
|
|
"hidden": true
|
|
},
|
|
{
|
|
"name": "id_can_connect",
|
|
"label": "Connect",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez_avatar_entities",
|
|
"label": "Avatar Entities",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_adjust_locks",
|
|
"label": "Lock / Unlock",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez",
|
|
"label": "Rez",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez_tmp",
|
|
"label": "Rez Temporary",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_write_to_asset_server",
|
|
"label": "Write Assets",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_connect_past_max_capacity",
|
|
"label": "Ignore Max Capacity",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_kick",
|
|
"label": "Kick Users",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_replace_content",
|
|
"label": "Replace Content",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_get_and_set_private_user_data",
|
|
"label": "Get and Set Private User Data",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_view_asset_urls",
|
|
"label": "View Asset URLs",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "group_forbiddens",
|
|
"type": "table",
|
|
"caption": "Permissions Denied to Users in Groups",
|
|
"help": "For groups that are provided from WordPress you need to denote them by putting an \"@\" symbol in front of each item, e.g., \"@silver\".",
|
|
"categorize_by_key": "permissions_id",
|
|
"can_add_new_categories": true,
|
|
"can_add_new_rows": false,
|
|
"new_category_placeholder": "Add Blacklist Group",
|
|
"new_category_message": "Save and reload to see ranks",
|
|
"groups": [
|
|
{
|
|
"label": "Rank",
|
|
"span": 1
|
|
},
|
|
{
|
|
"label": "Permissions <a data-toggle='tooltip' data-html='true' title='<p><strong>Domain-Wide User Permissions</strong></p><ul><li><strong>Connect</strong><br />Sets whether users in specific groups can connect to the domain.</li><li><strong>Avatar Entities</strong><br />Sets whether users in specific groups can use avatar entities on the domain.</li><li><strong>Lock / Unlock</strong><br />Sets whether users in specific groups can change the “locked” property of an entity (either from on to off or off to on).</li><li><strong>Rez</strong><br />Sets whether users in specific groups can create new entities.</li><li><strong>Rez Temporary</strong><br />Sets whether users in specific groups can create new entities with a finite lifetime.</li><li><strong>Write Assets</strong><br />Sets whether users in specific groups can make changes to the domain’s asset-server assets.</li><li><strong>Ignore Max Capacity</strong><br />Sets whether user in specific groups can connect even if the domain has reached or exceeded its maximum allowed agents.</li><li><strong>Replace Content</strong><br>Sets whether users in specific groups can replace entire content sets by wiping existing domain content.</li><li><strong>Get and Set Private User Data</strong><br>Sets whether a user can get and set the privateUserData entity property</li></ul><p>Permissions granted to a specific user will be a union of the permissions granted to the groups they are in. Group permissions are only granted if the user doesn’t have their own row in the per-account section, below.</p>'>?</a>",
|
|
"span": 12
|
|
}
|
|
],
|
|
"columns": [
|
|
{
|
|
"name": "permissions_id",
|
|
"label": "Group Name",
|
|
"hidden": true
|
|
},
|
|
{
|
|
"name": "rank_id",
|
|
"label": "Rank ID",
|
|
"hidden": true
|
|
},
|
|
{
|
|
"name": "rank_order",
|
|
"label": "Rank Order",
|
|
"hidden": true
|
|
},
|
|
{
|
|
"name": "rank_name",
|
|
"label": "",
|
|
"readonly": true
|
|
},
|
|
{
|
|
"name": "group_id",
|
|
"label": "Group ID",
|
|
"readonly": true,
|
|
"hidden": true
|
|
},
|
|
{
|
|
"name": "id_can_connect",
|
|
"label": "Connect",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez_avatar_entities",
|
|
"label": "Avatar Entities",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_adjust_locks",
|
|
"label": "Lock / Unlock",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez",
|
|
"label": "Rez",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez_tmp",
|
|
"label": "Rez Temporary",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_write_to_asset_server",
|
|
"label": "Write Assets",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_connect_past_max_capacity",
|
|
"label": "Ignore Max Capacity",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_kick",
|
|
"label": "Kick Users",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_replace_content",
|
|
"label": "Replace Content",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_get_and_set_private_user_data",
|
|
"label": "Get and Set Private User Data",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_view_asset_urls",
|
|
"label": "View Asset URLs",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "permissions",
|
|
"type": "table",
|
|
"caption": "Permissions for Specific Users",
|
|
"can_add_new_rows": true,
|
|
"groups": [
|
|
{
|
|
"label": "User",
|
|
"span": 1
|
|
},
|
|
{
|
|
"label": "Permissions <a data-toggle='tooltip' data-html='true' title='<p><strong>Domain-Wide User Permissions</strong></p><ul><li><strong>Connect</strong><br />Sets whether a user can connect to the domain.</li><li><strong>Avatar Entities</strong><br />Sets whether a user can use avatar entities on the domain.</li><li><strong>Lock / Unlock</strong><br />Sets whether a user change the “locked” property of an entity (either from on to off or off to on).</li><li><strong>Rez</strong><br />Sets whether a user can create new entities.</li><li><strong>Rez Temporary</strong><br />Sets whether a user can create new entities with a finite lifetime.</li><li><strong>Rez Temporary</strong><br />Sets whether a user can create new entities with a finite lifetime.</li><li><strong>Write Assets</strong><br />Sets whether a user can make changes to the domain’s asset-server assets.</li><li><strong>Ignore Max Capacity</strong><br />Sets whether a user can connect even if the domain has reached or exceeded its maximum allowed agents.</li><li><strong>Replace Content</strong><br>Sets whether a user can replace entire content sets by wiping existing domain content.</li><li><strong>Get and Set Private User Data</strong><br>Sets whether a user can get and set the privateUserData entity property.</li></ul><p>Note that permissions assigned to a specific user will supersede any parameter-level or group permissions that might otherwise apply to that user.</p>'>?</a>",
|
|
"span": 12
|
|
}
|
|
],
|
|
"columns": [
|
|
{
|
|
"name": "permissions_id",
|
|
"label": ""
|
|
},
|
|
{
|
|
"name": "id_can_connect",
|
|
"label": "Connect",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez_avatar_entities",
|
|
"label": "Avatar Entities",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_adjust_locks",
|
|
"label": "Lock / Unlock",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez",
|
|
"label": "Rez",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez_tmp",
|
|
"label": "Rez Temporary",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_write_to_asset_server",
|
|
"label": "Write Assets",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_connect_past_max_capacity",
|
|
"label": "Ignore Max Capacity",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_kick",
|
|
"label": "Kick Users",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_replace_content",
|
|
"label": "Replace Content",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_get_and_set_private_user_data",
|
|
"label": "Get and Set Private User Data",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_view_asset_urls",
|
|
"label": "View Asset URLs",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "ip_permissions",
|
|
"type": "table",
|
|
"caption": "Permissions for Users from IP Addresses",
|
|
"can_add_new_rows": true,
|
|
"groups": [
|
|
{
|
|
"label": "IP Address",
|
|
"span": 1
|
|
},
|
|
{
|
|
"label": "Permissions <a data-toggle='tooltip' data-html='true' title='<p><strong>Domain-Wide IP Permissions</strong></p><ul><li><strong>Connect</strong><br />Sets whether users from specific IPs can connect to the domain.</li><li><strong>Avatar Entities</strong><br />Sets whether users from specific IPs can use avatar entities on the domain.</li><li><strong>Lock / Unlock</strong><br />Sets whether users from specific IPs can change the “locked” property of an entity (either from on to off or off to on).</li><li><strong>Rez</strong><br />Sets whether users from specific IPs can create new entities.</li><li><strong>Rez Temporary</strong><br />Sets whether users from specific IPs can create new entities with a finite lifetime.</li><li><strong>Rez Temporary</strong><br />Sets whether a user can create new entities with a finite lifetime.</li><li><strong>Write Assets</strong><br />Sets whether users from specific IPs can make changes to the domain’s asset-server assets.</li><li><strong>Ignore Max Capacity</strong><br />Sets whether users from specific IPs can connect even if the domain has reached or exceeded its maximum allowed agents.</li><li><strong>Replace Content</strong><br>Sets whether users from specific IPs can replace entire content sets by wiping existing domain content.</li><li><strong>Get and Set Private User Data</strong><br>Sets whether a user can get and set the privateUserData entity property.</li></ul><p>Note that permissions assigned to a specific IP will supersede any parameter-level permissions that might otherwise apply to that user (from groups or standard permissions above). IP address permissions are overriden if the user has their own row in the users section.</p>'>?</a>",
|
|
"span": 12
|
|
}
|
|
],
|
|
"columns": [
|
|
{
|
|
"name": "permissions_id",
|
|
"label": ""
|
|
},
|
|
{
|
|
"name": "id_can_connect",
|
|
"label": "Connect",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez_avatar_entities",
|
|
"label": "Avatar Entities",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_adjust_locks",
|
|
"label": "Lock / Unlock",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez",
|
|
"label": "Rez",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez_tmp",
|
|
"label": "Rez Temporary",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_write_to_asset_server",
|
|
"label": "Write Assets",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_connect_past_max_capacity",
|
|
"label": "Ignore Max Capacity",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_kick",
|
|
"label": "Kick Users",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_replace_content",
|
|
"label": "Replace Content",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_get_and_set_private_user_data",
|
|
"label": "Get and Set Private User Data",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_view_asset_urls",
|
|
"label": "View Asset URLs",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "mac_permissions",
|
|
"type": "table",
|
|
"caption": "Permissions for Users with MAC Addresses",
|
|
"can_add_new_rows": true,
|
|
"groups": [
|
|
{
|
|
"label": "MAC Address",
|
|
"span": 1
|
|
},
|
|
{
|
|
"label": "Permissions <a data-toggle='tooltip' data-html='true' title='<p><strong>Domain-Wide MAC Permissions</strong></p><ul><li><strong>Connect</strong><br />Sets whether users with specific MACs can connect to the domain.</li><li><strong>Avatar Entities</strong><br />Sets whether users with specific MACs can use avatar entities on the domain.</li><li><strong>Lock / Unlock</strong><br />Sets whether users from specific MACs can change the “locked” property of an entity (either from on to off or off to on).</li><li><strong>Rez</strong><br />Sets whether users with specific MACs can create new entities.</li><li><strong>Rez Temporary</strong><br />Sets whether users with specific MACs can create new entities with a finite lifetime.</li><li><strong>Write Assets</strong><br />Sets whether users with specific MACs can make changes to the domain’s asset-server assets.</li><li><strong>Ignore Max Capacity</strong><br />Sets whether users with specific MACs can connect even if the domain has reached or exceeded its maximum allowed agents.</li><li><strong>Replace Content</strong><br>Sets whether users with specific MACs can replace entire content sets by wiping existing domain content.</li><li><strong>Get and Set Private User Data</strong><br>Sets whether a user can get and set the privateUserData entity property.</li></ul><p>Note that permissions assigned to a specific MAC will supersede any parameter-level permissions that might otherwise apply to that user (from groups or standard permissions above). MAC address permissions are overriden if the user has their own row in the users section.</p>'>?</a>",
|
|
"span": 12
|
|
}
|
|
],
|
|
"columns": [
|
|
{
|
|
"name": "permissions_id",
|
|
"label": ""
|
|
},
|
|
{
|
|
"name": "id_can_connect",
|
|
"label": "Connect",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez_avatar_entities",
|
|
"label": "Avatar Entities",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_adjust_locks",
|
|
"label": "Lock / Unlock",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez",
|
|
"label": "Rez",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez_tmp",
|
|
"label": "Rez Temporary",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_write_to_asset_server",
|
|
"label": "Write Assets",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_connect_past_max_capacity",
|
|
"label": "Ignore Max Capacity",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_kick",
|
|
"label": "Kick Users",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_replace_content",
|
|
"label": "Replace Content",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_get_and_set_private_user_data",
|
|
"label": "Get and Set Private User Data",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_view_asset_urls",
|
|
"label": "View Asset URLs",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "machine_fingerprint_permissions",
|
|
"type": "table",
|
|
"caption": "Permissions for Users with Machine Fingerprints",
|
|
"can_add_new_rows": true,
|
|
"groups": [
|
|
{
|
|
"label": "Machine Fingerprint",
|
|
"span": 1
|
|
},
|
|
{
|
|
"label": "Permissions <a data-toggle='tooltip' data-html='true' title='<p><strong>Domain-Wide Machine Fingerprint Permissions</strong></p><ul><li><strong>Connect</strong><br />Sets whether users with specific Machine Fingerprints can connect to the domain.</li><li><strong>Avatar Entities</strong><br />Sets whether users with specific Machine Fingerprints can use avatar entities on the domain.</li><li><strong>Lock / Unlock</strong><br />Sets whether users from specific Machine Fingerprints can change the “locked” property of an entity (either from on to off or off to on).</li><li><strong>Rez</strong><br />Sets whether users with specific Machine Fingerprints can create new entities.</li><li><strong>Rez Temporary</strong><br />Sets whether users with specific Machine Fingerprints can create new entities with a finite lifetime.</li><li><strong>Write Assets</strong><br />Sets whether users with specific Machine Fingerprints can make changes to the domain’s asset-server assets.</li><li><strong>Ignore Max Capacity</strong><br />Sets whether users with specific Machine Fingerprints can connect even if the domain has reached or exceeded its maximum allowed agents.</li><li><strong>Replace Content</strong><br>Sets whether users with specific Machine Fingerprints can replace entire content sets by wiping existing domain content.</li><li><strong>Get and Set Private User Data</strong><br>Sets whether a user can get and set the privateUserData entity property.</li></ul><p>Note that permissions assigned to a specific Machine Fingerprint will supersede any parameter-level permissions that might otherwise apply to that user (from groups or standard permissions above). Machine Fingerprint address permissions are overriden if the user has their own row in the users section.</p>'>?</a>",
|
|
"span": 12
|
|
}
|
|
],
|
|
"columns": [
|
|
{
|
|
"name": "permissions_id",
|
|
"label": ""
|
|
},
|
|
{
|
|
"name": "id_can_connect",
|
|
"label": "Connect",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez_avatar_entities",
|
|
"label": "Avatar Entities",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_adjust_locks",
|
|
"label": "Lock / Unlock",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez",
|
|
"label": "Rez",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_rez_tmp",
|
|
"label": "Rez Temporary",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_write_to_asset_server",
|
|
"label": "Write Assets",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_connect_past_max_capacity",
|
|
"label": "Ignore Max Capacity",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_kick",
|
|
"label": "Kick Users",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_replace_content",
|
|
"label": "Replace Content",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_get_and_set_private_user_data",
|
|
"label": "Get and Set Private User Data",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
},
|
|
{
|
|
"name": "id_can_view_asset_urls",
|
|
"label": "View Asset URLs",
|
|
"type": "checkbox",
|
|
"editable": true,
|
|
"default": false
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "multi_kick_logged_in",
|
|
"type": "checkbox",
|
|
"label": "Multi-Kick for Logged In Users",
|
|
"help": "Kick logged in users by machine fingerprint (in addition to the default kick by username)",
|
|
"default": false,
|
|
"advanced": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "scripts",
|
|
"label": "Scripts",
|
|
"settings": [
|
|
{
|
|
"name": "persistent_scripts",
|
|
"type": "table",
|
|
"label": "Persistent Scripts",
|
|
"content_setting": true,
|
|
"help": "Add the URLs for scripts that you would like to ensure are always running in your domain.",
|
|
"can_add_new_rows": true,
|
|
"columns": [
|
|
{
|
|
"name": "url",
|
|
"label": "Script URL"
|
|
},
|
|
{
|
|
"name": "num_instances",
|
|
"label": "# instances",
|
|
"default": 1
|
|
},
|
|
{
|
|
"name": "pool",
|
|
"label": "Pool"
|
|
}
|
|
]
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "audio_threading",
|
|
"label": "Audio Threading",
|
|
"assignment-types": [ 0 ],
|
|
"settings": [
|
|
{
|
|
"name": "auto_threads",
|
|
"label": "Automatically determine thread count",
|
|
"type": "checkbox",
|
|
"help": "Allow system to determine number of threads (recommended)",
|
|
"default": false,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "num_threads",
|
|
"label": "Number of Threads",
|
|
"help": "Threads to spin up for audio mixing (if not automatically set)",
|
|
"placeholder": "1",
|
|
"default": "1",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "throttle_start",
|
|
"type": "double",
|
|
"label": "Throttle Start Target",
|
|
"help": "Target percentage of frame time to start throttling",
|
|
"placeholder": "0.9",
|
|
"default": 0.9,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "throttle_backoff",
|
|
"type": "double",
|
|
"label": "Throttle Backoff Target",
|
|
"help": "Target percentage of frame time to backoff throttling",
|
|
"placeholder": "0.44",
|
|
"default": 0.44,
|
|
"advanced": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "audio_env",
|
|
"label": "Audio Environment",
|
|
"assignment-types": [ 0 ],
|
|
"settings": [
|
|
{
|
|
"name": "attenuation_per_doubling_in_distance",
|
|
"label": "Default Domain Attenuation",
|
|
"help": "Factor between 0 and 1.0 (0: No attenuation, 1.0: extreme attenuation)",
|
|
"content_setting": true,
|
|
"placeholder": "0.5",
|
|
"default": "0.5",
|
|
"advanced": false
|
|
},
|
|
{
|
|
"name": "noise_muting_threshold",
|
|
"label": "Noise Muting Threshold",
|
|
"help": "Loudness value for noise background between 0 and 1.0 (0: mute everyone, 1.0: never mute). 0.003 is a typical setting to mute loud people.",
|
|
"placeholder": "1.0",
|
|
"default": "1.0",
|
|
"advanced": false
|
|
},
|
|
{
|
|
"name": "enable_filter",
|
|
"label": "Low-pass Filter",
|
|
"type": "checkbox",
|
|
"help": "Positional audio stream uses low-pass filter",
|
|
"default": true
|
|
},
|
|
{
|
|
"name": "zones",
|
|
"type": "table",
|
|
"label": "Zones (deprecated, use Zone Entities)",
|
|
"help": "In this table you can define a set of zones in which you can specify various audio properties.",
|
|
"numbered": false,
|
|
"content_setting": true,
|
|
"can_add_new_rows": true,
|
|
"key": {
|
|
"name": "name",
|
|
"label": "Name",
|
|
"placeholder": "Zone_Name"
|
|
},
|
|
"columns": [
|
|
{
|
|
"name": "x_min",
|
|
"label": "X start",
|
|
"can_set": true,
|
|
"placeholder": "-16384.0"
|
|
},
|
|
{
|
|
"name": "x_max",
|
|
"label": "X end",
|
|
"can_set": true,
|
|
"placeholder": "16384.0"
|
|
},
|
|
{
|
|
"name": "y_min",
|
|
"label": "Y start",
|
|
"can_set": true,
|
|
"placeholder": "-16384.0"
|
|
},
|
|
{
|
|
"name": "y_max",
|
|
"label": "Y end",
|
|
"can_set": true,
|
|
"placeholder": "16384.0"
|
|
},
|
|
{
|
|
"name": "z_min",
|
|
"label": "Z start",
|
|
"can_set": true,
|
|
"placeholder": "-16384.0"
|
|
},
|
|
{
|
|
"name": "z_max",
|
|
"label": "Z end",
|
|
"can_set": true,
|
|
"placeholder": "16384.0"
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "attenuation_coefficients",
|
|
"type": "table",
|
|
"label": "Attenuation Coefficients (deprecated, use Zone Entities)",
|
|
"help": "In this table you can set custom attenuation coefficients between audio zones",
|
|
"content_setting": true,
|
|
"numbered": true,
|
|
"can_order": true,
|
|
"can_add_new_rows": true,
|
|
"columns": [
|
|
{
|
|
"name": "source",
|
|
"label": "Source",
|
|
"can_set": true,
|
|
"placeholder": "Zone_A"
|
|
},
|
|
{
|
|
"name": "listener",
|
|
"label": "Listener",
|
|
"can_set": true,
|
|
"placeholder": "Zone_B"
|
|
},
|
|
{
|
|
"name": "coefficient",
|
|
"label": "Attenuation coefficient",
|
|
"can_set": true,
|
|
"placeholder": "0.5"
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "reverb",
|
|
"type": "table",
|
|
"label": "Reverb Settings (deprecated, use Zone Entities)",
|
|
"help": "In this table you can set reverb levels for audio zones. For a medium-sized (e.g., 100 square meter) meeting room, try a decay time of around 1.5 seconds and a wet/dry mix of 25%. For an airplane hangar or cathedral, try a decay time of 4 seconds and a wet/dry mix of 50%.",
|
|
"numbered": true,
|
|
"content_setting": true,
|
|
"can_add_new_rows": true,
|
|
"columns": [
|
|
{
|
|
"name": "zone",
|
|
"label": "Zone",
|
|
"can_set": true,
|
|
"placeholder": "Audio_Zone"
|
|
},
|
|
{
|
|
"name": "reverb_time",
|
|
"label": "Reverb Decay Time",
|
|
"can_set": true,
|
|
"placeholder": "(in sec)"
|
|
},
|
|
{
|
|
"name": "wet_level",
|
|
"label": "Wet/Dry Mix",
|
|
"can_set": true,
|
|
"placeholder": "(in percent)"
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "codec_preference_order",
|
|
"label": "Audio Codec Preference Order",
|
|
"help": "List of codec names in order of preferred usage",
|
|
"placeholder": "opus, zlib, pcm",
|
|
"default": "opus,zlib,pcm",
|
|
"advanced": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "audio_buffer",
|
|
"label": "Audio Buffers",
|
|
"assignment-types": [
|
|
0
|
|
],
|
|
"settings": [
|
|
{
|
|
"name": "dynamic_jitter_buffer",
|
|
"type": "checkbox",
|
|
"label": "Dynamic Jitter Buffers",
|
|
"help": "Dynamically buffer inbound audio streams based on perceived jitter in packet receipt timing.",
|
|
"default": true,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "static_desired_jitter_buffer_frames",
|
|
"label": "Static Desired Jitter Buffer Frames",
|
|
"help": "If dynamic jitter buffers is disabled, this determines the size of the jitter buffers of inbound audio streams in the mixer. Higher numbers introduce more latency.",
|
|
"placeholder": "1",
|
|
"default": "1",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "max_frames_over_desired",
|
|
"deprecated": true
|
|
},
|
|
{
|
|
"name": "window_starve_threshold",
|
|
"deprecated": true
|
|
},
|
|
{
|
|
"name": "window_seconds_for_desired_calc_on_too_many_starves",
|
|
"deprecated": true
|
|
},
|
|
{
|
|
"name": "window_seconds_for_desired_reduction",
|
|
"deprecated": true
|
|
},
|
|
{
|
|
"name": "use_stdev_for_desired_calc",
|
|
"deprecated": true
|
|
},
|
|
{
|
|
"name": "repetition_with_fade",
|
|
"deprecated": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "avatars",
|
|
"label": "Avatars",
|
|
"assignment-types": [ 1, 2 ],
|
|
"settings": [
|
|
{
|
|
"name": "min_avatar_height",
|
|
"type": "double",
|
|
"label": "Minimum Avatar Height (meters)",
|
|
"help": "Limits the height of avatars in your domain. Must be at least 0.009.",
|
|
"placeholder": 0.4,
|
|
"default": 0.4
|
|
},
|
|
{
|
|
"name": "max_avatar_height",
|
|
"type": "double",
|
|
"label": "Maximum Avatar Height (meters)",
|
|
"help": "Limits the height of avatars in your domain. Cannot be greater than 1755.",
|
|
"placeholder": 5.2,
|
|
"default": 5.2
|
|
},
|
|
{
|
|
"name": "avatar_whitelist",
|
|
"label": "Avatars Allowed from:",
|
|
"help": "Comma separated list of URLs (with optional paths) that avatar .fst files are allowed from. If someone attempts to use an avatar with a different domain, it will be rejected and the replacement avatar will be used. If left blank, any domain is allowed.",
|
|
"placeholder": "",
|
|
"default": "",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "replacement_avatar",
|
|
"label": "Replacement Avatar for disallowed avatars",
|
|
"help": "A URL for an avatar .fst to be used when someone tries to use an avatar that is not allowed. If left blank, the generic default avatar is used.",
|
|
"placeholder": "",
|
|
"default": "",
|
|
"advanced": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "avatar_mixer",
|
|
"label": "Avatar Mixer",
|
|
"assignment-types": [
|
|
1
|
|
],
|
|
"settings": [
|
|
{
|
|
"name": "max_node_send_bandwidth",
|
|
"type": "double",
|
|
"label": "Per-Node Bandwidth",
|
|
"help": "Desired maximum send bandwidth (in Megabits per second) to each node",
|
|
"placeholder": 5.0,
|
|
"default": 5.0,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "auto_threads",
|
|
"label": "Automatically determine thread count",
|
|
"type": "checkbox",
|
|
"help": "Allow system to determine number of threads (recommended)",
|
|
"default": false,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "num_threads",
|
|
"label": "Number of Threads",
|
|
"help": "Threads to spin up for avatar mixing (if not automatically set)",
|
|
"placeholder": "1",
|
|
"default": "1",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "connection_rate",
|
|
"label": "Connection Rate",
|
|
"help": "Number of new agents that can connect to the mixer every second",
|
|
"placeholder": "10000000",
|
|
"default": "10000000",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "priority_fraction",
|
|
"type": "double",
|
|
"label": "Hero Bandwidth",
|
|
"help": "Fraction of downstream bandwidth reserved for avatars in 'Hero' zones",
|
|
"placeholder": "0.40",
|
|
"default": "0.40",
|
|
"advanced": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "messages_mixer",
|
|
"label": "Messages Mixer",
|
|
"assignment-types": [
|
|
4
|
|
],
|
|
"settings": [
|
|
{
|
|
"name": "max_node_messages_per_second",
|
|
"type": "int",
|
|
"label": "Maximum Message Rate",
|
|
"help": "Maximum message send rate (messages per second) per node",
|
|
"placeholder": 1000,
|
|
"default": 1000,
|
|
"advanced": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "entity_server_settings",
|
|
"label": "Entities",
|
|
"assignment-types": [
|
|
6
|
|
],
|
|
"settings": [
|
|
{
|
|
"name": "maxTmpLifetime",
|
|
"label": "Maximum Lifetime of Temporary Entities",
|
|
"help": "The maximum number of seconds for the lifetime of an entity which will be considered \"temporary\".",
|
|
"placeholder": "3600",
|
|
"default": "3600",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "dynamicDomainVerificationTimeMin",
|
|
"label": "Dynamic Domain Verification Time (seconds) - Minimum",
|
|
"help": "The lower limit on the amount of time that passes before Dynamic Domain Verification on entities occurs. Units are seconds.",
|
|
"placeholder": "2700",
|
|
"default": "2700",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "dynamicDomainVerificationTimeMax",
|
|
"label": "Dynamic Domain Verification Time (seconds) - Maximum",
|
|
"help": "The upper limit on the amount of time that passes before Dynamic Domain Verification on entities occurs. Units are seconds.",
|
|
"placeholder": "3600",
|
|
"default": "3600",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "entityScriptSourceWhitelist",
|
|
"label": "Entity Scripts Allowed from:",
|
|
"help": "Comma separated list of URLs (with optional paths) that entity scripts are allowed from. If someone attempts to create and entity or edit an entity to have a different domain, it will be rejected. If left blank, any domain is allowed.",
|
|
"placeholder": "",
|
|
"default": "",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "entityEditFilter",
|
|
"label": "Filter Entity Edits",
|
|
"help": "Check all entity edits against this filter function.",
|
|
"content_setting": true,
|
|
"placeholder": "url whose content is like: function filter(properties) { return properties; }",
|
|
"default": "",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "persistFilePath",
|
|
"label": "Entities File Path",
|
|
"help": "The path to the file entities are stored in.<br/>If this path is relative it will be relative to the application data directory.<br/>The filename must end in .json.gz.",
|
|
"placeholder": "models.json.gz",
|
|
"default": "models.json.gz",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "backupDirectoryPath",
|
|
"label": "Entities Backup Directory Path",
|
|
"help": "The path to the directory to store backups in.<br/>If this path is relative it will be relative to the application data directory.",
|
|
"placeholder": "",
|
|
"default": "",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "persistInterval",
|
|
"label": "Save Check Interval",
|
|
"help": "Milliseconds between checks for saving the current state of entities.",
|
|
"placeholder": "30000",
|
|
"default": "30000",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "NoPersist",
|
|
"type": "checkbox",
|
|
"label": "Disable Persistence",
|
|
"help": "Don't persist your entities to a file.",
|
|
"default": false,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "NoBackup",
|
|
"type": "checkbox",
|
|
"label": "Disable Backup",
|
|
"help": "Don't regularly backup your persisted entities to a backup file.",
|
|
"default": false,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "statusHost",
|
|
"label": "Status Hostname",
|
|
"help": "Host name or IP address of the server for accessing the status page",
|
|
"placeholder": "",
|
|
"default": "",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "statusPort",
|
|
"label": "Status Port",
|
|
"help": "Port of the server for accessing the status page",
|
|
"placeholder": "",
|
|
"default": "",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "persistFileDownload",
|
|
"type": "checkbox",
|
|
"label": "Persist File Download",
|
|
"help": "Includes a download link to the persist file in the server status page.",
|
|
"default": false,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "wantEditLogging",
|
|
"type": "checkbox",
|
|
"label": "Edit Logging",
|
|
"help": "Logging of all edits to entities",
|
|
"default": false,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "wantTerseEditLogging",
|
|
"type": "checkbox",
|
|
"label": "Edit Logging (Terse)",
|
|
"help": "Logging of all edits to entities",
|
|
"default": false,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "verboseDebug",
|
|
"type": "checkbox",
|
|
"label": "Verbose Debug",
|
|
"help": "Lots of debugging",
|
|
"default": false,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "debugReceiving",
|
|
"type": "checkbox",
|
|
"label": "Extra Receiving Debug",
|
|
"help": "Extra debugging on receiving",
|
|
"default": false,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "debugSending",
|
|
"type": "checkbox",
|
|
"label": "Extra Sending Debug",
|
|
"help": "Extra debugging on sending",
|
|
"default": false,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "debugTimestampNow",
|
|
"type": "checkbox",
|
|
"label": "Extra Timestamp Debugging",
|
|
"help": "Extra debugging for usecTimestampNow() function",
|
|
"default": false,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "clockSkew",
|
|
"label": "Clock Skew",
|
|
"help": "Number of msecs to skew the server clock by to test clock skew",
|
|
"placeholder": "0",
|
|
"default": "0",
|
|
"advanced": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "asset_server",
|
|
"label": "Asset Server (ATP)",
|
|
"assignment-types": [ 3 ],
|
|
"settings": [
|
|
{
|
|
"name": "enabled",
|
|
"type": "checkbox",
|
|
"label": "Enabled",
|
|
"help": "Assigns an asset-server in your domain to serve files to clients via the ATP protocol (over UDP)",
|
|
"default": true,
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "assets_path",
|
|
"type": "string",
|
|
"label": "Assets Path",
|
|
"help": "The path to the directory assets are stored in.<br/>If this path is relative, it will be relative to the application data directory.<br/>If you change this path you will need to manually copy any existing assets from the previous directory.",
|
|
"default": "",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "assets_filesize_limit",
|
|
"type": "int",
|
|
"label": "File Size Limit",
|
|
"help": "The file size limit of an asset that can be imported into the asset server in MBytes. 0 (default) means no limit on file size.",
|
|
"default": 0,
|
|
"advanced": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "entity_script_server",
|
|
"label": "Entity Script Server (ESS)",
|
|
"assignment-types": [ 5 ],
|
|
"settings": [
|
|
{
|
|
"name": "entity_pps_per_script",
|
|
"label": "Entity PPS per script",
|
|
"help": "The number of packets per second (PPS) that can be sent to the entity server for each server entity script. This contributes to a total overall amount.<br/>Example: 1000 PPS with 5 entites gives a total PPS of 5000 that is shared among the entity scripts. A single could use 4000 PPS, leaving 1000 for the rest, for example.",
|
|
"default": 900,
|
|
"type": "int",
|
|
"advanced": true
|
|
},
|
|
{
|
|
"name": "max_total_entity_pps",
|
|
"label": "Maximum Total Entity PPS",
|
|
"help": "The maximum total packets per seconds (PPS) that can be sent to the entity server.<br/>Example: 5 scripts @ 1000 PPS per script = 5000 total PPS. A maximum total PPS of 4000 would cap this 5000 total PPS to 4000.",
|
|
"default": 9000,
|
|
"type": "int",
|
|
"advanced": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "broadcasting",
|
|
"label": "Broadcasting",
|
|
"restart": false,
|
|
"settings": [
|
|
{
|
|
"name": "users",
|
|
"label": "Broadcasted Users",
|
|
"type": "table",
|
|
"advanced": true,
|
|
"can_add_new_rows": true,
|
|
"help": "Users that are broadcasted to downstream servers",
|
|
"numbered": false,
|
|
"columns": [
|
|
{
|
|
"name": "user",
|
|
"label": "User",
|
|
"can_set": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "downstream_servers",
|
|
"label": "Receiving Servers",
|
|
"assignment-types": [
|
|
0,
|
|
1
|
|
],
|
|
"type": "table",
|
|
"advanced": true,
|
|
"can_add_new_rows": true,
|
|
"help": "Servers that receive data for broadcasted users",
|
|
"numbered": false,
|
|
"columns": [
|
|
{
|
|
"name": "address",
|
|
"label": "Address",
|
|
"can_set": true
|
|
},
|
|
{
|
|
"name": "port",
|
|
"label": "Port",
|
|
"can_set": true
|
|
},
|
|
{
|
|
"name": "server_type",
|
|
"label": "Server Type",
|
|
"type": "select",
|
|
"placeholder": "Audio Mixer",
|
|
"default": "Audio Mixer",
|
|
"can_set": true,
|
|
"options": [
|
|
{
|
|
"value": "Audio Mixer",
|
|
"label": "Audio Mixer"
|
|
},
|
|
{
|
|
"value": "Avatar Mixer",
|
|
"label": "Avatar Mixer"
|
|
}
|
|
]
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "upstream_servers",
|
|
"label": "Broadcasting Servers",
|
|
"assignment-types": [
|
|
0,
|
|
1
|
|
],
|
|
"type": "table",
|
|
"advanced": true,
|
|
"can_add_new_rows": true,
|
|
"help": "Servers that broadcast data to this domain",
|
|
"numbered": false,
|
|
"columns": [
|
|
{
|
|
"name": "address",
|
|
"label": "Address",
|
|
"can_set": true
|
|
},
|
|
{
|
|
"name": "port",
|
|
"label": "Port",
|
|
"can_set": true
|
|
},
|
|
{
|
|
"name": "server_type",
|
|
"label": "Server Type",
|
|
"type": "select",
|
|
"placeholder": "Audio Mixer",
|
|
"default": "Audio Mixer",
|
|
"can_set": true,
|
|
"options": [
|
|
{
|
|
"value": "Audio Mixer",
|
|
"label": "Audio Mixer"
|
|
},
|
|
{
|
|
"value": "Avatar Mixer",
|
|
"label": "Avatar Mixer"
|
|
}
|
|
]
|
|
}
|
|
]
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "oauth",
|
|
"label": "OAuth",
|
|
"show_on_enable": true,
|
|
"settings": [
|
|
{
|
|
"name": "enable",
|
|
"type": "checkbox",
|
|
"default": false,
|
|
"hidden": true
|
|
},
|
|
{
|
|
"name": "admin-users",
|
|
"label": "Admin Users",
|
|
"type": "table",
|
|
"can_add_new_rows": true,
|
|
"help": "Any of these users can administer the domain.",
|
|
"numbered": false,
|
|
"backup": false,
|
|
"advanced": false,
|
|
"columns": [
|
|
{
|
|
"name": "username",
|
|
"label": "Username",
|
|
"can_set": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "admin-roles",
|
|
"label": "Admin Roles",
|
|
"type": "table",
|
|
"can_add_new_rows": true,
|
|
"help": "Any user with any of these roles can administer the domain.",
|
|
"numbered": false,
|
|
"backup": false,
|
|
"advanced": true,
|
|
"columns": [
|
|
{
|
|
"name": "role",
|
|
"label": "Role",
|
|
"can_set": true
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "client-id",
|
|
"label": "Client ID",
|
|
"help": "OAuth client ID.",
|
|
"default": "",
|
|
"advanced": true,
|
|
"backup": false
|
|
},
|
|
{
|
|
"name": "client-secret",
|
|
"label": "Client Secret",
|
|
"help": "OAuth client secret.",
|
|
"type": "password",
|
|
"password_placeholder": "******",
|
|
"value-hidden": true,
|
|
"advanced": true,
|
|
"backup": false
|
|
},
|
|
{
|
|
"name": "provider",
|
|
"label": "Provider",
|
|
"help": "OAuth provider URL.",
|
|
"default": "https://mv.overte.org/server",
|
|
"advanced": true,
|
|
"backup": false
|
|
},
|
|
{
|
|
"name": "hostname",
|
|
"label": "Hostname",
|
|
"help": "OAuth hostname.",
|
|
"default": "",
|
|
"advanced": true,
|
|
"backup": false
|
|
},
|
|
{
|
|
"name": "key-passphrase",
|
|
"label": "SSL Private Key Passphrase",
|
|
"help": "SSL Private Key Passphrase",
|
|
"type": "password",
|
|
"password_placeholder": "******",
|
|
"value-hidden": true,
|
|
"advanced": true,
|
|
"backup": false
|
|
},
|
|
{
|
|
"name": "cert-fingerprint",
|
|
"type": "hidden",
|
|
"readonly": true,
|
|
"advanced": true,
|
|
"backup": false
|
|
},
|
|
{
|
|
"name": "cert",
|
|
"advanced": true,
|
|
"backup": false
|
|
},
|
|
{
|
|
"name": "key",
|
|
"advanced": true,
|
|
"backup": false
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "automatic_content_archives",
|
|
"label": "Automatic Content Archives",
|
|
"settings": [
|
|
{
|
|
"name": "backup_rules",
|
|
"type": "table",
|
|
"label": "Rolling Backup Rules",
|
|
"help": "Define how frequently to create automatic content archives",
|
|
"numbered": false,
|
|
"can_add_new_rows": true,
|
|
"default": [
|
|
{
|
|
"Name": "Half Hourly Rolling",
|
|
"backupInterval": 1800,
|
|
"maxBackupVersions": 5
|
|
},
|
|
{
|
|
"Name": "Daily Rolling",
|
|
"backupInterval": 86400,
|
|
"maxBackupVersions": 7
|
|
},
|
|
{
|
|
"Name": "Weekly Rolling",
|
|
"backupInterval": 604800,
|
|
"maxBackupVersions": 4
|
|
},
|
|
{
|
|
"Name": "Thirty Day Rolling",
|
|
"backupInterval": 2592000,
|
|
"maxBackupVersions": 12
|
|
}
|
|
],
|
|
"columns": [
|
|
{
|
|
"name": "Name",
|
|
"label": "Name",
|
|
"can_set": true,
|
|
"placeholder": "Example",
|
|
"default": "Example"
|
|
},
|
|
{
|
|
"name": "backupInterval",
|
|
"label": "Backup Interval in Seconds",
|
|
"help": "Interval between backup checks in seconds.",
|
|
"placeholder": 1800,
|
|
"default": 1800,
|
|
"can_set": true
|
|
},
|
|
{
|
|
"name": "maxBackupVersions",
|
|
"label": "Max Rolled Backup Versions",
|
|
"help": "If your backup extension format uses 'rolling', how many versions do you want us to keep?",
|
|
"placeholder": 5,
|
|
"default": 5,
|
|
"can_set": true
|
|
}
|
|
]
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "wizard",
|
|
"label": "Setup Wizard",
|
|
"restart": false,
|
|
"hidden": true,
|
|
"settings": [
|
|
{
|
|
"name": "cloud_domain",
|
|
"type": "checkbox",
|
|
"default": true
|
|
},
|
|
{
|
|
"name": "steps_completed",
|
|
"type": "int",
|
|
"default": 0
|
|
},
|
|
{
|
|
"name": "completed_once",
|
|
"type": "checkbox",
|
|
"default": false
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "domain_server",
|
|
"label": "Setup Domain Server",
|
|
"restart": false,
|
|
"hidden": true,
|
|
"settings": [
|
|
{
|
|
"name": "network_address",
|
|
"default": ""
|
|
},
|
|
{
|
|
"name": "network_port",
|
|
"type": "int",
|
|
"default": 0
|
|
}
|
|
]
|
|
},
|
|
{
|
|
"name": "installed_content",
|
|
"label": "Installed Content",
|
|
"hidden": true,
|
|
"settings": [
|
|
{
|
|
"name": "filename",
|
|
"content_setting": true,
|
|
"default": ""
|
|
},
|
|
{
|
|
"name": "name",
|
|
"content_setting": true,
|
|
"default": ""
|
|
},
|
|
{
|
|
"name": "creation_time",
|
|
"content_setting": true,
|
|
"default": 0
|
|
},
|
|
{
|
|
"name": "install_time",
|
|
"type": "int",
|
|
"content_setting": true,
|
|
"default": 0
|
|
},
|
|
{
|
|
"name": "installed_by",
|
|
"content_setting": true,
|
|
"default": ""
|
|
}
|
|
]
|
|
}
|
|
]
|
|
}
|