Renamed Metaverse Server to Directory Server/Services

This commit is contained in:
ksuprynowicz 2022-09-04 21:33:44 +02:00
parent 614c6927b6
commit 88046506c3
40 changed files with 169 additions and 168 deletions

View file

@ -128,7 +128,7 @@ PRODUCTION_BUILD=0|1
PR_BUILD=0|1 PR_BUILD=0|1
STABLE_BUILD=0|1 STABLE_BUILD=0|1
// Determine if to utilize testing or stable Metaverse URLs // Determine if to utilize testing or stable directory services URLs
USE_STABLE_GLOBAL_SERVICES=1 USE_STABLE_GLOBAL_SERVICES=1
BUILD_GLOBAL_SERVICES=STABLE BUILD_GLOBAL_SERVICES=STABLE
``` ```

View file

@ -16,10 +16,11 @@
### What is this? ### What is this?
Overte is a 3D social software project seeking to incrementally bring about a truly free and open metaverse. Overte is a free and open source 3D social virtual worlds software.
* Desktop and VR use * Desktop and VR use
* Hundreds of users simultaneously * Hundreds of users simultaneously
* Collaborative in-game creation
* Full-body avatars * Full-body avatars
* FBX, glTF, and OBJ support * FBX, glTF, and OBJ support
* JavaScript scripting engine * JavaScript scripting engine
@ -58,18 +59,18 @@ Overte is a 3D social software project seeking to incrementally bring about a tr
- [For Linux - Server .deb - Overte Builder](INSTALLER.md#ubuntu-1804--deb) - [For Linux - Server .deb - Overte Builder](INSTALLER.md#ubuntu-1804--deb)
- [For Linux - Interface AppImage - Overte Builder](https://github.com/overte-org/overte-builder/blob/master/README.md#building-appimages) - [For Linux - Interface AppImage - Overte Builder](https://github.com/overte-org/overte-builder/blob/master/README.md#building-appimages)
### Boot to Metaverse: The Goal ### Mission statement
Having a place to experience adventure, a place to relax with calm breath, that's a world to live in. An engine to support infinite combinations and possibilities of worlds without censorship and interruption, that's metaverse. Finding a way to make infinite realities our reality is the dream. Overte aims to provide social virtual worlds experience with entitely free and open source infrastructure.
### Boot to Metaverse: The Technicals ### Technical details
Overte consists of many projects and codebases with its unifying structure's goal being a decentralized metaverse. Overte consists of many projects and codebases with its unifying structure's goal being free and open source self-hosted virtual worlds.
- The Interface - You are here! - The Interface - You are here!
- The Server - You are also here! - The Server - You are also here!
- [The Metaverse Server (Codename Iamus)](https://github.com/overte/Iamus/) - [The Directory Server (Codename Iamus)](https://github.com/overte/Iamus/)
- [The Metaverse Server Dashboard (Codename Iamus)](https://github.com/overte/project-iamus-dashboard/) - [The Directory Server Dashboard (Codename Iamus)](https://github.com/overte/project-iamus-dashboard/)
- [The Launcher (Codename Pantheon)](https://github.com/overte/pantheon-launcher/) - Currently Windows only. - [The Launcher (Codename Pantheon)](https://github.com/overte/pantheon-launcher/) - Currently Windows only.
#### Tools #### Tools

View file

@ -230,7 +230,7 @@ void MixerAvatar::ownerRequestComplete() {
} }
void MixerAvatar::requestCurrentOwnership() { void MixerAvatar::requestCurrentOwnership() {
// Get registered owner's public key from metaverse. // Get registered owner's public key from directory server.
static const QString POP_MARKETPLACE_API { "/api/v1/commerce/proof_of_purchase_status/transfer" }; static const QString POP_MARKETPLACE_API { "/api/v1/commerce/proof_of_purchase_status/transfer" };
auto& networkAccessManager = NetworkAccessManager::getInstance(); auto& networkAccessManager = NetworkAccessManager::getInstance();
QNetworkRequest networkRequest; QNetworkRequest networkRequest;

10
debian/control vendored
View file

@ -4,12 +4,12 @@ Priority: optional
Maintainer: Seth Alves <seth.alves@gmail.com> Maintainer: Seth Alves <seth.alves@gmail.com>
Build-Depends: debhelper (>= 11), cmake Build-Depends: debhelper (>= 11), cmake
Standards-Version: 4.1.3 Standards-Version: 4.1.3
Homepage: https://www.highfidelity.com/ Homepage: https://www.overte.org/
Vcs-Browser: https://github.com/highfidelity/hifi Vcs-Browser: https://github.com/overte-org/overte
Vcs-Git: https://github.com/highfidelity/hifi.git Vcs-Git: https://github.com/overte-org/overte.git
Package: hifi-interface Package: hifi-interface
Architecture: any Architecture: any
Depends: ${shlibs:Depends}, ${misc:Depends}, libqt5quick5, libqt5quickcontrols2-5, libqt5quickwidgets5, qml-module-qtquick-controls, qml-module-qtquick-controls2, qml-module-qtquick-dialogs, libqt5webchannel5, qml-module-qtwebchannel, qml-module-qtwebengine, qml-module-qt-labs-folderlistmodel, qml-module-qt-labs-settings Depends: ${shlibs:Depends}, ${misc:Depends}, libqt5quick5, libqt5quickcontrols2-5, libqt5quickwidgets5, qml-module-qtquick-controls, qml-module-qtquick-controls2, qml-module-qtquick-dialogs, libqt5webchannel5, qml-module-qtwebchannel, qml-module-qtwebengine, qml-module-qt-labs-folderlistmodel, qml-module-qt-labs-settings
Description: High Fidelity allows creation and sharing of VR experiences. Description: Overte allows creation and sharing of virtual worlds experiences.
The High Fidelity metaverse provides built-in social features, including avatar interactions, spatialized audio and interactive physics. Additionally, you have the ability to import any 3D object into your virtual environment. Overte provides built-in social features, including avatar interactions, spatialized audio and interactive physics. Additionally, you have the ability to import any 3D object into your virtual environment.

View file

@ -3,25 +3,25 @@
"settings": [ "settings": [
{ {
"name": "metaverse", "name": "metaverse",
"label": "Networking / Metaverse", "label": "Networking / Directory Services",
"settings": [ "settings": [
{ {
"name": "access_token", "name": "access_token",
"label": "Access Token", "label": "Access Token",
"help": "This is your OAuth access token to connect this domain-server with your Metaverse 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 Metaverse Server and generate a token with the 'domains' scope and paste it here.", "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, "advanced": true,
"backup": false "backup": false
}, },
{ {
"name": "id", "name": "id",
"label": "Domain ID", "label": "Domain ID",
"help": "This is your Metaverse domain ID. If you do not want your domain to be registered in the Metaverse you can leave this blank.", "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 "advanced": true
}, },
{ {
"name": "automatic_networking", "name": "automatic_networking",
"label": "Automatic Networking", "label": "Automatic Networking",
"help": "This defines how other nodes in the Metaverse will be able to reach your domain-server.<br/>If you don't want to deal with any network settings, use full 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", "default": "full",
"type": "select", "type": "select",
"options": [ "options": [
@ -35,7 +35,7 @@
}, },
{ {
"value": "disabled", "value": "disabled",
"label": "None: use the network information I have entered for this domain at in the Metaverse Server." "label": "None: use the network information I have entered for this domain at the Directory Server."
} }
] ]
}, },
@ -50,7 +50,7 @@
{ {
"name": "enable_packet_verification", "name": "enable_packet_verification",
"label": "Enable Packet Verification", "label": "Enable Packet Verification",
"help": "Enable secure checksums on communication that uses the Metaverse protocol. Increases security with possibly a small performance penalty.", "help": "Enable secure checksums on communication that uses the Directory Services protocol. Increases security with possibly a small performance penalty.",
"default": true, "default": true,
"type": "checkbox", "type": "checkbox",
"advanced": true "advanced": true
@ -66,7 +66,7 @@
{ {
"name": "metadata_exporter_port", "name": "metadata_exporter_port",
"label": "Metadata Exporter HTTP Port", "label": "Metadata Exporter HTTP Port",
"help": "This is the port where the Metaverse 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.", "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", "default": "9704",
"type": "int", "type": "int",
"advanced": true "advanced": true
@ -182,7 +182,7 @@
"name": "descriptors", "name": "descriptors",
"label": "Description", "label": "Description",
"restart": false, "restart": false,
"help": "This data will be queryable from your server. It may be collected by the Metaverse and used to share your domain with others.", "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": [ "settings": [
{ {
"name": "world_name", "name": "world_name",
@ -1947,7 +1947,7 @@
"label": "Admin Roles", "label": "Admin Roles",
"type": "table", "type": "table",
"can_add_new_rows": true, "can_add_new_rows": true,
"help": "Any user with any of these metaverse roles can administer the domain.", "help": "Any user with any of these roles can administer the domain.",
"numbered": false, "numbered": false,
"backup": false, "backup": false,
"advanced": true, "advanced": true,

View file

@ -61,7 +61,7 @@ var Strings = {
CHOOSE_DOMAIN_BUTTON: "Choose from my domains", CHOOSE_DOMAIN_BUTTON: "Choose from my domains",
CREATE_DOMAIN_BUTTON: "Create new domain ID", CREATE_DOMAIN_BUTTON: "Create new domain ID",
CREATE_DOMAIN_SUCCESS_JUST_CONNECTED: "We connnected your Metaverse account and created a new domain ID for this machine.", CREATE_DOMAIN_SUCCESS_JUST_CONNECTED: "We connected your Directory Services account and created a new domain ID for this machine.",
CREATE_DOMAIN_SUCCESS: "We created a new domain ID for this machine.", CREATE_DOMAIN_SUCCESS: "We created a new domain ID for this machine.",
// When a place modification fails, they will be brought back to the previous // When a place modification fails, they will be brought back to the previous
@ -92,7 +92,7 @@ var Strings = {
ADD_PLACE_LOADING_DIALOG: "Loading your places...", ADD_PLACE_LOADING_DIALOG: "Loading your places...",
ADD_PLACE_NOT_CONNECTED_TITLE: "Access token required", ADD_PLACE_NOT_CONNECTED_TITLE: "Access token required",
ADD_PLACE_NOT_CONNECTED_MESSAGE: "You must have an access token to query your Metaverse places.<br><br>Please follow the instructions on the settings page to add an access token.", ADD_PLACE_NOT_CONNECTED_MESSAGE: "You must have an access token to query your Directory Services places.<br><br>Please follow the instructions on the settings page to add an access token.",
}; };
var DOMAIN_ID_TYPE_NONE = 0; var DOMAIN_ID_TYPE_NONE = 0;
@ -428,7 +428,7 @@ function chooseFromMetaversePlaces(accessToken, forcePathTo, onSuccessfullyAdded
loadPlaces(); loadPlaces();
} else { } else {
loadingDialog.modal('hide'); loadingDialog.modal('hide');
bootbox.confirm("We were not able to load your domain information from the Metaverse. Would you like to retry?", function(response) { bootbox.confirm("We were not able to load your domain information from the Directory Services. Would you like to retry?", function(response) {
if (response) { if (response) {
chooseFromMetaversePlaces(accessToken, forcePathTo, onSuccessfullyAdded); chooseFromMetaversePlaces(accessToken, forcePathTo, onSuccessfullyAdded);
} }

View file

@ -279,7 +279,7 @@ $(document).ready(function(){
swal({ swal({
title: '', title: '',
type: 'error', type: 'error',
text: "There was a problem retrieving domain information from the Metaverse API.", text: "There was a problem retrieving domain information from the Directory Services API.",
confirmButtonText: 'Try again', confirmButtonText: 'Try again',
showCancelButton: true, showCancelButton: true,
closeOnConfirm: false closeOnConfirm: false
@ -308,7 +308,7 @@ $(document).ready(function(){
if (hasAccessToken) { if (hasAccessToken) {
el = "<p>"; el = "<p>";
el += "<span class='account-connected-header'>Metaverse Account Connected</span>"; el += "<span class='account-connected-header'>Directory Services Account Connected</span>";
el += "<button id='" + Settings.DISCONNECT_ACCOUNT_BTN_ID + "' class='btn'>Disconnect</button>"; el += "<button id='" + Settings.DISCONNECT_ACCOUNT_BTN_ID + "' class='btn'>Disconnect</button>";
el += "</p>"; el += "</p>";
el = $(el); el = $(el);
@ -321,7 +321,7 @@ $(document).ready(function(){
} }
buttonSetting.help = ""; buttonSetting.help = "";
buttonSetting.classes = "btn-primary"; buttonSetting.classes = "btn-primary";
buttonSetting.button_label = "Connect Metaverse Account"; buttonSetting.button_label = "Connect Directory Services Account";
buttonSetting.html_id = Settings.CONNECT_ACCOUNT_BTN_ID; buttonSetting.html_id = Settings.CONNECT_ACCOUNT_BTN_ID;
buttonSetting.href = METAVERSE_URL + "/user/tokens/new?for_domain_server=true"; buttonSetting.href = METAVERSE_URL + "/user/tokens/new?for_domain_server=true";
@ -334,7 +334,7 @@ $(document).ready(function(){
el = viewHelpers.getFormGroup('', buttonSetting, Settings.data.values); el = viewHelpers.getFormGroup('', buttonSetting, Settings.data.values);
} }
// add the button group to the top of the metaverse panel // add the button group to the top of the Directory Services panel
$('#metaverse .panel-body').prepend(el); $('#metaverse .panel-body').prepend(el);
} }
@ -730,7 +730,7 @@ $(document).ready(function(){
html_id: Settings.PLACES_TABLE_ID, html_id: Settings.PLACES_TABLE_ID,
help: "To point places to this domain, " help: "To point places to this domain, "
+ " go to the <a href='" + METAVERSE_URL + "/user/places'>Places</a> " + " go to the <a href='" + METAVERSE_URL + "/user/places'>Places</a> "
+ "page in your Metaverse account.", + "page in your Directory Services account.",
read_only: true, read_only: true,
can_add_new_rows: false, can_add_new_rows: false,
columns: [ columns: [
@ -1015,7 +1015,7 @@ $(document).ready(function(){
if (data.data.domains.length) { if (data.data.domains.length) {
// setup a select box for the returned domains // setup a select box for the returned domains
modal_body = "<p>Choose the Metaverse domain you want this domain-server to represent.<br/>This will set your domain ID on the settings page.</p>"; modal_body = "<p>Choose the Directory Services domain you want this domain-server to represent.<br/>This will set your domain ID on the settings page.</p>";
domain_select = $("<select id='domain-name-select' class='form-control'></select>"); domain_select = $("<select id='domain-name-select' class='form-control'></select>");
_.each(data.data.domains, function(domain){ _.each(data.data.domains, function(domain){
var domainString = ""; var domainString = "";
@ -1044,7 +1044,7 @@ $(document).ready(function(){
window.open(METAVERSE_URL + "/user/domains", '_blank'); window.open(METAVERSE_URL + "/user/domains", '_blank');
} }
} }
modal_body = "<p>You do not have any domains in your Metaverse account." + modal_body = "<p>You do not have any domains in your Directory Services account." +
"<br/><br/>Go to your domains page to create a new one. Once your domain is created re-open this dialog to select it.</p>" "<br/><br/>Go to your domains page to create a new one. Once your domain is created re-open this dialog to select it.</p>"
} }
@ -1056,7 +1056,7 @@ $(document).ready(function(){
}) })
}, },
error: function() { error: function() {
bootbox.alert("Failed to retrieve your domains from the Metaverse"); bootbox.alert("Failed to retrieve your domains from the Directory Server");
}, },
complete: function() { complete: function() {
// remove the spinner from the choose button // remove the spinner from the choose button
@ -1067,7 +1067,7 @@ $(document).ready(function(){
} else { } else {
bootbox.alert({ bootbox.alert({
message: "You must have an access token to query your Metaverse domains.<br><br>" + message: "You must have an access token to query your Directory Services domains.<br><br>" +
"Please follow the instructions on the settings page to add an access token.", "Please follow the instructions on the settings page to add an access token.",
title: "Access token required" title: "Access token required"
}) })

View file

@ -3,12 +3,12 @@
<h4 class="step-title"></h4> <h4 class="step-title"></h4>
<dl class="row"> <dl class="row">
<dd class="col-md-12"> <dd class="col-md-12">
<span class='step-description'>Connect your Metaverse account to be able to make your domain discoverable and add account based authentication. You can always do this later.</span> <span class='step-description'>Connect your Directory Services to be able to make your domain discoverable and add account based authentication. You can always do this later.</span>
</dd> </dd>
</dl> </dl>
<dl class="row"> <dl class="row">
<dd class="col-md-12"> <dd class="col-md-12">
<a id="connect-account-btn" role="button" class="btn btn-primary btn-md btn-block" target="_blank">Connect your Metaverse account</a> <a id="connect-account-btn" role="button" class="btn btn-primary btn-md btn-block" target="_blank">Connect your Directory Services account</a>
</dd> </dd>
</dl> </dl>
@ -60,7 +60,7 @@
</div> </div>
<div id="admin-row" class="row"> <div id="admin-row" class="row">
<p class="col-md-6"> <p class="col-md-6">
<span class="step-info"><span id="admin-description"><b>Add your Metaverse username</b> and any other usernames</span> to grant <span class='wizard-link' data-toggle="tooltip" title="Users who will have all the permissions for this domain.">administrator privileges</span></span> <span class="step-info"><span id="admin-description"><b>Add your Directory Services username</b> and any other usernames</span> to grant <span class='wizard-link' data-toggle="tooltip" title="Users who will have all the permissions for this domain.">administrator privileges</span></span>
</p> </p>
<div class="col-md-6"> <div class="col-md-6">
<input id="admin-usernames" type="text" class="form-control"> <input id="admin-usernames" type="text" class="form-control">
@ -95,7 +95,7 @@
</p> </p>
<p class="col-md-5"> <p class="col-md-5">
<label> <label>
<input id="connect-logged-in" name="connect-radio" type="radio" value="logged-in"> Users logged into the Metaverse <input id="connect-logged-in" name="connect-radio" type="radio" value="logged-in"> Users logged into the Directory Services
</label> </label>
</p> </p>
<p class="col-md-2"> <p class="col-md-2">
@ -126,7 +126,7 @@
</p> </p>
<p class="col-md-5"> <p class="col-md-5">
<label> <label>
<input id="rez-logged-in" name="rez-radio" type="radio" value="logged-in" disabled> Users logged into the Metaverse <input id="rez-logged-in" name="rez-radio" type="radio" value="logged-in" disabled> Users logged into the Directory Services
</label> </label>
</p> </p>
<p class="col-md-2"> <p class="col-md-2">
@ -164,14 +164,14 @@
<dt class="col-md-4 step-info">Username</dt> <dt class="col-md-4 step-info">Username</dt>
<dd class="col-md-8"> <dd class="col-md-8">
<input id="http_username" type="text" class="form-control"> <input id="http_username" type="text" class="form-control">
<span class='help-block'>This does not have to be your Metaverse username</span> <span class='help-block'>This does not have to be your Directory Services username</span>
</dd> </dd>
</dl> </dl>
<dl class="row"> <dl class="row">
<dt class="col-md-4 step-info">Enter password</dt> <dt class="col-md-4 step-info">Enter password</dt>
<dd class="col-md-8"> <dd class="col-md-8">
<input id="http_password" type="password" class="form-control"> <input id="http_password" type="password" class="form-control">
<span class='help-block'>This should not be the same as your Metaverse password</span> <span class='help-block'>This should not be the same as your Directory Services password</span>
</dd> </dd>
</dl> </dl>
<dl id="verify-password-row" class="row"> <dl id="verify-password-row" class="row">

View file

@ -20,9 +20,9 @@ $(document).ready(function(){
$('.perms-link').on('click', function() { $('.perms-link').on('click', function() {
var modal_body = '<div>'; var modal_body = '<div>';
modal_body += '<b>None</b> - No one will have permissions. Only you and the users your have given administrator privileges to will have permissions.</br></br>'; modal_body += '<b>None</b> - No one will have permissions. Only you and the users your have given administrator privileges to will have permissions.</br></br>';
modal_body += '<b>Friends</b> - Users who are your Friends in the Metaverse.</br></br>'; modal_body += '<b>Friends</b> - Users who are your Friends in the Directory Services.</br></br>';
modal_body += '<b>Users logged into the Metaverse</b> - Users who are currently logged into the Metaverse.</br></br>'; modal_body += '<b>Users logged into the Directory Services</b> - Users who are currently logged into the Directory Services.</br></br>';
modal_body += '<b>Everyone</b> - Anyone who uses the Metaverse.'; modal_body += '<b>Everyone</b> - Any user, both logged in and not logged in.';
modal_body += '</div>'; modal_body += '</div>';
dialog = bootbox.dialog({ dialog = bootbox.dialog({
@ -153,7 +153,7 @@ function setupWizardSteps() {
}); });
$('#permissions-description').html('You <span id="username-display"></span>have been assigned administrator privileges to this domain.'); $('#permissions-description').html('You <span id="username-display"></span>have been assigned administrator privileges to this domain.');
$('#admin-description').html('Add more Metaverse usernames'); $('#admin-description').html('Add more Directory Services usernames');
} else { } else {
$('.cloud-only').remove(); $('.cloud-only').remove();
$('#save-threading-settings').text("Finish"); $('#save-threading-settings').text("Finish");
@ -207,7 +207,7 @@ function promptToCreateDomainID() {
if (data && data.status === "failure") { if (data && data.status === "failure") {
swal.showInputError("Error: " + data.error); swal.showInputError("Error: " + data.error);
} else { } else {
swal.showInputError("Error: Failed to post to metaverse."); swal.showInputError("Error: Failed to post to directory server.");
} }
console.log("Failed to create domain ID..."); console.log("Failed to create domain ID...");
}); });
@ -250,7 +250,7 @@ function updatePlaceNameDisplay() {
console.warn('Request Failed'); console.warn('Request Failed');
}); });
} else { } else {
console.warn('No metaverse domain ID!'); console.warn('No Directory Services domain ID!');
} }
} }

View file

@ -178,7 +178,7 @@ NodePermissions DomainGatekeeper::setPermissionsForUser(bool isLocalUser, QStrin
} }
// If this user is a known member of a domain group, give them the implied permissions. // If this user is a known member of a domain group, give them the implied permissions.
// Do before processing verifiedUsername in case user is logged into the metaverse and is a member of a blacklist group. // Do before processing verifiedUsername in case user is logged into the Directory Services and is a member of a blacklist group.
if (!verifiedDomainUserName.isEmpty()) { if (!verifiedDomainUserName.isEmpty()) {
auto userGroups = _domainGroupMemberships[verifiedDomainUserName]; auto userGroups = _domainGroupMemberships[verifiedDomainUserName];
foreach (QString userGroup, userGroups) { foreach (QString userGroup, userGroups) {
@ -249,10 +249,10 @@ NodePermissions DomainGatekeeper::setPermissionsForUser(bool isLocalUser, QStrin
qDebug() << "| user-permissions: specific IP matches, so:" << userPerms; qDebug() << "| user-permissions: specific IP matches, so:" << userPerms;
#endif #endif
} else { } else {
// they are logged into metaverse, but we don't have specific permissions for them. // they are logged into Directory Services, but we don't have specific permissions for them.
userPerms |= _server->_settingsManager.getStandardPermissionsForName(NodePermissions::standardNameLoggedIn); userPerms |= _server->_settingsManager.getStandardPermissionsForName(NodePermissions::standardNameLoggedIn);
#ifdef WANT_DEBUG #ifdef WANT_DEBUG
qDebug() << "| user-permissions: user is logged-into metaverse, so:" << userPerms; qDebug() << "| user-permissions: user is logged-into Directory Services, so:" << userPerms;
#endif #endif
// if this user is a friend of the domain-owner, give them friend's permissions // if this user is a friend of the domain-owner, give them friend's permissions
@ -568,7 +568,7 @@ SharedNodePointer DomainGatekeeper::processAgentConnectRequest(const NodeConnect
nodeConnection.senderSockAddr, DomainHandler::ConnectionRefusedReason::NotAuthorizedDomain, nodeConnection.senderSockAddr, DomainHandler::ConnectionRefusedReason::NotAuthorizedDomain,
domainAuthURL + "|" + domainAuthClientID); domainAuthURL + "|" + domainAuthClientID);
} else { } else {
sendConnectionDeniedPacket("You lack the required metaverse permissions to connect to this domain.", sendConnectionDeniedPacket("You lack the required Directory Services permissions to connect to this domain.",
nodeConnection.senderSockAddr, DomainHandler::ConnectionRefusedReason::NotAuthorizedMetaverse); nodeConnection.senderSockAddr, DomainHandler::ConnectionRefusedReason::NotAuthorizedMetaverse);
} }
#ifdef WANT_DEBUG #ifdef WANT_DEBUG
@ -737,11 +737,11 @@ bool DomainGatekeeper::verifyUserSignature(const QString& username,
// (a key that we hoped would work but is probably stale) // (a key that we hoped would work but is probably stale)
if (!senderSockAddr.isNull() && !isOptimisticKey) { if (!senderSockAddr.isNull() && !isOptimisticKey) {
qDebug() << "Error decrypting metaverse username signature for" << username << "- denying connection."; qDebug() << "Error decrypting directory services username signature for" << username << "- denying connection.";
sendConnectionDeniedPacket("Error decrypting username signature.", senderSockAddr, sendConnectionDeniedPacket("Error decrypting username signature.", senderSockAddr,
DomainHandler::ConnectionRefusedReason::LoginErrorMetaverse); DomainHandler::ConnectionRefusedReason::LoginErrorMetaverse);
} else if (!senderSockAddr.isNull()) { } else if (!senderSockAddr.isNull()) {
qDebug() << "Error decrypting metaverse username signature for" << username << "with optimistic key -" qDebug() << "Error decrypting directory services username signature for" << username << "with optimistic key -"
<< "re-requesting public key and delaying connection"; << "re-requesting public key and delaying connection";
} }
@ -1291,7 +1291,7 @@ void DomainGatekeeper::requestDomainUserFinished() {
QStringList domainUserGroups; QStringList domainUserGroups;
auto userRoles = rootObject.value("roles").toArray(); auto userRoles = rootObject.value("roles").toArray();
foreach (auto role, userRoles) { foreach (auto role, userRoles) {
// Distinguish domain groups from metaverse groups by adding a leading special character. // Distinguish domain groups from directory services groups by adding a leading special character.
domainUserGroups.append(DOMAIN_GROUP_CHAR + role.toString().toLower()); domainUserGroups.append(DOMAIN_GROUP_CHAR + role.toString().toLower());
} }
_domainGroupMemberships[username] = domainUserGroups; _domainGroupMemberships[username] = domainUserGroups;

View file

@ -76,7 +76,7 @@ public slots:
private slots: private slots:
void handlePeerPingTimeout(); void handlePeerPingTimeout();
// Login and groups for domain, separate from metaverse. // Login and groups for domain, separate from directory services.
void requestDomainUserFinished(); void requestDomainUserFinished();
private: private:
@ -153,7 +153,7 @@ private:
Node::LocalID _currentLocalID; Node::LocalID _currentLocalID;
Node::LocalID _idIncrement; Node::LocalID _idIncrement;
// Login and groups for domain, separate from metaverse. // Login and groups for domain, separate from directory services.
bool domainHasLogin(); bool domainHasLogin();
void requestDomainUser(const QString& username, const QString& accessToken, const QString& refreshToken); void requestDomainUser(const QString& username, const QString& accessToken, const QString& refreshToken);

View file

@ -86,10 +86,10 @@ bool DomainServer::_getTempName { false };
QString DomainServer::_userConfigFilename; QString DomainServer::_userConfigFilename;
int DomainServer::_parentPID { -1 }; int DomainServer::_parentPID { -1 };
/// @brief The Domain server can proxy requests to the Metaverse server, this function handles those forwarding requests. /// @brief The Domain server can proxy requests to the Directory Server, this function handles those forwarding requests.
/// @param connection The HTTP connection object. /// @param connection The HTTP connection object.
/// @param requestUrl The full URL of the request. e.g. https://google.com/api/v1/test /// @param requestUrl The full URL of the request. e.g. https://google.com/api/v1/test
/// @param metaversePath The path on the Metaverse server to route to. /// @param metaversePath The path on the Directory Server to route to.
/// @param requestSubobjectKey (Optional) The parent object key that any data will be inserted into for the forwarded request. /// @param requestSubobjectKey (Optional) The parent object key that any data will be inserted into for the forwarded request.
/// @param requiredData (Optional) This data is required to be present for the request. /// @param requiredData (Optional) This data is required to be present for the request.
/// @param optionalData (Optional) If provided, this optional data will be forwarded with the request. /// @param optionalData (Optional) If provided, this optional data will be forwarded with the request.
@ -180,7 +180,7 @@ bool DomainServer::forwardMetaverseAPIRequest(HTTPConnection* connection,
connect(reply, &QNetworkReply::finished, this, [reply, connection]() { connect(reply, &QNetworkReply::finished, this, [reply, connection]() {
if (reply->error() != QNetworkReply::NoError) { if (reply->error() != QNetworkReply::NoError) {
auto data = reply->readAll(); auto data = reply->readAll();
qDebug() << "Got error response from metaverse server (" << reply->url() << "): " << data << reply->errorString(); qDebug() << "Got error response from directory server (" << reply->url() << "): " << data << reply->errorString();
connection->respond(HTTPConnection::StatusCode400, data); connection->respond(HTTPConnection::StatusCode400, data);
return; return;
} }
@ -298,14 +298,14 @@ DomainServer::DomainServer(int argc, char* argv[]) :
#endif #endif
if (_type != NonMetaverse) { if (_type != NonMetaverse) {
// if we have a metaverse domain, we'll use an access token for API calls // if we have a directory services domain, we'll use an access token for API calls
resetAccountManagerAccessToken(); resetAccountManagerAccessToken();
setupAutomaticNetworking(); setupAutomaticNetworking();
} }
if (!getID().isNull() && _type != NonMetaverse) { if (!getID().isNull() && _type != NonMetaverse) {
// setup periodic heartbeats to metaverse API // setup periodic heartbeats to directory services API
setupHeartbeatToMetaverse(); setupHeartbeatToMetaverse();
// send the first heartbeat immediately // send the first heartbeat immediately
@ -988,7 +988,7 @@ bool DomainServer::resetAccountManagerAccessToken() {
if (accessTokenVariant.canConvert(QMetaType::QString)) { if (accessTokenVariant.canConvert(QMetaType::QString)) {
accessToken = accessTokenVariant.toString(); accessToken = accessTokenVariant.toString();
} else { } else {
qWarning() << "No access token is present. Some operations that use the metaverse API will fail."; qWarning() << "No access token is present. Some operations that use the directory services API will fail.";
qDebug() << "Set an access token via the web interface, in your user config" qDebug() << "Set an access token via the web interface, in your user config"
<< "at keypath metaverse.access_token or in your ENV at key DOMAIN_SERVER_ACCESS_TOKEN"; << "at keypath metaverse.access_token or in your ENV at key DOMAIN_SERVER_ACCESS_TOKEN";
@ -1799,7 +1799,7 @@ void DomainServer::sendICEServerAddressToMetaverseAPI() {
callbackParameters.errorCallbackMethod = "handleFailedICEServerAddressUpdate"; callbackParameters.errorCallbackMethod = "handleFailedICEServerAddressUpdate";
callbackParameters.jsonCallbackMethod = "handleSuccessfulICEServerAddressUpdate"; callbackParameters.jsonCallbackMethod = "handleSuccessfulICEServerAddressUpdate";
qCDebug(domain_server_ice) << "Updating ice-server address in Metaverse API to" qCDebug(domain_server_ice) << "Updating ice-server address in Directory Services API to"
<< (_iceServerSocket.isNull() ? "" : _iceServerSocket.getAddress().toString()); << (_iceServerSocket.isNull() ? "" : _iceServerSocket.getAddress().toString());
static const QString DOMAIN_ICE_ADDRESS_UPDATE = "/api/v1/domains/%1/ice_server_address"; static const QString DOMAIN_ICE_ADDRESS_UPDATE = "/api/v1/domains/%1/ice_server_address";
@ -1814,11 +1814,11 @@ void DomainServer::sendICEServerAddressToMetaverseAPI() {
void DomainServer::handleSuccessfulICEServerAddressUpdate(QNetworkReply* requestReply) { void DomainServer::handleSuccessfulICEServerAddressUpdate(QNetworkReply* requestReply) {
_sendICEServerAddressToMetaverseAPIInProgress = false; _sendICEServerAddressToMetaverseAPIInProgress = false;
if (_sendICEServerAddressToMetaverseAPIRedo) { if (_sendICEServerAddressToMetaverseAPIRedo) {
qCDebug(domain_server_ice) << "ice-server address (" << _iceServerSocket << ") updated with metaverse, but has since changed. redoing update..."; qCDebug(domain_server_ice) << "ice-server address (" << _iceServerSocket << ") updated with directory server, but has since changed. redoing update...";
_sendICEServerAddressToMetaverseAPIRedo = false; _sendICEServerAddressToMetaverseAPIRedo = false;
sendICEServerAddressToMetaverseAPI(); sendICEServerAddressToMetaverseAPI();
} else { } else {
qCDebug(domain_server_ice) << "ice-server address (" << _iceServerSocket << ") updated with metaverse."; qCDebug(domain_server_ice) << "ice-server address (" << _iceServerSocket << ") updated with directory server.";
} }
} }
@ -1832,7 +1832,7 @@ void DomainServer::handleFailedICEServerAddressUpdate(QNetworkReply* requestRepl
const int ICE_SERVER_UPDATE_RETRY_MS = 2 * 1000; const int ICE_SERVER_UPDATE_RETRY_MS = 2 * 1000;
qCWarning(domain_server_ice) << "PAGE: Failed to update ice-server address (" << _iceServerSocket << qCWarning(domain_server_ice) << "PAGE: Failed to update ice-server address (" << _iceServerSocket <<
") with Metaverse (" << requestReply->url() << ") (critical error for auto-networking) error:" << ") with Directory Server (" << requestReply->url() << ") (critical error for auto-networking) error:" <<
requestReply->errorString(); requestReply->errorString();
qCWarning(domain_server_ice) << "\tRe-attempting in" << ICE_SERVER_UPDATE_RETRY_MS / 1000 << "seconds"; qCWarning(domain_server_ice) << "\tRe-attempting in" << ICE_SERVER_UPDATE_RETRY_MS / 1000 << "seconds";
@ -2655,9 +2655,9 @@ bool DomainServer::handleHTTPRequest(HTTPConnection* connection, const QUrl& url
connect(reply, &QNetworkReply::finished, this, [reply, connection]() { connect(reply, &QNetworkReply::finished, this, [reply, connection]() {
if (reply->error() != QNetworkReply::NoError) { if (reply->error() != QNetworkReply::NoError) {
qDebug() << "Got error response from metaverse server: " << reply->readAll(); qDebug() << "Got error response from Directory Server: " << reply->readAll();
connection->respond(HTTPConnection::StatusCode500, connection->respond(HTTPConnection::StatusCode500,
"Error communicating with Metaverse"); "Error communicating with Directory Server");
return; return;
} }
@ -3761,7 +3761,7 @@ void DomainServer::randomizeICEServerAddress(bool shouldTriggerHostLookup) {
// immediately fire an ICE heartbeat once we've picked a candidate ice-server // immediately fire an ICE heartbeat once we've picked a candidate ice-server
sendHeartbeatToIceServer(); sendHeartbeatToIceServer();
// immediately send an update to the metaverse API when our ice-server changes // immediately send an update to the directory services API when our ice-server changes
sendICEServerAddressToMetaverseAPI(); sendICEServerAddressToMetaverseAPI();
} }

View file

@ -2016,7 +2016,7 @@ void DomainServerSettingsManager::apiRefreshGroupInformation() {
foreach (QString groupName, groupNames) { foreach (QString groupName, groupNames) {
QString lowerGroupName = groupName.toLower(); QString lowerGroupName = groupName.toLower();
if (lowerGroupName.startsWith(DOMAIN_GROUP_CHAR)) { if (lowerGroupName.startsWith(DOMAIN_GROUP_CHAR)) {
// Ignore domain groups. (Assumption: metaverse group names can't start with a "@".) // Ignore domain groups. (Assumption: Directory Services group names can't start with a "@".)
return; return;
} }
if (_groupIDs.contains(lowerGroupName)) { if (_groupIDs.contains(lowerGroupName)) {
@ -2239,7 +2239,7 @@ QList<QUuid> DomainServerSettingsManager::getBlacklistGroupIDs() {
} }
QStringList DomainServerSettingsManager::getDomainServerGroupNames() { QStringList DomainServerSettingsManager::getDomainServerGroupNames() {
// All names as listed in the domain server settings; both metaverse groups and domain groups // All names as listed in the domain server settings; both Directory Services groups and domain groups
QSet<QString> result; QSet<QString> result;
foreach(NodePermissionsKey groupKey, _groupPermissions.keys()) { foreach(NodePermissionsKey groupKey, _groupPermissions.keys()) {
result += _groupPermissions[groupKey]->getID(); result += _groupPermissions[groupKey]->getID();
@ -2248,7 +2248,7 @@ QStringList DomainServerSettingsManager::getDomainServerGroupNames() {
} }
QStringList DomainServerSettingsManager::getDomainServerBlacklistGroupNames() { QStringList DomainServerSettingsManager::getDomainServerBlacklistGroupNames() {
// All names as listed in the domain server settings; not necessarily mnetaverse groups. // All names as listed in the domain server settings; not necessarily Directory Services groups.
QSet<QString> result; QSet<QString> result;
foreach (NodePermissionsKey groupKey, _groupForbiddens.keys()) { foreach (NodePermissionsKey groupKey, _groupForbiddens.keys()) {
result += _groupForbiddens[groupKey]->getID(); result += _groupForbiddens[groupKey]->getID();

View file

@ -110,7 +110,7 @@ public:
QStringList getDomainServerGroupNames(); QStringList getDomainServerGroupNames();
QStringList getDomainServerBlacklistGroupNames(); QStringList getDomainServerBlacklistGroupNames();
// these are used to locally cache the result of calling "/api/v1/groups/.../is_member/..." on metaverse's api // these are used to locally cache the result of calling "/api/v1/groups/.../is_member/..." on Directory Services api
void clearGroupMemberships(const QString& name) { _groupMembership[name.toLower()].clear(); } void clearGroupMemberships(const QString& name) { _groupMembership[name.toLower()].clear(); }
void recordGroupMembership(const QString& name, const QUuid groupID, QUuid rankID); void recordGroupMembership(const QString& name, const QUuid groupID, QUuid rankID);
QUuid isGroupMember(const QString& name, const QUuid& groupID); // returns rank or -1 if not a member QUuid isGroupMember(const QString& name, const QUuid& groupID); // returns rank or -1 if not a member
@ -177,7 +177,7 @@ private:
// is done with the returned QVariant* // is done with the returned QVariant*
HifiConfigVariantMap _configMap; HifiConfigVariantMap _configMap;
// these cause calls to metaverse's group api // these cause calls to directory services group api
void apiGetGroupID(const QString& groupName); void apiGetGroupID(const QString& groupName);
void apiGetGroupRanks(const QUuid& groupID); void apiGetGroupRanks(const QUuid& groupID);

View file

@ -206,7 +206,7 @@ bool IceServer::isVerifiedHeartbeat(const QUuid& domainID, const QByteArray& pla
} }
// we could not verify this heartbeat (missing public key, could not load public key, bad actor) // we could not verify this heartbeat (missing public key, could not load public key, bad actor)
// ask the metaverse API for the right public key and return false to indicate that this is not verified // ask the directory services API for the right public key and return false to indicate that this is not verified
requestDomainPublicKey(domainID); requestDomainPublicKey(domainID);
} }
@ -214,7 +214,7 @@ bool IceServer::isVerifiedHeartbeat(const QUuid& domainID, const QByteArray& pla
} }
void IceServer::requestDomainPublicKey(const QUuid& domainID) { void IceServer::requestDomainPublicKey(const QUuid& domainID) {
// send a request to the metaverse API for the public key for this domain // send a request to the directory services API for the public key for this domain
auto& networkAccessManager = NetworkAccessManager::getInstance(); auto& networkAccessManager = NetworkAccessManager::getInstance();
QUrl publicKeyURL{ MetaverseAPI::getCurrentMetaverseServerURL() }; QUrl publicKeyURL{ MetaverseAPI::getCurrentMetaverseServerURL() };
@ -281,7 +281,7 @@ void IceServer::publicKeyReplyFinished(QNetworkReply* reply) {
qWarning() << "There was no public key present in response for domain with ID" << domainID; qWarning() << "There was no public key present in response for domain with ID" << domainID;
} }
} else { } else {
qWarning() << "The metaverse API did not return success for public key request for domain with ID" << domainID; qWarning() << "The directory services API did not return success for public key request for domain with ID" << domainID;
} }
} else { } else {

View file

@ -45,7 +45,7 @@ Item {
property bool lostFocus: false property bool lostFocus: false
readonly property bool loginDialogPoppedUp: loginDialog.getLoginDialogPoppedUp() readonly property bool loginDialogPoppedUp: loginDialog.getLoginDialogPoppedUp()
// If not logging into domain, then we must be logging into the metaverse... // If not logging into domain, then we must be logging into the directory services...
readonly property bool isLoggingInToDomain: loginDialog.getDomainLoginRequested() readonly property bool isLoggingInToDomain: loginDialog.getDomainLoginRequested()
readonly property string domainLoginDomain: loginDialog.getDomainLoginDomain() readonly property string domainLoginDomain: loginDialog.getDomainLoginDomain()
@ -74,7 +74,7 @@ Item {
} }
function login() { function login() {
// make sure the metaverse server is set so we don't send your password to the wrong place! // make sure the directory server is set so we don't send your password to the wrong place!
if (!isLoggingInToDomain) { if (!isLoggingInToDomain) {
Settings.setValue("private/selectedMetaverseURL", metaverseServerField.text); Settings.setValue("private/selectedMetaverseURL", metaverseServerField.text);
} }
@ -120,9 +120,9 @@ Item {
errorContainer.height = (loginErrorMessageTextMetrics.width / displayNameField.width) * loginErrorMessageTextMetrics.height; errorContainer.height = (loginErrorMessageTextMetrics.width / displayNameField.width) * loginErrorMessageTextMetrics.height;
} }
var domainLoginText = "Log In to Domain\n" + domainLoginDomain; var domainLoginText = "Log In to Domain\n" + domainLoginDomain;
loginDialogText.text = (!isLoggingInToDomain) ? "Log In to Metaverse" : domainLoginText; loginDialogText.text = (!isLoggingInToDomain) ? "Log In to Directory Service" : domainLoginText;
loginButton.text = (!linkAccountBody.linkSteam && !linkAccountBody.linkOculus) ? "Log In" : "Link Account"; loginButton.text = (!linkAccountBody.linkSteam && !linkAccountBody.linkOculus) ? "Log In" : "Link Account";
loginButton.text = (!isLoggingInToDomain) ? "Log In to Metaverse" : "Log In to Domain"; loginButton.text = (!isLoggingInToDomain) ? "Log In to Directory Service" : "Log In to Domain";
loginButton.color = hifi.buttons.blue; loginButton.color = hifi.buttons.blue;
displayNameField.placeholderText = "Display Name (optional)"; displayNameField.placeholderText = "Display Name (optional)";
var savedDisplayName = Settings.getValue("Avatar/displayName", ""); var savedDisplayName = Settings.getValue("Avatar/displayName", "");
@ -133,7 +133,7 @@ Item {
emailField.text = keepMeLoggedInCheckbox.checked ? savedUsername === "Unknown user" ? "" : savedUsername : ""; emailField.text = keepMeLoggedInCheckbox.checked ? savedUsername === "Unknown user" ? "" : savedUsername : "";
var metaverseServer = Settings.getValue("private/selectedMetaverseURL", ""); var metaverseServer = Settings.getValue("private/selectedMetaverseURL", "");
console.log("Saved metaverse server:", metaverseServer); console.log("Saved directory server:", metaverseServer);
metaverseServerField.text = metaverseServer; metaverseServerField.text = metaverseServer;
} else { } else {
// ####### TODO // ####### TODO
@ -388,7 +388,7 @@ Item {
top: passwordField.bottom top: passwordField.bottom
topMargin: 1.5 * hifi.dimensions.contentSpacing.y topMargin: 1.5 * hifi.dimensions.contentSpacing.y
} }
placeholderText: "Metaverse Server (optional)" placeholderText: "Directory Server (optional)"
activeFocusOnPress: true activeFocusOnPress: true
Keys.onPressed: { Keys.onPressed: {
switch (event.key) { switch (event.key) {
@ -405,7 +405,7 @@ Item {
event.accepted = true; event.accepted = true;
if (!isLoggingInToDomain) { if (!isLoggingInToDomain) {
var url = metaverseServerField.text; var url = metaverseServerField.text;
console.log("Setting metaverse server to", url); console.log("Setting directory server to", url);
Settings.setValue("private/selectedMetaverseURL", url); Settings.setValue("private/selectedMetaverseURL", url);
if(AccountServices.isLoggedIn()){ if(AccountServices.isLoggedIn()){
AccountServices.logOut(); AccountServices.logOut();
@ -424,7 +424,7 @@ Item {
var url = metaverseServerField.text; var url = metaverseServerField.text;
if(!(url == Settings.getValue("private/selectedMetaverseURL")) && !(url == "")){ if(!(url == Settings.getValue("private/selectedMetaverseURL")) && !(url == "")){
if (!isLoggingInToDomain) { if (!isLoggingInToDomain) {
console.log("Setting metaverse server to", url); console.log("Setting directory server to", url);
Settings.setValue("private/selectedMetaverseURL", url); Settings.setValue("private/selectedMetaverseURL", url);
if(AccountServices.isLoggedIn()){ if(AccountServices.isLoggedIn()){
AccountServices.logOut(); AccountServices.logOut();

View file

@ -1273,7 +1273,7 @@ Application::Application(
// to has gone down and switched to a new content set, so when you reconnect the cached ATP assets will no longer be valid. // to has gone down and switched to a new content set, so when you reconnect the cached ATP assets will no longer be valid.
connect(&domainHandler, &DomainHandler::disconnectedFromDomain, DependencyManager::get<ScriptCache>().data(), &ScriptCache::clearATPScriptsFromCache); connect(&domainHandler, &DomainHandler::disconnectedFromDomain, DependencyManager::get<ScriptCache>().data(), &ScriptCache::clearATPScriptsFromCache);
// update our location every 5 seconds in the metaverse server, assuming that we are authenticated with one // update our location every 5 seconds in the directory server, assuming that we are authenticated with one
const qint64 DATA_SERVER_LOCATION_CHANGE_UPDATE_MSECS = 5 * MSECS_PER_SECOND; const qint64 DATA_SERVER_LOCATION_CHANGE_UPDATE_MSECS = 5 * MSECS_PER_SECOND;
auto discoverabilityManager = DependencyManager::get<DiscoverabilityManager>(); auto discoverabilityManager = DependencyManager::get<DiscoverabilityManager>();
@ -1282,7 +1282,7 @@ Application::Application(
DependencyManager::get<AddressManager>().data(), &AddressManager::storeCurrentAddress); DependencyManager::get<AddressManager>().data(), &AddressManager::storeCurrentAddress);
locationUpdateTimer.start(DATA_SERVER_LOCATION_CHANGE_UPDATE_MSECS); locationUpdateTimer.start(DATA_SERVER_LOCATION_CHANGE_UPDATE_MSECS);
// if we get a domain change, immediately attempt update location in metaverse server // if we get a domain change, immediately attempt update location in directory server
connect(&nodeList->getDomainHandler(), &DomainHandler::connectedToDomain, connect(&nodeList->getDomainHandler(), &DomainHandler::connectedToDomain,
discoverabilityManager.data(), &DiscoverabilityManager::updateLocation); discoverabilityManager.data(), &DiscoverabilityManager::updateLocation);
@ -2571,7 +2571,7 @@ Application::Application(
_pendingIdleEvent = false; _pendingIdleEvent = false;
_graphicsEngine.startup(); _graphicsEngine.startup();
qCDebug(interfaceapp) << "Metaverse session ID is" << uuidStringWithoutCurlyBraces(accountManager->getSessionID()); qCDebug(interfaceapp) << "Directory Service session ID is" << uuidStringWithoutCurlyBraces(accountManager->getSessionID());
#if defined(Q_OS_ANDROID) #if defined(Q_OS_ANDROID)
connect(&AndroidHelper::instance(), &AndroidHelper::beforeEnterBackground, this, &Application::beforeEnterBackground); connect(&AndroidHelper::instance(), &AndroidHelper::beforeEnterBackground, this, &Application::beforeEnterBackground);
@ -7210,9 +7210,9 @@ void Application::updateWindowTitle() const {
QString metaverseDetails; QString metaverseDetails;
if (isMetaverseLoggedIn) { if (isMetaverseLoggedIn) {
metaverseDetails = " (Metaverse: Connected to " + MetaverseAPI::getCurrentMetaverseServerURL().toString() + " as " + metaverseUsername + ")"; metaverseDetails = " (Directory Services: Connected to " + MetaverseAPI::getCurrentMetaverseServerURL().toString() + " as " + metaverseUsername + ")";
} else { } else {
metaverseDetails = " (Metaverse: Not Logged In)"; metaverseDetails = " (Directory Services: Not Logged In)";
} }
QString domainDetails; QString domainDetails;

View file

@ -118,7 +118,7 @@ void DiscoverabilityManager::updateLocation() {
callbackParameters, QJsonDocument(rootObject).toJson()); callbackParameters, QJsonDocument(rootObject).toJson());
} else if (UserActivityLogger::getInstance().isEnabled()) { } else if (UserActivityLogger::getInstance().isEnabled()) {
// we still send a heartbeat to the metaverse server for stats collection // we still send a heartbeat to the directory server for stats collection
JSONCallbackParameters callbackParameters; JSONCallbackParameters callbackParameters;
callbackParameters.callbackReceiver = this; callbackParameters.callbackReceiver = this;

View file

@ -18,7 +18,7 @@
/*@jsdoc /*@jsdoc
* The <code>LocationBookmarks</code> API provides facilities for working with location bookmarks. A location bookmark * The <code>LocationBookmarks</code> API provides facilities for working with location bookmarks. A location bookmark
* associates a name with a metaverse address. * associates a name with a directory services address.
* *
* @namespace LocationBookmarks * @namespace LocationBookmarks
* *
@ -38,11 +38,11 @@ public:
static const QString HOME_BOOKMARK; static const QString HOME_BOOKMARK;
/*@jsdoc /*@jsdoc
* Gets the metaverse address associated with a bookmark. * Gets the directory services address associated with a bookmark.
* @function LocationBookmarks.getAddress * @function LocationBookmarks.getAddress
* @param {string} bookmarkName - Name of the bookmark to get the metaverse address for (case sensitive). * @param {string} bookmarkName - Name of the bookmark to get the directory services address for (case sensitive).
* @returns {string} The metaverse address for the bookmark. If the bookmark does not exist, <code>""</code> is returned. * @returns {string} The directory services address for the bookmark. If the bookmark does not exist, <code>""</code> is returned.
* @example <caption>Report the "Home" bookmark's metaverse address.</caption> * @example <caption>Report the "Home" bookmark's directory services address.</caption>
* print("Home bookmark's address: " + LocationBookmarks.getAddress("Home")); * print("Home bookmark's address: " + LocationBookmarks.getAddress("Home"));
*/ */
Q_INVOKABLE QString getAddress(const QString& bookmarkName); Q_INVOKABLE QString getAddress(const QString& bookmarkName);
@ -57,16 +57,16 @@ public slots:
void addBookmark(); void addBookmark();
/*@jsdoc /*@jsdoc
* Sets the metaverse address associated with the "Home" bookmark. * Sets the directory services address associated with the "Home" bookmark.
* @function LocationBookmarks.setHomeLocationToAddress * @function LocationBookmarks.setHomeLocationToAddress
* @param {string} address - The metaverse address to set the "Home" bookmark to. * @param {string} address - The directory services address to set the "Home" bookmark to.
*/ */
void setHomeLocationToAddress(const QVariant& address); void setHomeLocationToAddress(const QVariant& address);
/*@jsdoc /*@jsdoc
* Gets the metaverse address associated with the "Home" bookmark. * Gets the directory services address associated with the "Home" bookmark.
* @function LocationBookmarks.getHomeLocationAddress * @function LocationBookmarks.getHomeLocationAddress
* @returns {string} The metaverse address for the "Home" bookmark. * @returns {string} The directory services address for the "Home" bookmark.
*/ */
QString getHomeLocationAddress(); QString getHomeLocationAddress();

View file

@ -69,7 +69,7 @@ int main(int argc, const char* argv[]) {
LogHandler::getInstance().setShouldUseJournald(false); LogHandler::getInstance().setShouldUseJournald(false);
QCommandLineParser parser; QCommandLineParser parser;
parser.setApplicationDescription("Overte -- A free/libre and open-source metaverse client"); parser.setApplicationDescription("Overte -- A free/libre and open-source virtual worlds client");
QCommandLineOption helpOption = parser.addHelpOption(); QCommandLineOption helpOption = parser.addHelpOption();
QCommandLineOption versionOption = parser.addVersionOption(); QCommandLineOption versionOption = parser.addVersionOption();

View file

@ -85,7 +85,7 @@ class AccountServicesScriptingInterface : public QObject {
* <li><code>"connections"</code> &mdash; user is visible to friends and connections.</li> * <li><code>"connections"</code> &mdash; user is visible to friends and connections.</li>
* <li><code>"all"</code> &mdash; user is visible to everyone.</li> * <li><code>"all"</code> &mdash; user is visible to everyone.</li>
* </ul> * </ul>
* @property {string} metaverseServerURL - The metaverse server that the user is authenticated against when logged in * @property {string} metaverseServerURL - The directory server that the user is authenticated against when logged in
* &mdash; typically <code>"https://metaverse.highfidelity.com"</code>. <em>Read-only.</em> * &mdash; typically <code>"https://metaverse.highfidelity.com"</code>. <em>Read-only.</em>
* *
* @borrows AccountServices.getDownloadInfo as getDownloadInfo * @borrows AccountServices.getDownloadInfo as getDownloadInfo
@ -125,7 +125,7 @@ class AccountServicesScriptingInterface : public QObject {
* <li><code>"connections"</code> &mdash; user is visible to friends and connections.</li> * <li><code>"connections"</code> &mdash; user is visible to friends and connections.</li>
* <li><code>"all"</code> &mdash; user is visible to everyone.</li> * <li><code>"all"</code> &mdash; user is visible to everyone.</li>
* </ul> * </ul>
* @property {string} metaverseServerURL - The metaverse server that the user is authenticated against when logged in * @property {string} metaverseServerURL - The directory server that the user is authenticated against when logged in
* &mdash; typically <code>"https://metaverse.highfidelity.com"</code>. <em>Read-only.</em> * &mdash; typically <code>"https://metaverse.highfidelity.com"</code>. <em>Read-only.</em>
* *
* @borrows AccountServices.getDownloadInfo as getDownloadInfo * @borrows AccountServices.getDownloadInfo as getDownloadInfo
@ -194,7 +194,7 @@ public slots:
void logOut(); void logOut();
/*@jsdoc /*@jsdoc
* Updates Metaverse Server URL in AccountManager. It's called by Login window after Metaverse Server URL is changed. * Updates Directory Server URL in AccountManager. It's called by Login window after Directory Server URL is changed.
* @function AccountServices.updateAuthURLFromMetaverseServerURL * @function AccountServices.updateAuthURLFromMetaverseServerURL
*/ */
void updateAuthURLFromMetaverseServerURL(); void updateAuthURLFromMetaverseServerURL();

View file

@ -43,7 +43,7 @@
* <em>Read-only.</em> * <em>Read-only.</em>
* @property {boolean} interstitialModeEnabled=false - <code>true</code> if the interstitial graphics are displayed when a * @property {boolean} interstitialModeEnabled=false - <code>true</code> if the interstitial graphics are displayed when a
* domain is loading, otherwise <code>false</code>. * domain is loading, otherwise <code>false</code>.
* @property {location} location - Provides facilities for working with your current metaverse location. * @property {location} location - Provides facilities for working with your current directory services location.
*/ */
class WindowScriptingInterface : public QObject, public Dependency { class WindowScriptingInterface : public QObject, public Dependency {
@ -305,7 +305,7 @@ public slots:
/*@jsdoc /*@jsdoc
* Gets the signature for Interface's protocol version. * Gets the signature for Interface's protocol version.
* @function Window.protocolSignature * @function Window.protocolSignature
* @returns {string} A string uniquely identifying the version of the metaverse protocol that Interface is using. * @returns {string} A string uniquely identifying the version of the directory services protocol that Interface is using.
*/ */
QString protocolSignature(); QString protocolSignature();
@ -429,7 +429,7 @@ public slots:
* has been prepared. * has been prepared.
* @function Window.shareSnapshot * @function Window.shareSnapshot
* @param {string} path - The path and name of the image file to share. * @param {string} path - The path and name of the image file to share.
* @param {string} [href=""] - The metaverse location where the snapshot was taken. * @param {string} [href=""] - The directory services location where the snapshot was taken.
*/ */
void shareSnapshot(const QString& path, const QUrl& href = QUrl("")); void shareSnapshot(const QString& path, const QUrl& href = QUrl(""));

View file

@ -99,11 +99,11 @@ void LoginDialog::toggleAction() {
if (accountManager->isLoggedIn()) { if (accountManager->isLoggedIn()) {
// change the menu item to logout // change the menu item to logout
loginAction->setText("Metaverse: Logout " + accountManager->getAccountInfo().getUsername()); loginAction->setText("Directory Service: Logout " + accountManager->getAccountInfo().getUsername());
connection = connect(loginAction, &QAction::triggered, accountManager.data(), &AccountManager::logout); connection = connect(loginAction, &QAction::triggered, accountManager.data(), &AccountManager::logout);
} else { } else {
// change the menu item to login // change the menu item to login
loginAction->setText("Metaverse: Log In / Sign Up"); loginAction->setText("Directory Service: Log In / Sign Up");
connection = connect(loginAction, &QAction::triggered, [] { connection = connect(loginAction, &QAction::triggered, [] {
// if not in login state, show. // if not in login state, show.
if (!qApp->getLoginDialogPoppedUp()) { if (!qApp->getLoginDialogPoppedUp()) {

View file

@ -768,7 +768,7 @@ EntityPropertyFlags EntityItemProperties::getChangedProperties() const {
* if it isn't. * if it isn't.
* @property {boolean} collisionsWillMove - A synonym for <code>dynamic</code>. * @property {boolean} collisionsWillMove - A synonym for <code>dynamic</code>.
* *
* @property {string} href="" - A "hifi://" metaverse address that a user is teleported to when they click on the entity. * @property {string} href="" - A "hifi://" directory services address that a user is teleported to when they click on the entity.
* @property {string} description="" - A description of the <code>href</code> property value. * @property {string} description="" - A description of the <code>href</code> property value.
* *
* @property {string} userData="" - Used to store extra data about the entity in JSON format. * @property {string} userData="" - Used to store extra data about the entity in JSON format.

View file

@ -181,7 +181,7 @@ void AccountManager::setAuthURL(const QUrl& authURL) {
// pull out the stored account info and store it in memory // pull out the stored account info and store it in memory
_accountInfo = accountsMap[_authURL.toString()].value<DataServerAccountInfo>(); _accountInfo = accountsMap[_authURL.toString()].value<DataServerAccountInfo>();
qCDebug(networking) << "Found metaverse API account information for" << qPrintable(_authURL.toString()); qCDebug(networking) << "Found directory services API account information for" << qPrintable(_authURL.toString());
} else { } else {
qCWarning(networking) << "Unable to load account file. No existing account settings will be loaded."; qCWarning(networking) << "Unable to load account file. No existing account settings will be loaded.";
} }
@ -211,7 +211,7 @@ void AccountManager::updateAuthURLFromMetaverseServerURL() {
void AccountManager::setSessionID(const QUuid& sessionID) { void AccountManager::setSessionID(const QUuid& sessionID) {
if (_sessionID != sessionID) { if (_sessionID != sessionID) {
qCDebug(networking) << "Metaverse session ID changed to" << uuidStringWithoutCurlyBraces(sessionID); qCDebug(networking) << "Directory Services session ID changed to" << uuidStringWithoutCurlyBraces(sessionID);
_sessionID = sessionID; _sessionID = sessionID;
} }
} }
@ -381,7 +381,7 @@ void AccountManager::sendRequest(const QString& path,
} }
} else { } else {
if (VERBOSE_HTTP_REQUEST_DEBUGGING) { if (VERBOSE_HTTP_REQUEST_DEBUGGING) {
qCDebug(networking) << "Received JSON response from metaverse API that has no matching callback."; qCDebug(networking) << "Received JSON response from directory services API that has no matching callback.";
qCDebug(networking) << QJsonDocument::fromJson(networkReply->readAll()); qCDebug(networking) << QJsonDocument::fromJson(networkReply->readAll());
} }
} }
@ -409,7 +409,7 @@ void AccountManager::sendRequest(const QString& path,
} else { } else {
if (VERBOSE_HTTP_REQUEST_DEBUGGING) { if (VERBOSE_HTTP_REQUEST_DEBUGGING) {
qCDebug(networking) << "Received error response from metaverse API that has no matching callback."; qCDebug(networking) << "Received error response from directory services API that has no matching callback.";
qCDebug(networking) << "Error" << networkReply->error() << "-" << networkReply->errorString(); qCDebug(networking) << "Error" << networkReply->error() << "-" << networkReply->errorString();
qCDebug(networking) << networkReply->readAll(); qCDebug(networking) << networkReply->readAll();
} }
@ -840,7 +840,7 @@ void AccountManager::requestAccountSettings() {
return; return;
} }
qCDebug(networking) << "Requesting the Account Settings from the Metaverse API"; qCDebug(networking) << "Requesting the Account Settings from the Directory Services API";
QNetworkAccessManager& networkAccessManager = NetworkAccessManager::getInstance(); QNetworkAccessManager& networkAccessManager = NetworkAccessManager::getInstance();
@ -870,7 +870,7 @@ void AccountManager::requestAccountSettingsFinished() {
_settings.unpack(rootObject["data"].toObject()); _settings.unpack(rootObject["data"].toObject());
_lastSuccessfulSyncTimestamp = _settings.lastChangeTimestamp(); _lastSuccessfulSyncTimestamp = _settings.lastChangeTimestamp();
qCDebug(networking) << "Received the Account Settings from the Metaverse API"; qCDebug(networking) << "Received the Account Settings from the Directory Services API";
emit accountSettingsLoaded(); emit accountSettingsLoaded();
} else { } else {
@ -911,7 +911,7 @@ void AccountManager::postAccountSettings() {
return; return;
} }
qCDebug(networking) << "Account Settings have changed, pushing them to the Metaverse API"; qCDebug(networking) << "Account Settings have changed, pushing them to the Directory Services API";
QNetworkAccessManager& networkAccessManager = NetworkAccessManager::getInstance(); QNetworkAccessManager& networkAccessManager = NetworkAccessManager::getInstance();
@ -1000,7 +1000,7 @@ void AccountManager::processGeneratedKeypair(QByteArray publicKey, QByteArray pr
qCDebug(networking) << "Generated 2048-bit RSA keypair."; qCDebug(networking) << "Generated 2048-bit RSA keypair.";
// hold the private key to later set our metaverse API account info if upload succeeds // hold the private key to later set our directory services API account info if upload succeeds
_pendingPublicKey = publicKey; _pendingPublicKey = publicKey;
_pendingPrivateKey = privateKey; _pendingPrivateKey = privateKey;
uploadPublicKey(); uploadPublicKey();
@ -1058,7 +1058,7 @@ void AccountManager::uploadPublicKey() {
} }
void AccountManager::publicKeyUploadSucceeded(QNetworkReply* reply) { void AccountManager::publicKeyUploadSucceeded(QNetworkReply* reply) {
qCDebug(networking) << "Uploaded public key to Metaverse API. RSA keypair generation is completed."; qCDebug(networking) << "Uploaded public key to Directory Services API. RSA keypair generation is completed.";
// public key upload complete - store the matching private key and persist the account to settings // public key upload complete - store the matching private key and persist the account to settings
_accountInfo.setPrivateKey(_pendingPrivateKey); _accountInfo.setPrivateKey(_pendingPrivateKey);

View file

@ -33,10 +33,10 @@ const QString INDEX_PATH = "/";
const QString GET_PLACE = "/api/v1/places/%1"; const QString GET_PLACE = "/api/v1/places/%1";
/*@jsdoc /*@jsdoc
* The <code>location</code> API provides facilities related to your current location in the metaverse. * The <code>location</code> API provides facilities related to your current location in the directory services.
* *
* <h3>Getter/Setter</h3> * <h3>Getter/Setter</h3>
* <p>You can get and set your current metaverse address by directly reading a string value from and writing a string value to * <p>You can get and set your current directory services address by directly reading a string value from and writing a string value to
* the <code>location</code> object. This is an alternative to using the <code>location.href</code> property or other object * the <code>location</code> object. This is an alternative to using the <code>location.href</code> property or other object
* functions.</p> * functions.</p>
* *
@ -50,27 +50,27 @@ const QString GET_PLACE = "/api/v1/places/%1";
* @property {Uuid} domainID - A UUID uniquely identifying the domain you're visiting. Is {@link Uuid(0)|Uuid.NULL} if you're not * @property {Uuid} domainID - A UUID uniquely identifying the domain you're visiting. Is {@link Uuid(0)|Uuid.NULL} if you're not
* connected to the domain or are in a serverless domain. * connected to the domain or are in a serverless domain.
* <em>Read-only.</em> * <em>Read-only.</em>
* @property {string} hostname - The name of the domain for your current metaverse address (e.g., <code>"DomainName"</code>, * @property {string} hostname - The name of the domain for your current directory services address (e.g., <code>"DomainName"</code>,
* <code>localhost</code>, or an IP address). Is blank if you're in a serverless domain. * <code>localhost</code>, or an IP address). Is blank if you're in a serverless domain.
* <em>Read-only.</em> * <em>Read-only.</em>
* @property {string} href - Your current metaverse address (e.g., <code>"hifi://domainname/15,-10,26/0,0,0,1"</code>) * @property {string} href - Your current directory services address (e.g., <code>"hifi://domainname/15,-10,26/0,0,0,1"</code>)
* regardless of whether or not you're connected to the domain. Starts with <code>"file:///"</code> if you're in a * regardless of whether or not you're connected to the domain. Starts with <code>"file:///"</code> if you're in a
* serverless domain. * serverless domain.
* <em>Read-only.</em> * <em>Read-only.</em>
* @property {boolean} isConnected - <code>true</code> if you're connected to the domain in your current <code>href</code> * @property {boolean} isConnected - <code>true</code> if you're connected to the domain in your current <code>href</code>
* metaverse address, otherwise <code>false</code>. * directory services address, otherwise <code>false</code>.
* @property {string} pathname - The location and orientation in your current <code>href</code> metaverse address * @property {string} pathname - The location and orientation in your current <code>href</code> directory services address
* (e.g., <code>"/15,-10,26/0,0,0,1"</code>). * (e.g., <code>"/15,-10,26/0,0,0,1"</code>).
* <em>Read-only.</em> * <em>Read-only.</em>
* @property {string} placename - The place name in your current <code>href</code> metaverse address * @property {string} placename - The place name in your current <code>href</code> directory services address
* (e.g., <code>"DomainName"</code>). Is blank if your <code>hostname</code> is an IP address. * (e.g., <code>"DomainName"</code>). Is blank if your <code>hostname</code> is an IP address.
* <em>Read-only.</em> * <em>Read-only.</em>
* @property {string} protocol - The protocol of your current <code>href</code> metaverse address (e.g., <code>"hifi"</code>). * @property {string} protocol - The protocol of your current <code>href</code> directory services address (e.g., <code>"hifi"</code>).
* <em>Read-only.</em> * <em>Read-only.</em>
*/ */
/*@jsdoc /*@jsdoc
* The <code>AddressManager</code> API provides facilities related to your current location in the metaverse. * The <code>AddressManager</code> API provides facilities related to your current location in the directory services.
* *
* @namespace AddressManager * @namespace AddressManager
* *
@ -84,22 +84,22 @@ const QString GET_PLACE = "/api/v1/places/%1";
* @property {Uuid} domainID - A UUID uniquely identifying the domain you're visiting. Is {@link Uuid(0)|Uuid.NULL} if you're not * @property {Uuid} domainID - A UUID uniquely identifying the domain you're visiting. Is {@link Uuid(0)|Uuid.NULL} if you're not
* connected to the domain or are in a serverless domain. * connected to the domain or are in a serverless domain.
* <em>Read-only.</em> * <em>Read-only.</em>
* @property {string} hostname - The name of the domain for your current metaverse address (e.g., <code>"DomainName"</code>, * @property {string} hostname - The name of the domain for your current directory services address (e.g., <code>"DomainName"</code>,
* <code>localhost</code>, or an IP address). Is blank if you're in a serverless domain. * <code>localhost</code>, or an IP address). Is blank if you're in a serverless domain.
* <em>Read-only.</em> * <em>Read-only.</em>
* @property {string} href - Your current metaverse address (e.g., <code>"hifi://domainname/15,-10,26/0,0,0,1"</code>) * @property {string} href - Your current directory services address (e.g., <code>"hifi://domainname/15,-10,26/0,0,0,1"</code>)
* regardless of whether or not you're connected to the domain. Starts with <code>"file:///"</code> if you're in a * regardless of whether or not you're connected to the domain. Starts with <code>"file:///"</code> if you're in a
* serverless domain. * serverless domain.
* <em>Read-only.</em> * <em>Read-only.</em>
* @property {boolean} isConnected - <code>true</code> if you're connected to the domain in your current <code>href</code> * @property {boolean} isConnected - <code>true</code> if you're connected to the domain in your current <code>href</code>
* metaverse address, otherwise <code>false</code>. * directory services address, otherwise <code>false</code>.
* @property {string} pathname - The location and orientation in your current <code>href</code> metaverse address * @property {string} pathname - The location and orientation in your current <code>href</code> directory services address
* (e.g., <code>"/15,-10,26/0,0,0,1"</code>). * (e.g., <code>"/15,-10,26/0,0,0,1"</code>).
* <em>Read-only.</em> * <em>Read-only.</em>
* @property {string} placename - The place name in your current <code>href</code> metaverse address * @property {string} placename - The place name in your current <code>href</code> directory services address
* (e.g., <code>"DomainName"</code>). Is blank if your <code>hostname</code> is an IP address. * (e.g., <code>"DomainName"</code>). Is blank if your <code>hostname</code> is an IP address.
* <em>Read-only.</em> * <em>Read-only.</em>
* @property {string} protocol - The protocol of your current <code>href</code> metaverse address (e.g., <code>"hifi"</code>). * @property {string} protocol - The protocol of your current <code>href</code> directory services address (e.g., <code>"hifi"</code>).
* <em>Read-only.</em> * <em>Read-only.</em>
* *
* @borrows location.handleLookupString as handleLookupString * @borrows location.handleLookupString as handleLookupString
@ -144,7 +144,7 @@ public:
using OrientationGetter = std::function<glm::quat()>; using OrientationGetter = std::function<glm::quat()>;
/*@jsdoc /*@jsdoc
* <p>The reasons for an address lookup via the metaverse API are defined by numeric values:</p> * <p>The reasons for an address lookup via the Directory Services API are defined by numeric values:</p>
* <table> * <table>
* <thead> * <thead>
* <tr> * <tr>
@ -247,7 +247,7 @@ public:
public slots: public slots:
/*@jsdoc /*@jsdoc
* Takes you to a specified metaverse address. * Takes you to a specified directory services address.
* @function location.handleLookupString * @function location.handleLookupString
* @param {string} address - The address to go to: a <code>"hifi://"</code> address, an IP address (e.g., * @param {string} address - The address to go to: a <code>"hifi://"</code> address, an IP address (e.g.,
* <code>"127.0.0.1"</code> or <code>"localhost"</code>), a <code>file:///</code> address, a domain name, a named path * <code>"127.0.0.1"</code> or <code>"localhost"</code>), a <code>file:///</code> address, a domain name, a named path
@ -297,7 +297,7 @@ public slots:
} }
/*@jsdoc /*@jsdoc
* Takes you to the default "welcome" metaverse address. * Takes you to the default "welcome" directory services address.
* @function location.goToEntry * @function location.goToEntry
* @param {location.LookupTrigger} trigger=StartupFromSettings - The reason for the function call. Helps ensure that user's * @param {location.LookupTrigger} trigger=StartupFromSettings - The reason for the function call. Helps ensure that user's
* location history is correctly maintained. * location history is correctly maintained.
@ -336,20 +336,20 @@ public slots:
void refreshPreviousLookup(); void refreshPreviousLookup();
/*@jsdoc /*@jsdoc
* Updates your current metaverse location in Interface's {@link Settings} file as your last-known address. This can be used * Updates your current directory services location in Interface's {@link Settings} file as your last-known address. This can be used
* to ensure that you start up at that address if you exit Interface without a later address automatically being saved. * to ensure that you start up at that address if you exit Interface without a later address automatically being saved.
* @function location.storeCurrentAddress * @function location.storeCurrentAddress
*/ */
void storeCurrentAddress(); void storeCurrentAddress();
/*@jsdoc /*@jsdoc
* Copies your current metaverse address (i.e., <code>location.href</code> property value) to the OS clipboard. * Copies your current directory services address (i.e., <code>location.href</code> property value) to the OS clipboard.
* @function location.copyAddress * @function location.copyAddress
*/ */
void copyAddress(); void copyAddress();
/*@jsdoc /*@jsdoc
* Copies your current metaverse location and orientation (i.e., <code>location.pathname</code> property value) to the OS * Copies your current directory services location and orientation (i.e., <code>location.pathname</code> property value) to the OS
* clipboard. * clipboard.
* @function location.copyPath * @function location.copyPath
*/ */
@ -367,7 +367,7 @@ public slots:
signals: signals:
/*@jsdoc /*@jsdoc
* Triggered when looking up the details of a metaverse user or location to go to has completed (successfully or * Triggered when looking up the details of a directory services user or location to go to has completed (successfully or
* unsuccessfully). * unsuccessfully).
* @function location.lookupResultsFinished * @function location.lookupResultsFinished
* @returns {Signal} * @returns {Signal}
@ -375,7 +375,7 @@ signals:
void lookupResultsFinished(); void lookupResultsFinished();
/*@jsdoc /*@jsdoc
* Triggered when looking up the details of a metaverse user or location to go to has completed and the domain or user is * Triggered when looking up the details of a directory services user or location to go to has completed and the domain or user is
* offline. * offline.
* @function location.lookupResultIsOffline * @function location.lookupResultIsOffline
* @returns {Signal} * @returns {Signal}
@ -383,7 +383,7 @@ signals:
void lookupResultIsOffline(); void lookupResultIsOffline();
/*@jsdoc /*@jsdoc
* Triggered when looking up the details of a metaverse user or location to go to has completed and the domain or user could * Triggered when looking up the details of a directory services user or location to go to has completed and the domain or user could
* not be found. * not be found.
* @function location.lookupResultIsNotFound * @function location.lookupResultIsNotFound
* @returns {Signal} * @returns {Signal}

View file

@ -600,7 +600,7 @@ void DomainHandler::processDomainServerConnectionDeniedPacket(QSharedPointer<Rec
// Some connection refusal reasons imply that a login is required. If so, suggest a new login. // Some connection refusal reasons imply that a login is required. If so, suggest a new login.
if (reasonSuggestsMetaverseLogin(reasonCode)) { if (reasonSuggestsMetaverseLogin(reasonCode)) {
qCWarning(networking) << "Make sure you are logged in to the metaverse."; qCWarning(networking) << "Make sure you are logged in to the directory server.";
auto accountManager = DependencyManager::get<AccountManager>(); auto accountManager = DependencyManager::get<AccountManager>();
@ -617,7 +617,7 @@ void DomainHandler::processDomainServerConnectionDeniedPacket(QSharedPointer<Rec
_connectionDenialsSinceKeypairRegen = 0; _connectionDenialsSinceKeypairRegen = 0;
} }
// Server with domain login will prompt for domain login, not metaverse, so reset domain values if asked for metaverse. // Server with domain login will prompt for domain login, not directory server, so reset domain values if asked for directory server.
auto domainAccountManager = DependencyManager::get<DomainAccountManager>(); auto domainAccountManager = DependencyManager::get<DomainAccountManager>();
domainAccountManager->setAuthURL(QUrl()); domainAccountManager->setAuthURL(QUrl());
domainAccountManager->setClientID(QString()); domainAccountManager->setClientID(QString());
@ -641,7 +641,7 @@ void DomainHandler::processDomainServerConnectionDeniedPacket(QSharedPointer<Rec
_hasCheckedForDomainAccessToken = true; _hasCheckedForDomainAccessToken = true;
} }
// ####### TODO: regenerate key-pair after several failed connection attempts, similar to metaverse login code? // ####### TODO: regenerate key-pair after several failed connection attempts, similar to Directory Services login code?
} }
} }

View file

@ -200,12 +200,12 @@ public:
* <tr> * <tr>
* <td><strong>LoginErrorMetaverse</strong></td> * <td><strong>LoginErrorMetaverse</strong></td>
* <td><code>2</code></td> * <td><code>2</code></td>
* <td>You could not be logged into the domain per your metaverse login.</td> * <td>You could not be logged into the domain per your Directory Services login.</td>
* </tr> * </tr>
* <tr> * <tr>
* <td><strong>NotAuthorizedMetaverse</strong></td> * <td><strong>NotAuthorizedMetaverse</strong></td>
* <td><code>3</code></td> * <td><code>3</code></td>
* <td>You are not authorized to connect to the domain per your metaverse login.</td> * <td>You are not authorized to connect to the domain per your Directory Services login.</td>
* </tr> * </tr>
* <tr> * <tr>
* <td><strong>TooManyUsers</strong></td> * <td><strong>TooManyUsers</strong></td>

View file

@ -18,7 +18,7 @@
namespace MetaverseAPI { namespace MetaverseAPI {
// You can change the return of this function if you want to use a custom metaverse URL at compile time // You can change the return of this function if you want to use a custom directory services URL at compile time
// or you can pass a custom URL via the env variable // or you can pass a custom URL via the env variable
QUrl getCurrentMetaverseServerURL() { QUrl getCurrentMetaverseServerURL() {
QUrl selectedMetaverseURL; QUrl selectedMetaverseURL;

View file

@ -19,7 +19,7 @@
namespace NetworkingConstants { namespace NetworkingConstants {
// If you want to use STAGING instead of STABLE, // If you want to use STAGING instead of STABLE,
// links from the Domain Server web interface (like the connect account token generation) // links from the Domain Server web interface (like the connect account token generation)
// will still point at stable unless you ALSO change the Domain Server Metaverse Server URL inside of: // will still point at stable unless you ALSO change the Domain Server Directory Services URL inside of:
// <Overte repo>\domain-server\resources\web\js\shared.js // <Overte repo>\domain-server\resources\web\js\shared.js
// You can avoid changing that and still effectively use a connected domain on staging // You can avoid changing that and still effectively use a connected domain on staging
@ -28,7 +28,7 @@ namespace NetworkingConstants {
const QString WEB_ENGINE_VERSION = "Chrome/83.0.4103.122"; const QString WEB_ENGINE_VERSION = "Chrome/83.0.4103.122";
// For now we only have one Metaverse server. // For now we only have one directory server.
const QUrl METAVERSE_SERVER_URL_STABLE { "https://mv.overte.org/server" }; const QUrl METAVERSE_SERVER_URL_STABLE { "https://mv.overte.org/server" };
const QUrl METAVERSE_SERVER_URL_STAGING { "https://mv.overte.org/server" }; const QUrl METAVERSE_SERVER_URL_STAGING { "https://mv.overte.org/server" };

View file

@ -507,7 +507,7 @@ void NodeList::sendDomainServerCheckIn() {
if (!domainIsConnected) { if (!domainIsConnected) {
// Metaverse account. // Directory services account.
DataServerAccountInfo& accountInfo = accountManager->getAccountInfo(); DataServerAccountInfo& accountInfo = accountManager->getAccountInfo();
packetStream << accountInfo.getUsername(); packetStream << accountInfo.getUsername();
// if this is a connect request, and we can present a username signature, send it along // if this is a connect request, and we can present a username signature, send it along

View file

@ -4,7 +4,7 @@ if [ -z "$1" ] || [ -z "$2" ]; then
echo echo
echo "Sets up a new Overte server with the specified name and base port number" echo "Sets up a new Overte server with the specified name and base port number"
echo " {name} - a simple name used to identify the server to scripts (not used in the server configuration)" echo " {name} - a simple name used to identify the server to scripts (not used in the server configuration)"
echo " {base-port} - the base port number (default server is 40100). The metaverse port will be {base-port}+2" echo " {base-port} - the base port number (default server is 40100). The domain server port will be {base-port}+2"
echo " Four contiguous port numbers are allocated, these must not overlap with other running services on this machine" echo " Four contiguous port numbers are allocated, these must not overlap with other running services on this machine"
echo echo
echo "Launching a server created by this script is done with:" echo "Launching a server created by this script is done with:"

View file

@ -1,7 +1,7 @@
// //
// hotPlaces.js // hotPlaces.js
// //
// Press the number keys to jump to different places in the metaverse! // Press the number keys to jump to different places!
// //
// Created by Philip Rosedale on November 20, 2014 // Created by Philip Rosedale on November 20, 2014
// Copyright 2014 High Fidelity, Inc. // Copyright 2014 High Fidelity, Inc.

View file

@ -321,7 +321,7 @@
var activeThresholdTime = new Date(); var activeThresholdTime = new Date();
activeThresholdTime.setMinutes(activeThresholdTime.getMinutes() - 15); activeThresholdTime.setMinutes(activeThresholdTime.getMinutes() - 15);
// while blending metaverse data ensure it is cleaned for active domains // while blending directory server data ensure it is cleaned for active domains
for (var i = 0; i < placesData.length; i++) { for (var i = 0; i < placesData.length; i++) {
if (placesData[i].domain.active && placesData[i].visibility == "open" && new Date(placesData[i].last_activity_update) > activeThresholdTime) { if (placesData[i].domain.active && placesData[i].visibility == "open" && new Date(placesData[i].last_activity_update) > activeThresholdTime) {
joinedData.push({ joinedData.push({
@ -351,9 +351,9 @@
EventBridge.emitWebEvent(JSON.stringify(readyEvent)); EventBridge.emitWebEvent(JSON.stringify(readyEvent));
} }
// if metaverse data not loaded fire a request for it // if directory server data not loaded fire a request for it
if (placesData == null) { if (placesData == null) {
// fire off data get against the metaverse // fire off data get against the directory server
axios.get("https://mv.overte.org/server/api/v1/places") axios.get("https://mv.overte.org/server/api/v1/places")
.then((response) => { .then((response) => {
placesData = response.data.data.places; placesData = response.data.data.places;

View file

@ -696,8 +696,8 @@
requestBody = {'node_id': cleanId(MyAvatar.sessionUUID), 'proposed_node_id': cleanId(id)}; // for use when repeating requestBody = {'node_id': cleanId(MyAvatar.sessionUUID), 'proposed_node_id': cleanId(id)}; // for use when repeating
// It would be "simpler" to skip this and just look at the response, but: // It would be "simpler" to skip this and just look at the response, but:
// 1. We don't want to bother the metaverse with request that we know will fail. // 1. We don't want to bother the directory server with request that we know will fail.
// 2. We don't want our code here to be dependent on precisely how the metaverse responds (400, 401, etc.) // 2. We don't want our code here to be dependent on precisely how the directory server responds (400, 401, etc.)
// 3. We also don't want to connect to someone who is anonymous _now_, but was not earlier and still has // 3. We also don't want to connect to someone who is anonymous _now_, but was not earlier and still has
// the same node id. Since the messaging doesn't say _who_ isn't logged in, fail the same as if we are // the same node id. Since the messaging doesn't say _who_ isn't logged in, fail the same as if we are
// not logged in. // not logged in.

View file

@ -194,7 +194,7 @@
function generateContent() { function generateContent() {
if (currentListFormat === "REGIONS") { if (currentListFormat === "REGIONS") {
//Display metaverse page here //Display directory services page here
var formattedMetaverseList = ""; var formattedMetaverseList = "";
var metaverseCounter = 0; var metaverseCounter = 0;

View file

@ -13,7 +13,7 @@
// QML has its own XMLHttpRequest, but: // QML has its own XMLHttpRequest, but:
// - npm request is easier to use. // - npm request is easier to use.
// - It is not easy to hack QML's XMLHttpRequest to use our MetaverseServer, and to supply the user's auth when contacting it. // - It is not easy to hack QML's XMLHttpRequest to use our Directory Services, and to supply the user's auth when contacting it.
// a. Our custom XMLHttpRequestClass object only works with QScriptEngine, not QML's javascript. // a. Our custom XMLHttpRequestClass object only works with QScriptEngine, not QML's javascript.
// b. We have hacked profiles that intercept requests to our MetavserseServer (providing the correct auth), but those // b. We have hacked profiles that intercept requests to our MetavserseServer (providing the correct auth), but those
// only work in QML WebEngineView. Setting up communication between ordinary QML and a hiddent WebEngineView is // only work in QML WebEngineView. Setting up communication between ordinary QML and a hiddent WebEngineView is
@ -24,7 +24,7 @@
// We will then asynchonously call fromScript({id: theSameString, method: 'http.response', error: errorOrFalsey, response: body}) // We will then asynchonously call fromScript({id: theSameString, method: 'http.response', error: errorOrFalsey, response: body})
// on that root object. // on that root object.
// RootHttpRequest.qml does this. // RootHttpRequest.qml does this.
// 2. If the uri used (computed from byNameOptions, see request.js) is to our metaverse, we will use the appropriate auth. // 2. If the uri used (computed from byNameOptions, see request.js) is to our Directory Services, we will use the appropriate auth.
var request = Script.require('request').request; var request = Script.require('request').request;
var tablet = Tablet.getTablet("com.highfidelity.interface.tablet.system"); var tablet = Tablet.getTablet("com.highfidelity.interface.tablet.system");

View file

@ -85,7 +85,7 @@
tablet.emitScriptEvent(JSON.stringify(object)); tablet.emitScriptEvent(JSON.stringify(object));
} }
if (event.type === "manage-friends") { if (event.type === "manage-friends") {
// open a web overlay to metaverse friends page // open a web overlay to directory services friends page
var friendsWindow = new OverlayWebWindow({ var friendsWindow = new OverlayWebWindow({
title: FRIENDS_WINDOW_TITLE, title: FRIENDS_WINDOW_TITLE,
width: FRIENDS_WINDOW_WIDTH, width: FRIENDS_WINDOW_WIDTH,

View file

@ -14,7 +14,7 @@ var OVERLAY = null;
location.hostChanged.connect(function(host) { location.hostChanged.connect(function(host) {
print('Detected host change:', host); print('Detected host change:', host);
// Fetch the domain ID from the metaverse // Fetch the domain ID from the directory server
var placeData = request(SERVER + '/places/' + host); var placeData = request(SERVER + '/places/' + host);
if (!placeData) { if (!placeData) {
print('Cannot find place name - abandoning metadata request for', host); print('Cannot find place name - abandoning metadata request for', host);
@ -24,7 +24,7 @@ location.hostChanged.connect(function(host) {
var domainID = placeData.data.place.domain.id; var domainID = placeData.data.place.domain.id;
print('Domain ID:', domainID); print('Domain ID:', domainID);
// Fetch the domain metadata from the metaverse // Fetch the domain metadata from the directory server
var domainData = request(SERVER + '/domains/' + domainID); var domainData = request(SERVER + '/domains/' + domainID);
print(SERVER + '/domains/' + domainID); print(SERVER + '/domains/' + domainID);
if (!domainData) { if (!domainData) {

View file

@ -1,4 +1,4 @@
The Overte JavaScript API lets content creators and developers create new experiences and transform virtual worlds within the Overte metaverse. The Overte JavaScript API lets content creators and developers create new experiences and transform virtual worlds within the Overte.
With it, you can build great content, customize avatars, play audio and so much more. With it, you can build great content, customize avatars, play audio and so much more.
You are most likely to interact with these APIs: You are most likely to interact with these APIs:
@ -7,4 +7,4 @@ You are most likely to interact with these APIs:
* The **[AvatarList](AvatarList.html)**, **[MyAvatar](MyAvatar.html)**, and **[Avatar](Avatar.html)** namespaces affect your personal avatars, and lets you get information on other people's avatars. * The **[AvatarList](AvatarList.html)**, **[MyAvatar](MyAvatar.html)**, and **[Avatar](Avatar.html)** namespaces affect your personal avatars, and lets you get information on other people's avatars.
* The **[Script](Script.html)** namespace lets you to connect callbacks from your client to script, such as functionality that is dependent on time (`Script.update`, `Script.setTimeout`, `Script.setInterval`, etc), connect paths relatively to assets (`Script.resolvePath`), refer to other scripts (`Script.require`, `Script.include`), or connect functions to events which occur when the script is turned off (`Script.scriptEnding`). * The **[Script](Script.html)** namespace lets you to connect callbacks from your client to script, such as functionality that is dependent on time (`Script.update`, `Script.setTimeout`, `Script.setInterval`, etc), connect paths relatively to assets (`Script.resolvePath`), refer to other scripts (`Script.require`, `Script.include`), or connect functions to events which occur when the script is turned off (`Script.scriptEnding`).
To learn more about using Overte and exploring the metaverse, visit the [Overte User Documentation](https://docs.overte.org). To learn more about using Overte and exploring virtual worlds, visit the [Overte User Documentation](https://docs.overte.org).