• Stars
    star
    158
  • Rank 237,131 (Top 5 %)
  • Language
    PHP
  • License
    MIT License
  • Created over 7 years ago
  • Updated about 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Odoo ERP API for Laravel

Laradoo

Odoo ERP API for Laravel. Odoo website

Build Status Total Downloads Latest Stable Version License

Compatibility

Laravel version PHP version Package version
^5.1 ^5.6 ^V2.0
^5.1 ^5.5 ^V1.1

Installation

type in console:

composer require edujugon/laradoo

Register Laradoo service by adding it to the providers array.

'providers' => array(
        ...
        Edujugon\Laradoo\Providers\OdooServiceProvider::class
    )

Let's add the Alias facade, add it to the aliases array.

'aliases' => array(
        ...
        'Odoo' => Edujugon\Laradoo\Facades\Odoo::class,
    )

Publish the package's configuration file to the application's own config directory

php artisan vendor:publish --provider="Edujugon\Laradoo\Providers\OdooServiceProvider" --tag="config"

Configuration

After publishing the package config file, the base configuration for laradoo package is located in config/laradoo.php

Also, you can dynamically update those values calling the available setter methods:

host($url), username($username), password($password), db($name), apiSuffix($name)

Usage samples

Instance the main Odoo class:

$odoo = new \Edujugon\Laradoo\Odoo();

You can get the Odoo API version just calling the version method:

$version = $odoo->version();

This methods doesn't require to be connected/Logged into the ERP.

Connect and log into the ERP:

$odoo = $odoo->connect();

All needed configuration data is taken from laradoo.php config file. But you always may pass new values on the fly if required.

$this->odoo = $this->odoo
            ->username('my-user-name')
            ->password('my-password')
            ->db('my-db')
            ->host('https://my-host.com')
            ->connect();

// Note: host should contain 'http://' or 'https://'

After login, you can check the user identifier like follows:

$userId= $this->odoo->getUid();

You always can check the permission on a specific model:

$can = $odoo->can('read', 'res.partner');

Permissions which can be checked: 'read','write','create','unlink'

Method `search provides a collection of ids based on your conditions:

$ids = $odoo->where('customer', '=', true)
            ->search('res.partner');

You can limit the amount of data using limit method and use as many as condition you need:

$ids = $odoo->where('is_company', true)
            ->where('customer', '=', true)
            ->limit(3)
            ->search('res.partner');

If need to get a list of models, use the get method:

$models = $odoo->where('customer', true)
                ->limit(3)
                ->get('res.partner');

Instead of retrieving all properties of the models, you can reduce it by adding fields method before the method get

$models = $odoo->where('customer', true)
                ->limit(3)
                ->fields('name')
                ->get('res.partner');

If not sure about what fields a model has, you can retrieve the model structure data by calling fieldsOf method:

$structure = $odoo->fieldsOf('res.partner');

Till now we have only retrieved data from the ERP but you can also Create and Delete records.

In order to create a new record just call create method as follows:

$id = $odoo->create('res.partner',['name' => 'Jonh Odoo']);

The method returns the id of the new record.

For Deleting records we have the delete method:

$result = $odoo->where('name', 'Jonh Odoo')
            ->delete('res.partner');

Notice that before calling delete method you have to use where.

You can also remove records by ids like follows:

$result = $odoo->deleteById('res.partner',$ids);

Update any record of your ERP:

$updated = $odoo->where('name', 'John Odoo')
            ->update('res.partner',['name' => 'John Odoo Odoo','email' => '[email protected]']);

Notice that all delete and update methods always returns true except if there was an error.

call method is also available for those who want to set a custom API call:

$odoo->call('res.partner', 'search',[
        [
            ['is_company', '=', true],
            ['customer', '=', true]
        ]
    ],[
        'offset'=>1,
        'limit'=>5
    ]);

Full API list

More Repositories

1

PushNotification

PHP and Laravel Package to send push notifications to Android and IOS devices.
PHP
478
star
2

laravel-google-ads

Google Adwords API for Laravel
PHP
68
star
3

XMLMapper

XMLMapper for Laravel and PHP
PHP
27
star
4

laravel-log

Simple API to write logs for Laravel.
PHP
19
star
5

SocialAutoPost

PHP and Laravel 5 Package to post on Twitter
PHP
13
star
6

node-parallelizer

A NodeJS package for running code in parallel. Initially created to provide multiprocessing in an AWS Lambda function, but it can be used in any NodeJS environment.
JavaScript
12
star
7

adminLTE

Install latest version of AdminLTE Control Panel and add some extra features in your Fresh Laravel 5 installation.
HTML
6
star
8

LaravelCachesCleaner

Laravel Console Command Package to clean all caches of your project
PHP
5
star
9

JobRunningChecker

Run a callback and/or fire an event just after a job or a list of jobs of the same class have finished
PHP
4
star
10

tablediff

Comparing values of tables
PHP
3
star
11

LaravelAdminLTE

Skeleton - Laravel 5.3 & AdminLTE Control Panel Template.
JavaScript
3
star
12

LaravelExtraFeatures

This package provides useful features to give extra functionality to your Laravel project.
PHP
3
star
13

VueTableLaravel

Powerful Vue Table Component to handle Laravel DB Tables Data.
Vue
1
star
14

graphql-directive-resolve-as

Graphql directive to resolve fields as different prop names of the belonging object
JavaScript
1
star
15

serverless-remove-resources

A Serverless Framework plugin for removing resources from your CloudFormation template before deployment.
JavaScript
1
star
16

skeleton-laravel-package

Skeleton Laravel Package. Initial base for your new awesome laravel package
PHP
1
star