diff --git a/.github/dependabot.yml b/.github/dependabot.yml new file mode 100644 index 00000000..3a3cce57 --- /dev/null +++ b/.github/dependabot.yml @@ -0,0 +1,11 @@ +# To get started with Dependabot version updates, you'll need to specify which +# package ecosystems to update and where the package manifests are located. +# Please see the documentation for all configuration options: +# https://docs.github.com/github/administering-a-repository/configuration-options-for-dependency-updates + +version: 2 +updates: + - package-ecosystem: "npm" # See documentation for possible values + directory: "/" # Location of package manifests + schedule: + interval: "weekly" diff --git a/CHANGES.md b/CHANGES.md index df0322cc..ed6f7f57 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -26,7 +26,8 @@ ## Version 1.24 -- Add new `REST Explore` page to call Salesforce APIs from the extension +- Fix issues [543](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/543), [538](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/538), [545](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/545) & [546](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/545) +- Add new REST Explore page to call Salesforce APIs from the extension - Add Global Search in Shortcut tab when no result was found - Enable users to configure custom headers on Data Import (AssignmentRuleHeader, DuplicateRuleHeader, OwnerChangeOptions ...) [feature 478](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/478) - Fix CustomSetting links in popup [issue 473](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/473) (contribution by [Boris Castellani](https://github.com/castellani)) @@ -39,7 +40,7 @@ - Add option to exclude formula fields from data export autocomplete [feature 415](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/415) - Removes whitespace from both ends in user search [feature 410](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/410) (contribution by [César Blanco](https://github.com/cesarblancg)) - Add setup menu items `Trusted URLs` and `Trusted URL and Browser Policy Violations` to shortcut links -- Ability to quit popup with escape button [feature 378](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/378) (contribution by [Gerald Gramier](https://github.com/gramier)) +- Ability to quit popup with escape button [feature 378](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/378) (contribution by [Gerald Ramier](https://github.com/gramier)) - Add option to customize org favicon [feature 180](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/180) - Add tooltip to options [feature 399](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/399) (contribution by [Nathan Shulman](https://github.com/nshulman)) - Fixed popup button disappearance at 100%, also changed horizontal orientation to start at left [issue 404](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/404) (contribution by [Nathan Shulman](https://github.com/nshulman)) @@ -54,7 +55,7 @@ - Fix popup not closing in inspect page [issue 159](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/159) (contribution by [Luca Bassani](https://github.com/baslu93)) - On inspect page, when double clicking on a picklist field, iterate through available values [feature 366](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/366) - Integrate Experience Cloud builder link to shortcut search in popup [feature 365](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/365) -- Add `Flow Versions` button in popup when recordId is a flow [feature 362](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/362) +- Add `Flow Versions` button in popup when recordId is a flow [feature 362](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/362) (feature request by [Rebbe Pod](https://github.com/RebbePod)) - Format relations as expected in import process [feature 26](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/26) (contribution by [Olivier Dufour](https://github.com/dufoli)) - Ability to choose header theme [feature 294](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/294) - Add query template customization in Option page [feature 349](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/349) diff --git a/PRIVACY.md b/PRIVACY.md index b37116e0..b1c25f7d 100644 --- a/PRIVACY.md +++ b/PRIVACY.md @@ -1,12 +1,16 @@ # Privacy Policy -The Salesforce Inspector browser extension/plugin communicates directly between the user's web browser and the Salesforce servers. No data is sent to other parties and no data is persisted outside of Salesforce servers after the user leaves the Salesforce Inspector pages. -The Inspector communicates via the official Salesforce webservice APIs on behalf of the currently logged in user. This means the Inspector will be capable of accessing nothing but the data and features the user has been granted access to in Salesforce. +The Salesforce Inspector Reloaded browser extension/plugin communicates directly between the user's web browser and the Salesforce servers. No data is sent to other parties. -All Salesforce API calls from the Inspector re-uses the access token/session used by the browser to access Salesforce. To acquire this access token the Salesforce Inspector requires permission to read browser cookie information for Salesforce domains. +We are saving some info in the browser localStorage to avoid redundant queries and save user extension's preferences. None of the saved elements are related to Salesforce SObject data (Account, Contact etc.) -To validate the accuracy of this description, inspect the source code, monitor the network traffic in your browser or take my word. +You can find the list of all the localStorage saved [here](https://github.com/search?q=repo:tprouvot/Salesforce-Inspector-reloaded+"localStorage"+path:addon&type=code) and inspect what is stored by following [this tutorial](https://developer.chrome.com/docs/devtools/storage/localstorage). + +The extension communicates via the official Salesforce webservice APIs on behalf of the currently logged in user. This means the extension will be capable of accessing nothing but the data and features the user has been granted access to in Salesforce. +All Salesforce API calls from the Inspector re-uses the access token/session used by the browser to access Salesforce (or the generated on if API Access Control is enabled). To acquire this access token the Salesforce Inspector requires permission to read browser cookie information for Salesforce domains. + +To validate the accuracy of this description, inspect the source code, monitor the network traffic in your browser or take my word. ## Local Storage Policy Local storage objects are sets of data that can be stored on your browser and/or hard drive by us. @@ -17,4 +21,4 @@ We use local storage objects to remember your : - Environment type (PROD or Sandbox) - Client Id @ Session Id (only if you're using Salesforce Extension with a connected App) -We do not use local storage objects for any other purpose. You may erase the local storage objects by deleting your browser's history. \ No newline at end of file +We do not use local storage objects for any other purpose. You may erase the local storage objects by deleting your browser's history. diff --git a/README.md b/README.md index 8732cec1..020ad794 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,6 @@ - + -# Salesforce inspector reloaded +# Salesforce Inspector Reloaded ![GitHub release](https://img.shields.io/github/v/release/tprouvot/Salesforce-Inspector-reloaded?sort=semver) [![Chrome Web Store Installs](https://img.shields.io/chrome-web-store/users/hpijlohoihegkfehhibggnkbjhoemldh)](https://chrome.google.com/webstore/detail/salesforce-inspector-relo/hpijlohoihegkfehhibggnkbjhoemldh) @@ -43,7 +43,8 @@ We all know and love Salesforce Inspector: As the great Søren Krabbe did not ha [![view - Documentation](https://img.shields.io/badge/view-Documentation-blue?style=for-the-badge)](https://tprouvot.github.io/Salesforce-Inspector-reloaded/ "Go to extension documentation") -- SalesforceBen + - Salesforce Developers Blog [Improve Your Productivity with Salesforce Inspector Reloaded](https://developer.salesforce.com/blogs/2024/07/improve-your-productivity-with-salesforce-inspector-reloaded) +- SalesforceBen : - [Salesforce Inspector Reloaded](https://www.salesforceben.com/salesforce-inspector-reloaded/) - [Video](https://youtu.be/dvYp5mKxxzM?si=hBCIaGOyqAJlerea) - [Explore REST API With Salesforce Inspector Reloaded](https://www.salesforceben.com/explore-rest-api-with-salesforce-inspector-reloaded/) @@ -53,6 +54,8 @@ We all know and love Salesforce Inspector: As the great Søren Krabbe did not ha ## New features compared to original SF Inspector +- REST Explore: use Salesforce APIs without external tool +- Favicon customization for each org - Allow users to update API Version [feature 58](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/58) - Add new "Shortcuts" tab to accelerate setup navigation [feature 42](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/42) - Add shortcuts links to (list of record types, current SObject RecordType and objet details, show all data from user tab) from popup [feature 34](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues/34) @@ -62,10 +65,15 @@ We all know and love Salesforce Inspector: As the great Søren Krabbe did not ha ## Security and Privacy -The Salesforce Inspector browser extension/plugin communicates directly between the user's web browser and the Salesforce servers. No data is sent to other parties and no data is persisted outside of Salesforce servers after the user leaves the Salesforce Inspector pages. -The Inspector communicates via the official Salesforce webservice APIs on behalf of the currently logged in user. This means the Inspector will be capable of accessing nothing but the data and features the user has been granted access to in Salesforce. +The Salesforce Inspector Reloaded browser extension/plugin communicates directly between the user's web browser and the Salesforce servers. No data is sent to other parties. -All Salesforce API calls from the Inspector re-uses the access token/session used by the browser to access Salesforce. To acquire this access token the Salesforce Inspector requires permission to read browser cookie information for Salesforce domains. +We are saving some info in the browser localStorage to avoid redundant queries and save user extension's preferences. None of the saved elements are related to Salesforce SObject data (Account, Contact etc.) + +You can find the list of all the localStorage saved [here](https://github.com/search?q=repo:tprouvot/Salesforce-Inspector-reloaded+"localStorage"+path:addon&type=code) and inspect what is stored by following [this tutorial](https://developer.chrome.com/docs/devtools/storage/localstorage) + +The extension communicates via the official Salesforce webservice APIs on behalf of the currently logged in user. This means the extension will be capable of accessing nothing but the data and features the user has been granted access to in Salesforce. + +All Salesforce API calls from the Inspector re-uses the access token/session used by the browser to access Salesforce (or the generated on if API Access Control is enabled). To acquire this access token the Salesforce Inspector requires permission to read browser cookie information for Salesforce domains. To validate the accuracy of this description, inspect the source code, monitor the network traffic in your browser or take my word. @@ -113,6 +121,7 @@ Thank you for shaping our extension's future! Your feedback makes it better. Contributions are welcome! +Before starting developments, create a feature request and explain the goal of it and the uses cases that it addresses. You can check for the [open issues](https://github.com/tprouvot/Salesforce-Inspector-reloaded/issues) and [check if any help is wanted](https://github.com/tprouvot/Salesforce-Inspector-reloaded/labels/help%20wanted) Before starting developments, create a feature request and explain the goal of it and the uses cases that it addresses. diff --git a/addon/field-creator.html b/addon/field-creator.html index d97e8326..f0c54ed4 100644 --- a/addon/field-creator.html +++ b/addon/field-creator.html @@ -1,16 +1,19 @@ - - - ... - - - - -
- - - - - + + + + ... + + + + + +
+ + + + + + \ No newline at end of file diff --git a/addon/manifest-firefox.json b/addon/manifest-firefox.json index 7e449427..4381808f 100644 --- a/addon/manifest-firefox.json +++ b/addon/manifest-firefox.json @@ -51,12 +51,20 @@ "https://*.builder.salesforce-experience.com/*" ], "all_frames": true, - "css": ["button.css", "inspect-inline.css"], - "js": ["button.js", "inspect-inline.js"] + "css": [ + "button.css", + "inspect-inline.css" + ], + "js": [ + "button.js", + "inspect-inline.js" + ] } ], "background": { - "scripts": ["background.js"] + "scripts": [ + "background.js" + ] }, "web_accessible_resources": [ "popup.html", @@ -73,4 +81,4 @@ ], "incognito": "spanning", "manifest_version": 2 -} +} \ No newline at end of file diff --git a/addon/manifest-template.json b/addon/manifest-template.json index 6d9a81f2..354089d9 100644 --- a/addon/manifest-template.json +++ b/addon/manifest-template.json @@ -10,7 +10,9 @@ "default_title": "Open popup" }, "minimum_chrome_version": "88", - "permissions": ["cookies"], + "permissions": [ + "cookies" + ], "host_permissions": [ "https://*.salesforce.com/*", "https://*.salesforce-setup.com/*", @@ -50,8 +52,14 @@ "https://*.builder.salesforce-experience.com/*" ], "all_frames": true, - "css": ["button.css", "inspect-inline.css"], - "js": ["button.js", "inspect-inline.js"] + "css": [ + "button.css", + "inspect-inline.css" + ], + "js": [ + "button.js", + "inspect-inline.js" + ] } ], "background": { @@ -72,7 +80,9 @@ "field-creator.html", "options.html" ], - "matches": ["https://*/*"], + "matches": [ + "https://*/*" + ], "extension_ids": [] } ], @@ -110,4 +120,4 @@ "description": "Event Monitor" } } -} +} \ No newline at end of file diff --git a/addon/manifest.json b/addon/manifest.json index 6157dcab..fff455fd 100644 --- a/addon/manifest.json +++ b/addon/manifest.json @@ -1,8 +1,8 @@ { - "name": "Salesforce Inspector Reloaded BETA", + "name": "Salesforce Inspector Reloaded", "description": "Productivity tools for Salesforce administrators and developers to inspect data and metadata directly from the Salesforce UI.", - "version": "1.25.3", - "version_name": "1.25 beta", + "version": "1.250", + "version_name": "1.25", "icons": { "128": "icon128.png" }, diff --git a/addon/popup.js b/addon/popup.js index eed698c9..eaed882b 100644 --- a/addon/popup.js +++ b/addon/popup.js @@ -45,7 +45,7 @@ function showApiName(e) { } function init({sfHost, inDevConsole, inLightning, inInspector}) { - let addonVersion = chrome.runtime.getManifest().version_name.substring(0, 4); + let addonVersion = chrome.runtime.getManifest().version_name; sfConn.getSession(sfHost).then(() => { ReactDOM.render(h(App, { @@ -1716,7 +1716,7 @@ class AllDataSelection extends React.PureComponent { return "https://" + sfHost + newUrl; } getSubscribeUrl(name){ - return this.props.eventMonitorHref + '&channel=' + name; + return this.props.eventMonitorHref + "&channel=" + name; } setFlowDefinitionId(recordId){ if (recordId && !this.state.flowDefinitionId){ @@ -1815,7 +1815,7 @@ class AllDataSelection extends React.PureComponent { ))), isFieldsPresent ? h("a", {ref: "showFieldApiNameBtn", onClick: showApiName, target: linkTarget, className: "slds-m-top_xx-small page-button slds-button slds-button_neutral"}, h("span", {}, "Show ", h("u", {}, "f"), "ields API names")) : null, selectedValue.sobject.isEverCreatable && !selectedValue.sobject.name.endsWith("__e") ? h("a", {ref: "showNewBtn", href: this.getNewObjectUrl(sfHost, selectedValue.sobject.newUrl), target: linkTarget, className: "slds-m-top_xx-small page-button slds-button slds-button_neutral"}, h("span", {}, h("u", {}, "N"), "ew " + selectedValue.sobject.label)) : null, - selectedValue.sobject.name.endsWith("__e") ? h("a", { href: this.getSubscribeUrl(selectedValue.sobject.name), target: linkTarget, className: "slds-m-top_xx-small page-button slds-button slds-button_neutral"}, h("span", {}, h("u", {}), "Subscribe to Event")) : null, + selectedValue.sobject.name.endsWith("__e") ? h("a", {href: this.getSubscribeUrl(selectedValue.sobject.name), target: linkTarget, className: "slds-m-top_xx-small page-button slds-button slds-button_neutral"}, h("span", {}, h("u", {}), "Subscribe to Event")) : null, ) ); } diff --git a/addon/symbols.svg b/addon/symbols.svg index 08edb1d9..4bbd8da5 100644 --- a/addon/symbols.svg +++ b/addon/symbols.svg @@ -1 +1,2541 @@ - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/package.json b/package.json index 00b914a7..cc1cffad 100644 --- a/package.json +++ b/package.json @@ -17,4 +17,4 @@ "replace-in-file": "8.1.0", "zip-dir": "2.0.0" } -} +} \ No newline at end of file