Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tardo/odooterminal
Webextension tool for Odoo
https://github.com/tardo/odooterminal
chrome chrome-extension chromium chromium-extension edge edge-extension firefox firefox-webextension made-by-humans odoo webextension
Last synced: 3 days ago
JSON representation
Webextension tool for Odoo
- Host: GitHub
- URL: https://github.com/tardo/odooterminal
- Owner: Tardo
- License: agpl-3.0
- Created: 2019-12-26T14:59:48.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2024-12-28T02:02:08.000Z (25 days ago)
- Last Synced: 2025-01-11T22:11:36.895Z (10 days ago)
- Topics: chrome, chrome-extension, chromium, chromium-extension, edge, edge-extension, firefox, firefox-webextension, made-by-humans, odoo, webextension
- Language: JavaScript
- Homepage:
- Size: 2.63 MB
- Stars: 122
- Watchers: 11
- Forks: 28
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: docs/contributing.md
- License: LICENSE
- Roadmap: ROADMAP.md
Awesome Lists containing this project
README
![Mozilla Add-on](https://img.shields.io/amo/v/odoo-terminal?style=for-the-badge)
![Mozilla Add-on](https://img.shields.io/amo/users/odoo-terminal?style=for-the-badge) ![Chrome Add-on](https://img.shields.io/chrome-web-store/v/fdidojpjkbpfplcdmeaaehnjfkgpbhad?style=for-the-badge)
![Chrome Add-on](https://img.shields.io/chrome-web-store/users/fdidojpjkbpfplcdmeaaehnjfkgpbhad?style=for-the-badge) ![Edge Add-on](https://img.shields.io/badge/dynamic/json?style=for-the-badge&label=edge%20add-on&prefix=v&query=%24.version&url=https%3A%2F%2Fmicrosoftedge.microsoft.com%2Faddons%2Fgetproductdetailsbycrxid%2Ffhndkkdikhceeojdacifnlmaeoklbogg)
![](https://img.shields.io/badge/dynamic/json?style=for-the-badge&label=users&query=%24.activeInstallCount&url=https%3A%2F%2Fmicrosoftedge.microsoft.com%2Faddons%2Fgetproductdetailsbycrxid%2Ffhndkkdikhceeojdacifnlmaeoklbogg)
OdooTerminal - WebExtension[![Tests](https://github.com/Tardo/OdooTerminal/actions/workflows/tests.yml/badge.svg)](https://github.com/Tardo/OdooTerminal/actions/workflows/tests.yml)
The BFG10k for Odoo developers
All the power of Odoo json-rpc in a really easy way!This web extension adds a terminal-like to control Odoo (11 to 18). All implemented commands use the tools provided by
the Odoo framework. An unwavering policy when developing this extension is to not modify or alter in any way the Odoo
classes. This sometimes results in certain commands having reduced/increased capabilities depending on the Odoo version.The terminal is fully initialized when it is first opened after loading the page. The time overhead for using this
extension is ~24ms.**Downloads**
[](https://addons.mozilla.org/es/firefox/addon/odoo-terminal/)
[](https://chrome.google.com/webstore/detail/odoo-terminal/fdidojpjkbpfplcdmeaaehnjfkgpbhad)
[](https://microsoftedge.microsoft.com/addons/detail/odooterminal/fhndkkdikhceeojdacifnlmaeoklbogg)---
# Usage
When you visit a Odoo website, the browser action icon of the extension turn to enabled state. This indicates that the
extension is ready to use in the current page.Few commands aren't available on the frontend, use command 'help' to know the available commands.
You can toggle terminal using one of these options:
- Press CTRL + , (by default)
- Use extension browser action icon## Example Commands
| Description | Terminal Command |
| --------------------------------------------------- | --------------------------------------------------------------------- |
| Create 'res.partner' record | `create -m res.partner -v {name: 'Hipcut', street: 'Mystery street'}` |
| Search 'res.partner' records | `search -m res.partner -f name,email -d [['id', '>', 5]]` |
| Search all fields of selected 'res.partner' records | `search -m res.partner -f * -d [['id', '>', 5]]` |
| Read all fields of selected 'res.partner' record | `read -m res.partner -i 5 -f *` |
| Read all fields of various 'res.partner' records | `read -m res.partner -i 5,15,8 -f *` |
| View 'res.partner' records _(only backend)_ | `view -m res.partner` |
| View selected 'res.partner' record _(only backend)_ | `view -m res.partner -i 4` |
| Install module | `install -m mymodule` |
| Create alias | `alias -n myalias -c "print 'My name is: $1'"` |> Notice that a list is an string of values separated by commas. Example: "5, 15, 8" (quotes included) or can use array
> notation [5, 15, 8]> Notice that can call commands without 'named arguments', for example:
> `create res.partner {name: 'Hipcut', street: 'Mystery street'}`. The rule is that 'unnamed arguments' fill values
> following the order of the command arguments definition. So mix 'unnamed' with 'named' arguments can be done as long
> as the order is maintained.## Notes
- This extension have a "preferences" page where you can add commands to run on every session. This is useful for
example to load a remote script to extend the 'terminal' features or declare custom aliases.
- This extension uses an internal context to extend the 'user context'. This 'terminal context' has by default the key
'active_test' = false (see issue #14 to get more information). This context only affects to terminal operations.
- The maximum buffered screen lines is set to 750. So, you can't see more than 749 records in the same query. This is
necessary to avoid have a lot of nodes... One of the problems of use HTML elements to render the output :/
- Can remap preferred key combination at chrome://extensions/shortcuts---
## Advance Usage
#### + HELPERS
The following are available:
| Name | Description |
| ------- | ----------------------------- |
| $$RMOD | Returns the active model name |
| $$RID | Returns the active record id |
| $$UID | Returns the active user id |
| $$UNAME | Returns the active user login |Examples:
- `search $$RMOD`
- `write $$RMOD $$RID {name: 'The new name'}`#### + Recordsets
`search`, `read` and `create` commands returns `recordsets`. Can use them to write values with `commit` command.
Example:
```
$rs = (search res.partner)
$rs[4]['name'] = 'The Name'
$rs[2]['name'] = 'Other Name'
commit $rs$record = (read res.partner 8)
$record['name'] = 'Willy Wonka'
$record['city'] = 'O Courel'
commit $record$new_rec = (create res.partner {name: 'The test'})
print $new_rec
```#### + Nested Calls
You can execute "commands" to use the result in a new command call. The syntax of 'nested calls' looks like `(command)`.
For example: `read -m res.users -i (search -m res.users -f id)[0]['id']` or
`read -m res.users -i (search -m res.users -f id)['ids']`#### + Loops
Massive operations are possible using `for loops`. Print to screen is a expensive task, consider use the keyword
`silent` to increase the performance.Examples:
- Create 5000 res.partner:{
`for ($i = 0; $i < 5000; $i += 1) { silent create -m res.partner -v {name: (gen str 12 8) + ' (Test)'} }`
- Cancel all sale.order:
`$orders = (search sale.order); for ($i = 0; $i < $orders['length']; $i += 1) { silent call sale.order action_cancel [$orders[$i]['id']] }`#### + Send files
Can use the command 'genfile' to create a file object that can be sent via post.
Example:
- `post '/web/binary/upload_attachment' -d {callback: '', model: 'res.partner', id: 1, ufile: (genfile)}`
#### + Websockets
Can open websocket connections (Odoo 16.0+).
Example:
- ```
$webs = (ws -o open -e /websocket)
ws -o send -wo $webs -d "hello"
```#### + Math operations
Examples:
- Print 3*2 result: `print 3 * 2`
- Modify the lst_price of the 3,product.product:
`$prod = (read product.product 3 -f lst_price); $prod['lst_price'] = 5 * $prod['lst_price']; commit $prod;`#### + If, Elif, Else
Example:
- `if ((gen int 0 8) > 2) { print 'Yussef Dayes & Alfa Mist - Blacked Out' } else { print 'Vincenzo Salvia & PJ D\'Atri - The Elemental Dive' }`
- `$num = (gen int 0 8); if ($num > 2) { print 'Yes! ' + $num + ' > 2' } else { print 'No... ' + $num + ' <= 2' }`
- `$num = (gen int 0 8); if ($num > 4) { print 'Yes! ' + $num + ' > 4' } elif ($num > 2) { print 'Yes! ' + $num + ' > 2' } else { print 'No... ' + $num + ' <= 2' }`#### + Functions
Example:
- `function myfun(user_name) { print "Hello, " + $user_name }; myfun 'world!'`
- `$myfun = function (user_name) { print "Hello, " + $user_name }; $$myfun 'world!'`---
# Extension Permissions
| Permission | Description | Reason |
| ---------- | ----------------------------------------------------- | ------------------------- |
| activeTab | Enables support to get information about browser tabs | Used to detect Odoo pages |
| storage | Enables support to manage stored data in the browser | Used for preferences |---
# More resources!
- [CHANGELOG](CHANGELOG.md)
- [Contributing](./docs/contributing.md)
- [Developing](./docs/developing.md)
- [Testing](./docs/testing.md)
- [TraSH](./docs/trash.md)
- [Translations](./docs/translations.md)---
# License
Copyright Alexandre Díaz & contributors
AGPL-3.0 or later (http://www.gnu.org/licenses/agpl)