sageintacctsdk


Namesageintacctsdk JSON
Version 1.25.2 PyPI version JSON
download
home_pagehttps://github.com/fylein/sageintacct-sdk-py
SummaryPython SDK for accessing Sage Intacct APIs
upload_time2024-12-17 05:48:00
maintainerNone
docs_urlNone
authorAshwin T
requires_pythonNone
licenseMIT
keywords sage-intacct sage fyle api python sdk
VCS
bugtrack_url
requirements requests xmltodict
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # Sage Intacct SDK
Python SDK to access Sage Intacct web services

## Installation

This project requires [Python 3+](https://www.python.org/downloads/) and [Requests](https://pypi.org/project/requests/) library (pip install requests).

1. Download this project and use it (copy it in your project, etc).
2. Install it from [pip](https://pypi.org).

        $ pip install sageintacctsdk

## Usage

To use this SDK you'll need these Sage Intacct credentials used for authentication: **sender ID**, **sender password**, **user ID**, **company ID** and **user password**.

This SDK is very easy to use.
1. First you'll need to create a connection using the main class SageIntacctSDK.
```python
from sageintacctsdk import SageIntacctSDK

connection = SageIntacctSDK(
    sender_id='<YOUR SENDER ID>',
    sender_password='<YOUR SENDER PASSWORD>',
    user_id='<YOUR USER ID>',
    company_id='<YOUR COMPANY ID>',
    user_password='<YOUR USER PASSWORD>'
)
```
2. After that you'll be able to access any of the 28 API classes: accounts, ap_payments, ar_invoices, ar_payments, attachments, bills, charge_card_accounts, charge_card_transactions, checking_accounts, classes, contacts, customers, departments, employees, expense_payment_types, expense_reports, expense_types, gl_detail, items, locations, order_entry_transactions, projects, reimbursements, revenue_recognition_schedules, revenue_recognition_schedule_entries, savings_accounts, tasks and vendors.
```python
"""
USAGE: <SageIntacctSDK INSTANCE>.<API_NAME>.<API_METHOD>(<PARAMETERS>)
"""

# Create a new Expense Report of 3800 USD, spent at 2019-28-11 and from employee with employee id E101
data = {
    'employeeid': 'E101',
    'datecreated': {
        'year': 2019,
        'month': 11,
        'day': 28
    },
    'state': 'Approved',
    'description': 'Team lunch',
    'expenses': {
        'expense': [
            {
                'expensetype': 'Food',
                'amount': 3800,
                'expensedate': {
                    'year': 2019,
                    'month': 11,
                    'day': 28
                }
            }
        ]
    }
}
response = connection.employees.post(data)

# Use get_all methods to get all objects of certain types
response = connection.accounts.get_all()

# Get details of Employee with EMPLOYEEID E101
response = connection.employees.get(field='EMPLOYEEID', value='E101')
```

## Advanced Queries
Several methods of querying the Sage Inacct API exists within the SDK.  <get_by_query> allows you to specify multiple
critera using textual mathematical operators and logical filters.

Arguments are passed to and_filter, or_filter, or both.  The and_filter is the default operator to pass filters to.
For example if you want to pass a single operator without a logical context you would pass it to and_filter.

You must pass multiple operators to or_filter.

You may also format your own filter payload in accordance with API documentation and pass to the function.

See query structures here: https://developer.intacct.com/web-services/queries/

Warning: Operators can only be used once in a given logical context. and_filter cannot accept multiple 'equalto' operators
for example.  This is an API limitation.

```python
#
# Returns Data Structure of object to perform query on.  Helpful to identify field keys.
print(connection.gl_detail.get_lookup())

# Returns records between specified dates
query_tuple_between = [('between','ENTRY_DATE',['01/01/2020','12/31/2020'])]
fields = ['RECORDNO','ENTRY_DATE','BATCH_NO','ACCOUNTNO','DEBITAMOUNT']
response = connection.gl_detail.get_by_query(fields=fields,and_filter=query_tuple_between)

# Returns records between specified accounts
query_tuple_multiple =[('greaterthan','ACOUNTNO','6000'),('lessthan','ACCOUNTNO','7000')]
response = connection.gl_detail.get_by_query(fields=fields,and_filter=query_tuple_multiple)

# Returns records that match list
in_list = ['1000','1100','1200']
query_tuple_in = [('in','ACCOUNTNO',in_list)]
response = connection.gl_detail.get_by_query(fields=fields,and_filter=query_tuple_in)

payload = {'and':{'equalto':{'field':'ACCOUNTNO','value':'1000'}}}
response = connnection.gl_detail.get_by_query(filter_payload=payload)

```

See more details about the usage into the wiki pages of this project.

## License

This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/fylein/sageintacct-sdk-py",
    "name": "sageintacctsdk",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "sage-intacct, sage, fyle, api, python, sdk",
    "author": "Ashwin T",
    "author_email": "ashwin.t@fyle.in",
    "download_url": "https://files.pythonhosted.org/packages/45/76/30ddb304b62bda30dee1fb28f22761425a1be3e72a9f16c4f41ac8217e6b/sageintacctsdk-1.25.2.tar.gz",
    "platform": null,
    "description": "# Sage Intacct SDK\nPython SDK to access Sage Intacct web services\n\n## Installation\n\nThis project requires [Python 3+](https://www.python.org/downloads/) and [Requests](https://pypi.org/project/requests/) library (pip install requests).\n\n1. Download this project and use it (copy it in your project, etc).\n2. Install it from [pip](https://pypi.org).\n\n        $ pip install sageintacctsdk\n\n## Usage\n\nTo use this SDK you'll need these Sage Intacct credentials used for authentication: **sender ID**, **sender password**, **user ID**, **company ID** and **user password**.\n\nThis SDK is very easy to use.\n1. First you'll need to create a connection using the main class SageIntacctSDK.\n```python\nfrom sageintacctsdk import SageIntacctSDK\n\nconnection = SageIntacctSDK(\n    sender_id='<YOUR SENDER ID>',\n    sender_password='<YOUR SENDER PASSWORD>',\n    user_id='<YOUR USER ID>',\n    company_id='<YOUR COMPANY ID>',\n    user_password='<YOUR USER PASSWORD>'\n)\n```\n2. After that you'll be able to access any of the 28 API classes: accounts, ap_payments, ar_invoices, ar_payments, attachments, bills, charge_card_accounts, charge_card_transactions, checking_accounts, classes, contacts, customers, departments, employees, expense_payment_types, expense_reports, expense_types, gl_detail, items, locations, order_entry_transactions, projects, reimbursements, revenue_recognition_schedules, revenue_recognition_schedule_entries, savings_accounts, tasks and vendors.\n```python\n\"\"\"\nUSAGE: <SageIntacctSDK INSTANCE>.<API_NAME>.<API_METHOD>(<PARAMETERS>)\n\"\"\"\n\n# Create a new Expense Report of 3800 USD, spent at 2019-28-11 and from employee with employee id E101\ndata = {\n    'employeeid': 'E101',\n    'datecreated': {\n        'year': 2019,\n        'month': 11,\n        'day': 28\n    },\n    'state': 'Approved',\n    'description': 'Team lunch',\n    'expenses': {\n        'expense': [\n            {\n                'expensetype': 'Food',\n                'amount': 3800,\n                'expensedate': {\n                    'year': 2019,\n                    'month': 11,\n                    'day': 28\n                }\n            }\n        ]\n    }\n}\nresponse = connection.employees.post(data)\n\n# Use get_all methods to get all objects of certain types\nresponse = connection.accounts.get_all()\n\n# Get details of Employee with EMPLOYEEID E101\nresponse = connection.employees.get(field='EMPLOYEEID', value='E101')\n```\n\n## Advanced Queries\nSeveral methods of querying the Sage Inacct API exists within the SDK.  <get_by_query> allows you to specify multiple\ncritera using textual mathematical operators and logical filters.\n\nArguments are passed to and_filter, or_filter, or both.  The and_filter is the default operator to pass filters to.\nFor example if you want to pass a single operator without a logical context you would pass it to and_filter.\n\nYou must pass multiple operators to or_filter.\n\nYou may also format your own filter payload in accordance with API documentation and pass to the function.\n\nSee query structures here: https://developer.intacct.com/web-services/queries/\n\nWarning: Operators can only be used once in a given logical context. and_filter cannot accept multiple 'equalto' operators\nfor example.  This is an API limitation.\n\n```python\n#\n# Returns Data Structure of object to perform query on.  Helpful to identify field keys.\nprint(connection.gl_detail.get_lookup())\n\n# Returns records between specified dates\nquery_tuple_between = [('between','ENTRY_DATE',['01/01/2020','12/31/2020'])]\nfields = ['RECORDNO','ENTRY_DATE','BATCH_NO','ACCOUNTNO','DEBITAMOUNT']\nresponse = connection.gl_detail.get_by_query(fields=fields,and_filter=query_tuple_between)\n\n# Returns records between specified accounts\nquery_tuple_multiple =[('greaterthan','ACOUNTNO','6000'),('lessthan','ACCOUNTNO','7000')]\nresponse = connection.gl_detail.get_by_query(fields=fields,and_filter=query_tuple_multiple)\n\n# Returns records that match list\nin_list = ['1000','1100','1200']\nquery_tuple_in = [('in','ACCOUNTNO',in_list)]\nresponse = connection.gl_detail.get_by_query(fields=fields,and_filter=query_tuple_in)\n\npayload = {'and':{'equalto':{'field':'ACCOUNTNO','value':'1000'}}}\nresponse = connnection.gl_detail.get_by_query(filter_payload=payload)\n\n```\n\nSee more details about the usage into the wiki pages of this project.\n\n## License\n\nThis project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Python SDK for accessing Sage Intacct APIs",
    "version": "1.25.2",
    "project_urls": {
        "Homepage": "https://github.com/fylein/sageintacct-sdk-py"
    },
    "split_keywords": [
        "sage-intacct",
        " sage",
        " fyle",
        " api",
        " python",
        " sdk"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "239f521833c61e1f64a98a3a7e5bfaeac6571578603367d3ce5803e4449b2873",
                "md5": "8a573e93c16229e71f828479f29b56f0",
                "sha256": "d16956f651d8f988ce658196ef3460ce1cff5d1e15650ce6a304577690435a62"
            },
            "downloads": -1,
            "filename": "sageintacctsdk-1.25.2-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "8a573e93c16229e71f828479f29b56f0",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 33449,
            "upload_time": "2024-12-17T05:47:58",
            "upload_time_iso_8601": "2024-12-17T05:47:58.376658Z",
            "url": "https://files.pythonhosted.org/packages/23/9f/521833c61e1f64a98a3a7e5bfaeac6571578603367d3ce5803e4449b2873/sageintacctsdk-1.25.2-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "457630ddb304b62bda30dee1fb28f22761425a1be3e72a9f16c4f41ac8217e6b",
                "md5": "e90e1dc6913a1e9f5c9f01301af53fff",
                "sha256": "bb7ca4b254403cafd7d820b340c9de06122019f5fe1fed492dd81a71feb07a6b"
            },
            "downloads": -1,
            "filename": "sageintacctsdk-1.25.2.tar.gz",
            "has_sig": false,
            "md5_digest": "e90e1dc6913a1e9f5c9f01301af53fff",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 21840,
            "upload_time": "2024-12-17T05:48:00",
            "upload_time_iso_8601": "2024-12-17T05:48:00.626593Z",
            "url": "https://files.pythonhosted.org/packages/45/76/30ddb304b62bda30dee1fb28f22761425a1be3e72a9f16c4f41ac8217e6b/sageintacctsdk-1.25.2.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-12-17 05:48:00",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "fylein",
    "github_project": "sageintacct-sdk-py",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "requirements": [
        {
            "name": "requests",
            "specs": [
                [
                    "==",
                    "2.31.0"
                ]
            ]
        },
        {
            "name": "xmltodict",
            "specs": [
                [
                    "==",
                    "0.12.0"
                ]
            ]
        }
    ],
    "lcname": "sageintacctsdk"
}
        
Elapsed time: 1.22496s