Metadata-Version: 2.1
Name: Flask-Odoo
Version: 0.4.0
Summary: Flask-Odoo is an extension for Flask that aims to simplify the integration with the Odoo XML-RPC API
Home-page: https://github.com/teamgeek-io/flask-odoo
Author: Teamgeek
Author-email: support@teamgeek.io
License: MIT
Keywords: utilities,development
Platform: UNKNOWN
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: Topic :: Software Development :: Libraries
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Requires-Python: >=3.6
Description-Content-Type: text/markdown
Requires-Dist: Flask (>=1.0.4)
Requires-Dist: schematics (>=2.1.0)


# Flask-Odoo

Flask-Odoo is an extension for [Flask](https://flask.palletsprojects.com/) that aims to simplify the integration with the [Odoo](https://www.odoo.com/) XML-RPC [External API](https://www.odoo.com/documentation/13.0/webservices/odoo.html).

## Installing

Install and update using [pip](https://pip.pypa.io/en/stable/quickstart/):

```
$ pip install -U Flask-Odoo
```

## Example

Initialize the Flask extension:

```
from flask import Flask
from flask_odoo import Odoo

app = Flask(__name__)
app.config["ODOO_URL"] = "http://localhost:8069"
app.config["ODOO_DB"] = "odoo"
app.config["ODOO_USERNAME"] = "admin"
app.config["ODOO_PASSWORD"] = "admin"
odoo = Odoo(app)
```

then fetch the Odoo version information by:

```
>>> odoo.common.version()
{
    "server_version": "13.0",
    "server_version_info": [13, 0, 0, "final", 0],
    "server_serie": "13.0",
    "protocol_version": 1,
}
```

or call a method on an Odoo model:

```
>>> odoo["res.partner"].check_access_rights("read", raise_exception=False)
true
```

If you prefer to use a higher level interface you can declare models by extending `odoo.Model` as follows:

```
class Partner(odoo.Model):
    _name = "res.partner"
    _domain = [["active", "=", True]]

    name = odoo.StringType()
```

count the number of records:

```
>>> Partner.search_count([["is_company", "=", True]])
1
```

search and read records:

```
>>> Partner.search_read([["is_company", "=", True]])
[<Partner(id=1)>]
```

read records by `id`:

```
>>> partner = Partner.search_by_id(1)
>>> partner.name
'Odoo'
```

create and update records:

```
>>> new_partner = Partner()
>>> new_partner.name = "Teamgeek"
>>> new_partner.id is None
True
>>> new_partner.create_or_update()
>>> new_partner.id
2
```

delete records:

```
>>> existing_partner = Partner()
>>> existing_partner.id = 2
>>> existing_partner.delete()
```

The `odoo.Model` base extends the [Schematics](https://github.com/schematics/schematics) `Model` class, which means that your models inherit all the capabilities of a Schematics model. For convenience the basic Schematics types are accessible directly from the Odoo instance. These types also handle Odoo `False` values for non-boolean types.

## Contributing

Setup your development environment by running:

```
$ make
```

this will create a new Python *virtualenv*, install all necessary dependencies and run the tests.


