Chrome and Firefox extension to add a metadata layout on top of the standard Salesforce UI to improve the productivity and joy of Salesforce configuration, development, and integration work.
We all know and love Salesforce Inspector: As the great Søren Krabbe did not have the time to maintain it anymore, I decided to take over so trailblazer community can keep asking for new features !
- New features compared to the original SF Inspector
- Security and Privacy
- Use Salesforce Inspector with a Connected App
- Installation
- Troubleshooting
- Contributions
- Development
- Release
- Design Principles
- About
- License
User guide for using the extension.
- Salesforce Developers Blog Improve Your Productivity with Salesforce Inspector Reloaded
- SalesforceBen :
- ApexHours article
- SalesforceWay podcast
- REST Explore: use Salesforce APIs without external tool
- Favicon customization for each org
- Allow users to update API Version feature 58
- Add new "Shortcuts" tab to accelerate setup navigation feature 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
- Control access to Salesforce Inspector reloaded with profiles / permissions (Implement OAuth2 flow to generate access token for connected App) how to
- Update manifest version from v2 to v3 (extensions using manifest v2 will be removed from the store)
- New UI for Export / Import
- Enhanced Event Monitor:
- Support for Change Events to monitor data changes in Salesforce
- Manual channel configuration with custom channel path input
- Improved channel type selection with dedicated dropdown
- Streamlined UI with all inputs in a single row for better usability
 
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.
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 and inspect what is stored by following this tutorial
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.
Follow steps described in how-to documentation. Note: you must complete these steps to use the extension in orgs where "API Access Control" is enabled.
Welcome to the beta testing phase! Your input is crucial for refining our extension. Here's why we need you:
Why Beta Testing?
- Diverse Testing: Identify issues across various setups.
- Real-World Scenarios: Discover unforeseen issues in different user contexts.
Report Bugs: If you discover a bug, please fill in an issue here. Detailed bug reports help us address issues quickly.
To become a beta tester, install the beta version. Thank you for shaping our extension's future! Your feedback makes it better.
- Download or clone the repo.
- Checkout the releaseCandidate branch.
- Open chrome://extensions/.
- Enable Developer mode.
- Click Load unpacked.
- Select the addonsubdirectory of this repository.
- If Salesforce Inspector is not available after installation, the most likely issue is that your browser is not up to date. See instructions for Google Chrome.
- When you enable the My Domain feature in Salesforce, Salesforce Inspector may not work until you have restarted your browser (or until you have deleted the "sid" cookie for the old Salesforce domain by other means).
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 and check if any help is wanted
Before starting developments, create a feature request and explain the goal of it and the uses cases that it addresses. To submit a PR, please create a branch from releaseCandidate which is the work in progress next version. This branch will be merge into master when the new version is published on web store.
Make sure to update CHANGES.md file by describing the improvement / bugfix you realized.
In order to make sure everyone who reads documentation is aware of your improvement, you can update the 'how-to' page to document / expose this new functionality.
Linting : to assure indentation, formatting and best practices coherence, please install ESLint extension.
- Install Node.js with npm
- npm install
- Open chrome://extensions/.
- Enable Developer mode.
- Click Load unpacked.
- Select the addonsubdirectory of this repository.
- Rename the manifest-firefox.json file to manifest.json (and manifest.json to manifest-chrome.json).
- In Firefox, open about:debugging.
- Select This Firefoxat the top left.
- Click Load Temporary Add-on….
- Select the file addon/manifest.json.
- Set up an org (e.g. a Developer Edition) and apply the following customizations:
- Everything described in metadata in test/. Push to org withsf deploy metadata -d test/ -o [your-test-org-alias].
- Make sure your user language is set to English.
- Ensure the org has no namespace prefix (Setup → Package Manager).
- Assign Permission Set SfInspectorto your user.
 
- Everything described in metadata in 
- Navigate to one of the extension pages and replace the file name with test-framework.html, for examplechrome-extension://example/test-framework.html?host=example.my.salesforce.com.
- Wait until "Salesforce Inspector unit test finished successfully" is shown.
- If the test fails, open your browser's developer tools console to see error messages.
- npm run eslint
(we don't live up to all of them. pull requests welcome)
- Stay completely inactive until the user explicitly interacts with it. The tool has the potential to break Salesforce functionality when used, since we rely on monkey patching and internal APIs. We must ensure that you cannot break Salesforce just by having the tool installed or enabled. For example, we won't fix the setup search placeholder bug.
- For manual ad-hoc tasks only. The tool is designed to help administrators and developers interact with Salesforce in the browser. It is after all a browser add-on. Enabling automation is a non-goal.
- User experience is important. Features should be intuitive and discoverable, but efficiency is more important than discoverability. More advanced features should be hidden, and primary features should be central. Performance is key.
- Automatically provide as much contextual information as possible, without overwhelming the user. Information that is presented automatically when needed is a lot more useful than information you need to explicitly request. For example, provide autocomplete for every input.
- Provide easy access to the raw Salesforce API. Enhance the interaction in a way that does not break the core use case, if our enhancements fails. For example, ensure we can display the result of a data export even if we cannot parse the SOQL query.
- It is fine to implement features that are already available in the core Salesforce UI, if we can make it easier, smarter or faster.
- Ensure that it works for as many users as possible. (for system administrators, for standard users, with person accounts, with multi currency, with large data volumes, with professional edition, on a slow network etc.)
- Be conservative about the number and complexity of Salesforce API requests we make, but don't sacrifice the other principles to do so.
- Focus on system administrators, developers and integrators.
By Thomas Prouvot and forked from Søren Krabbe and Jesper Kristensen
