// This file defines all of the RPC calls which are used between the inner and outer iframe. // Define *querys* (which expect a response) using Q_ // Define *events* (which expect no response) using EV_ // Please document the queries and events you create, and please please avoid making generic // "do stuff" events/queries which are used for many different things because it makes the // protocol unclear. // // WARNING: At this point, this protocol is still EXPERIMENTAL. This is not it's final form. // We need to define protocol one piece at a time and then when we are satisfied that we // fully understand the problem, we will define the *right* protocol and this file will be dynomited. // define({ // When the iframe first launches, this query is sent repeatedly by the controller // to wait for it to awake and give it the requirejs config to use. 'Q_INIT': true, // When either the outside or inside registers a query handler, this is sent. 'EV_REGISTER_HANDLER': true, // When an iframe is ready to receive messages 'EV_RPC_READY': true, // Realtime events called from the outside. // When someone joins the pad, argument is a string with their netflux id. 'EV_RT_JOIN': true, // When someone leaves the pad, argument is a string with their netflux id. 'EV_RT_LEAVE': true, // When you have been disconnected, no arguments. 'EV_RT_DISCONNECT': true, // When you have connected, argument is an object with myID: string, members: list, readOnly: boolean. 'EV_RT_CONNECT': true, // Called after the history is finished synchronizing, no arguments. 'EV_RT_READY': true, // Called when the server returns an error in a pad (EEXPIRED, EDELETED). 'EV_RT_ERROR': true, // Called from both outside and inside, argument is a (string) chainpad message. 'Q_RT_MESSAGE': true, // Called from the outside, this informs the inside whenever the user's data has been changed. // The argument is the object representing the content of the user profile minus the netfluxID // which changes per-reconnect. 'EV_METADATA_UPDATE': true, // Takes one argument only, the title to set for the CURRENT pad which the user is looking at. // This changes the pad title in drive ONLY, the pad title needs to be changed inside of the // iframe and synchronized with the other users. This will not trigger a EV_METADATA_UPDATE // because the metadata contained in EV_METADATA_UPDATE does not contain the pad title. // It also sets the page (tab) title to the selected title, unles it is overridden by // the EV_SET_TAB_TITLE event. 'Q_SET_PAD_TITLE_IN_DRIVE': true, // Set the page title (tab title) to the selected value which will override the pad title. // The new title value can contain {title}, which will be replaced by the pad title when it // is set or modified. 'EV_SET_TAB_TITLE': true, // Update the user's display-name which will be shown to contacts and people in the same pads. 'Q_SETTINGS_SET_DISPLAY_NAME': true, // Log the user out in all the tabs 'Q_LOGOUT': true, // Tell the user that he has been logged out from outside (probably from another tab) 'EV_LOGOUT': true, // When moving to the login or register page from a pad, we need to redirect to that pad at the // end of the login process. This query set the current href to the sessionStorage. 'Q_SET_LOGIN_REDIRECT': true, // Store the editing or readonly link of the current pad to the clipboard (share button). 'Q_STORE_LINK_TO_CLIPBOARD': true, // Use anonymous rpc from inside the iframe (for avatars & pin usage). 'Q_ANON_RPC_MESSAGE': true, // Get the user's pin limit, usage and plan 'Q_PIN_GET_USAGE': true, // Write/update the login block when the account password is changed 'Q_WRITE_LOGIN_BLOCK': true, // Check the pin limit to determine if we can store the pad in the drive or if we should. // display a warning 'Q_GET_PIN_LIMIT_STATUS': true, // Move a pad to the trash when using the forget button. 'Q_MOVE_TO_TRASH': true, // Request the full history from the server when the users clicks on the history button. // Callback is called when the FULL_HISTORY_END message is received in the outside. 'Q_GET_FULL_HISTORY': true, 'Q_GET_HISTORY_RANGE': true, // When a (full) history message is received from the server. 'EV_RT_HIST_MESSAGE': true, // Save a pad as a template using the toolbar button 'Q_SAVE_AS_TEMPLATE': true, // Friend requests from the userlist 'Q_SEND_FRIEND_REQUEST': true, // Up query 'Q_INCOMING_FRIEND_REQUEST': true, // Down query 'EV_FRIEND_REQUEST': true, // Down event when the request is complete // Set the tab notification when the content of the pad changes 'EV_NOTIFY': true, // Send the new settings to the inner iframe when they are changed in the proxy 'EV_SETTINGS_UPDATE': true, // Get and set (pad) attributes stored in the drive from the inner iframe 'Q_GET_ATTRIBUTE': true, 'Q_SET_ATTRIBUTE': true, 'Q_GET_PAD_ATTRIBUTE': true, 'Q_SET_PAD_ATTRIBUTE': true, // Check if a pad is only in a shared folder or (also) in the main drive. // This allows us to change the behavior of some buttons (trash icon...) 'Q_IS_ONLY_IN_SHARED_FOLDER': true, // Open/close the File picker (sent from the iframe to the outside) 'EV_FILE_PICKER_OPEN': true, 'EV_FILE_PICKER_CLOSE': true, 'EV_FILE_PICKER_REFRESH': true, // File selected in the file picker: sent from the filepicker iframe to the outside // and then send to the inner iframe 'EV_FILE_PICKED': true, // Get all the files from the drive to display them in a file picker secure app 'Q_GET_FILES_LIST': true, // Template picked, replace the content of the pad 'Q_TEMPLATE_USE': true, // Check if we have template(s) for the selected pad type 'Q_TEMPLATE_EXIST': true, // File upload queries and events 'Q_UPLOAD_FILE': true, 'EV_FILE_UPLOAD_STATE': true, 'Q_CANCEL_PENDING_FILE_UPLOAD': true, // Make the browser window navigate to a given URL, if no URL is passed then it will reload. 'EV_GOTO_URL': true, // Make the parent window open a given URL in a new tab. It allows us to keep sessionStorage // form the parent window. 'EV_OPEN_URL': true, // Present mode URL 'Q_PRESENT_URL_GET_VALUE': true, 'EV_PRESENT_URL_SET_VALUE': true, // Put one or more entries to the cache which will go in localStorage. // Cache is wiped after each new release 'EV_CACHE_PUT': true, // Contacts 'EV_CONTACTS_MESSAGE': true, 'EV_CONTACTS_JOIN': true, 'EV_CONTACTS_LEAVE': true, 'EV_CONTACTS_UPDATE': true, 'EV_CONTACTS_FRIEND': true, 'EV_CONTACTS_UNFRIEND': true, 'Q_CONTACTS_GET_FRIEND_LIST': true, 'Q_CONTACTS_GET_MY_INFO': true, 'Q_CONTACTS_GET_FRIEND_INFO': true, 'Q_CONTACTS_REMOVE_FRIEND': true, 'Q_CONTACTS_OPEN_FRIEND_CHANNEL': true, 'Q_CONTACTS_GET_STATUS': true, 'Q_CONTACTS_GET_MORE_HISTORY': true, 'Q_CONTACTS_SEND_MESSAGE': true, 'Q_CONTACTS_SET_CHANNEL_HEAD': true, 'Q_CONTACTS_CLEAR_OWNED_CHANNEL': true, // Put one or more entries to the localStore which will go in localStorage. 'EV_LOCALSTORE_PUT': true, // Put one entry in the parent sessionStorage 'Q_SESSIONSTORAGE_PUT': true, // Merge the anonymous drive (FS_hash) into the current logged in user's drive, to keep the pads // in the drive at registration. 'Q_MERGE_ANON_DRIVE': true, // Add or remove the avatar from the profile. // We have to pin/unpin the avatar and store/remove the value from the user object 'Q_PROFILE_AVATAR_ADD': true, 'Q_PROFILE_AVATAR_REMOVE': true, // Store outside and get thumbnails inside (stored with localForage (indexedDB) outside) 'Q_THUMBNAIL_SET': true, 'Q_THUMBNAIL_GET': true, // Settings app only // Clear all thumbnails 'Q_THUMBNAIL_CLEAR': true, // Backup and restore a drive 'Q_SETTINGS_DRIVE_GET': true, 'Q_SETTINGS_DRIVE_SET': true, 'Q_SETTINGS_DRIVE_RESET': true, // Logout from all the devices where the account is logged in 'Q_SETTINGS_LOGOUT': true, // Import pads from this computer's anon session into the current user account 'Q_SETTINGS_IMPORT_LOCAL': true, 'Q_SETTINGS_DELETE_ACCOUNT': true, // Store the language selected in the iframe into localStorage outside 'Q_LANGUAGE_SET': true, // Anonymous users can empty their drive and remove FS_hash from localStorage 'EV_BURN_ANON_DRIVE': true, // Inner drive needs to send command and receive updates from the async store 'Q_DRIVE_USEROBJECT': true, 'Q_DRIVE_GETOBJECT': true, 'Q_DRIVE_RESTORE': true, // Get the pads deleted from the server by other users to remove them from the drive 'Q_DRIVE_GETDELETED': true, // Store's userObject need to send log messages to inner to display them in the UI 'EV_DRIVE_LOG': true, // Refresh the drive when the drive has changed ('change' or 'remove' events) 'EV_DRIVE_CHANGE': true, 'EV_DRIVE_REMOVE': true, // Remove an owned pad from the server 'Q_REMOVE_OWNED_CHANNEL': true, // Notifications about connection and disconnection from the network 'EV_NETWORK_DISCONNECT': true, 'EV_NETWORK_RECONNECT': true, // Reload on new version 'EV_NEW_VERSION': true, // Pad creation screen: create a pad with the selected attributes (owned, expire) 'Q_CREATE_PAD': true, // Get the available templates 'Q_CREATE_TEMPLATES': true, // This is for sending data out of the iframe when we are in testing mode // The exact protocol is defined in common/test.js 'EV_TESTDATA': true, // Ask for the pad password when a pad is protected 'EV_PAD_PASSWORD': true, 'Q_PAD_PASSWORD_VALUE': true, // Change pad password 'Q_PAD_PASSWORD_CHANGE': true, // Loading events to display in the loading screen 'EV_LOADING_INFO': true, // Critical error outside the iframe during loading screen 'EV_LOADING_ERROR': true, // Get all existing tags 'Q_GET_ALL_TAGS': true, });