Skip to main content

Library to access Tryton server as a client

Project description

A library to access Tryton’s models like a client.

Installing

See INSTALL

Example of usage

>>> from proteus import config, Model, Wizard, Report

Configuration

Configuration to connect to a sqlite memory database using trytond as module.

>>> config = config.set_trytond('sqlite:///:memory:')

Installing a module

Find the module, call the activate button and run the upgrade wizard.

>>> Module = Model.get('ir.module')
>>> party_module, = Module.find([('name', '=', 'party')])
>>> party_module.click('activate')
>>> Wizard('ir.module.activate_upgrade').execute('upgrade')

Creating a party

First instanciate a new Party:

>>> Party = Model.get('party.party')
>>> party = Party()
>>> party.id < 0
True

Fill the fields:

>>> party.name = 'ham'

Save the instance into the server:

>>> party.save()
>>> party.name
u'ham'
>>> party.id > 0
True

Setting the language of the party

The language on party is a Many2One relation field. So it requires to get a Model instance as value.

>>> Lang = Model.get('ir.lang')
>>> en, = Lang.find([('code', '=', 'en')])
>>> party.lang = en
>>> party.save()
>>> party.lang.code
u'en'

Creating an address for the party

Addresses are store on party with a One2Many field. So the new address just needs to be appended to the list addresses.

>>> address = party.addresses.new(zip='42')
>>> party.save()
>>> party.addresses #doctest: +ELLIPSIS
[proteus.Model.get('party.address')(...)]

Adding category to the party

Categories are linked to party with a Many2Many field.

So first create a category

>>> Category = Model.get('party.category')
>>> category = Category()
>>> category.name = 'spam'
>>> category.save()

Append it to categories of the party

>>> party.categories.append(category)
>>> party.save()
>>> party.categories #doctest: +ELLIPSIS
[proteus.Model.get('party.category')(...)]

Sorting addresses and register order

Addresses are ordered by sequence which means they can be stored following a specific order. The set_sequence method stores the current order.

>>> address = party.addresses.new(zip='69')
>>> party.save()
>>> address = party.addresses.new(zip='23')
>>> party.save()

Now changing the order.

>>> reversed_addresses = list(reversed(party.addresses))
>>> while party.addresses:
...     _ = party.addresses.pop()
>>> party.addresses.extend(reversed_addresses)
>>> party.addresses.set_sequence()
>>> party.save()
>>> party.addresses == reversed_addresses
True

Support

If you encounter any problems with Tryton, please don’t hesitate to ask questions on the Tryton bug tracker, mailing list, wiki or IRC channel:

http://bugs.tryton.org/ http://groups.tryton.org/ http://wiki.tryton.org/ irc://irc.freenode.net/tryton

License

See LICENSE

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

proteus-4.6.7.tar.gz (39.6 kB view details)

Uploaded Source

Built Distributions

proteus-4.6.7-py3-none-any.whl (26.4 kB view details)

Uploaded Python 3

proteus-4.6.7-py2-none-any.whl (26.5 kB view details)

Uploaded Python 2

File details

Details for the file proteus-4.6.7.tar.gz.

File metadata

  • Download URL: proteus-4.6.7.tar.gz
  • Upload date:
  • Size: 39.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.9.1 tqdm/4.23.3 CPython/2.7.15

File hashes

Hashes for proteus-4.6.7.tar.gz
Algorithm Hash digest
SHA256 8d94d101cf703c5769809a1908b485eed8ec7a98120cdfbd233f0e660f872e72
MD5 68d60b570afb47950f688eb5f181c799
BLAKE2b-256 b422b4d4dc7306d27e86401793362e0ea669e68e97a6a2ed4151b12a41ff487b

See more details on using hashes here.

Provenance

File details

Details for the file proteus-4.6.7-py3-none-any.whl.

File metadata

  • Download URL: proteus-4.6.7-py3-none-any.whl
  • Upload date:
  • Size: 26.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.9.1 tqdm/4.23.3 CPython/2.7.15

File hashes

Hashes for proteus-4.6.7-py3-none-any.whl
Algorithm Hash digest
SHA256 0257574365f95f696c743d543f7430b3383eaf052e44d864ce2dc23ee4709e19
MD5 2d375b5742dd8756e68867025f89e649
BLAKE2b-256 e9e981bbac93f28f6fc850948e8e8924c33d602855bfe2f28e5e77026d8b7713

See more details on using hashes here.

Provenance

File details

Details for the file proteus-4.6.7-py2-none-any.whl.

File metadata

  • Download URL: proteus-4.6.7-py2-none-any.whl
  • Upload date:
  • Size: 26.5 kB
  • Tags: Python 2
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.9.1 tqdm/4.23.3 CPython/2.7.15

File hashes

Hashes for proteus-4.6.7-py2-none-any.whl
Algorithm Hash digest
SHA256 1d796b970d094fddb32c863b1eb629c6935381e8beb46ea7aa328e6f916c152e
MD5 d36594e58a1691c3e8fb5761654abc8c
BLAKE2b-256 0da46c65e561962eafd22b18e4a0cde7be60a0af23a274b76082a1f77c8ee224

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page