Python API client library for phpIPAM installations

Overview

phpypam: Python API client library for phpIPAM installation

PyPI version Codacy Badge Documentation Status

As we started to develop phpipam-ansible-modules we used an existing python library for phpIPAM API. As we needed a good error handling and we don't expect a quick fix of existing project we started to develop our own library.

installation

This library is hosted on pypi.org, so you can simply use pip to install it.

pip install phpypam

Alternatively you can install it from source. You need to do the following:

$ git clone https://github.com/codeaffen/phpypam.git
Cloning into 'phpypam'...
remote: Enumerating objects: 1, done.
remote: Counting objects: 100% (1/1), done.
remote: Total 366 (delta 0), reused 0 (delta 0), pack-reused 365
Receiving objects: 100% (366/366), 88.57 KiB | 521.00 KiB/s, done.
Resolving deltas: 100% (187/187), done.
$ cd phpypam/
$ python setup.py install

quick start

To start using phpypam you simply have to write some lines of code.

import phpypam

pi = phpypam.api(
  url='https://ipam.example.com',
  app_id='ansible',
  username='apiuser',
  password='apiP455wd',
  ssl_verify=True
)
pi.get_entity(controller='sections')

making api connection

To connect to phpIPAM API you need some parameters to authenticate against the phpIPAM instance.

Parameter Description Default
url The URL to a phpIPAM instance. It includes the protocol (http or https).
app_id The app_id which is used for the API operations.
username The username which is used to connect to API. None
password The password to authenticate username against API. None
ssl_verify Should certificate of endpoint verified or not. Useful if you use a self signed certificate. True

Example connect to api and request current token:

connection_params = dict(
url='https://ipam.example.com',
  app_id='ansible',
  username='apiuser',
  password='apiP455wd',
  ssl_verify=True
)

pi = phpypam.api(**connection_params)

token = pi.get_token()

First of all you create a dictionary with the connection data. This dictionary will unpacked for creating a phpypam.api object.

If all went well you can use the get_token to get the currently valid token from API.

get available controllers

To work with the phpIPAM api it is useful if you know all available controllers. To achieve this you can either read the api documentation or you can use the controllers method.

controllers = pi.controllers()

The method returns a set with all supported controllers.

get an entity

To get an entity the get_entity method has to be used.

get_entity(controller, controller_path=None, params=None)

Example get a section by name:

entity = pi.get_entity(controller='sections', controller_path='foobar')

This call returns a dictionary for the entity with the name foobar.

create an entity

To create an entity the create_entity method has to be used.

create_entity(controller, controller_path=None, data=None, params=None)

Example create a section if it does not exists:

my_section = dict(
    name='foobar',
    description='new section',
    permissions='{"3":"1","2":"2"}'
)

try:
    entity = pi.get_entity(controller='sections', controller_path=my_section['name'])
except PHPyPAMEntityNotFoundException:
    print('create entity')
    entity = pi.create_entity(controller='sections', data=my_section)

In this example first we check if the section we work on already exists. If the PHPyPAMEntityNotFoundException is raised we create the entity.

update an entity

To update an entity you have to use the update_entity method.

update_entity(controller, controller_path=None, data=None, params=None)

Example update a section if it exists:

my_section['description'] = 'new description'

entity = pi.get_entity(controller='sections', controller_path=my_section['name'])
pi.update_entity(controller='sections', controller_path=entity['id'], data=my_section)

To change data you have to modify the value of the desired key to the value you want. You can see the data is changed in the dict from the former example. Then you get the entity to obtain its id to work on.

Note: All modifying operations need the id of an entity not the name.

In the last step you call update_entity and put the entity id in parameter controller_path with the data parameter you provide the fully entity description dictionary.

delete an entity

To delete an entity you have to use the delete_entity method.

delete_entity(controller, controller_path, params=None)

Example delete a existing section:

entity = pi.get_entity(controller='sections', controller_path=my_section['name'])
pi.delete_entity(controller='sections', controller_path=entity['id'])

In this example you request the entity you had created/updated in the above examples. After that you call delete_entity with the entity id from the request before.

possible exceptions

  • PHPyPAMInvalidCredentials - will be raised if something goes wrong with the authentication
  • PHPyPAMEntityNotFoundException - will be raised if an entity does not exists
  • PHPyPAMInvalidSyntax - will be raised for requests which will be answered with status code 400 from API
  • PHPyPAMException - for any errors which we catch but no specific exception exists this exception wil be raised
Comments
  • unable to login with no clear error message.

    unable to login with no clear error message.

    Hello,

    I m trying to test phpypam with the sample provide.

    pi = phpypam.api( url='http://myipam.com', app_id='xx', token='xxxxx', username='xxx', password='xxx', ssl_verify=False ) pi.get_entity(controller='sections')

    And i got the following error

    Traceback (most recent call last): File "test_ipam.py", line 10, in ssl_verify=False File "/lib/python3.6/site-packages/phpypam/core/api.py", line 66, in init self._login() File "/lib/python3.6/site-packages/phpypam/core/api.py", line 131, in _login resp = self._query(method=POST, auth=_auth) File "/lib/python3.6/site-packages/phpypam/core/api.py", line 121, in _query raise PHPyPAMException(code=result['code'], message=result['message']) phpypam.core.exceptions.PHPyPAMException

    Versions:

    • python 3.6.0
    • phpypam
    bug documentation 
    opened by kevinhuy 8
  • Added not-found error message for hostname search

    Added not-found error message for hostname search

    The following call raises a PHPyPAMException.

    pi.get_entity(controller='addresses', controller_path=f"search_hostname/{hostname}/")
    

    I would expect the library to raise PHPyPAMEntityNotFoundException instead. This PR fixes this by adding the error returned from phpipam to the expected list.

    opened by mattiasa 5
  • Unable to authenticate to API

    Unable to authenticate to API "Please provide token"

    Describe the bug This follows on from https://github.com/codeaffen/phpipam-ansible-modules/discussions/52

    Running the phpypam module on phpIPAM version 1.4.0 results in an unhandled error. Further debugging shows a HTTP 403 forbidden error with "Please provide token" from phpIPAM.

    To Reproduce Example code:

    import phpypam
    
    pi = phpypam.api(
      url='https://phpipam.server/',
      app_id='myappid',
      username='myusername',
      password='mypassword',
      ssl_verify=False
    )
    print(pi.get_entity(controller='sections'))
    

    Version 1.40 of phpIPAM used

    Expected behavior With the above code, I expect an output of the configured sections in phpIPAM

    Versions:

    • phpIPAM 1.4.0
    • phpypam 1.0.1

    Additional context Amending api.py in the core package as follows fixes the problem:

    72c72
    <     def _query(self, path='user/', headers=None, method=GET, data=None, params=None, auth=None, token=None):
    ---
    >     def _query(self, path='user', headers=None, method=GET, data=None, params=None, auth=None, token=None):
    

    It appears that from phpIPAM 1.4.1 and above, the trailing "/" is no longer needed. I tested there and it works fine without the trailing "/"

    I'm not sure if the above "fix" is the best way to fix the problem. If it is, let me know and I will try creating a pull request for that together with a feature enhancement for undefined errors (display the HTTP error and message).

    bug wontfix 
    opened by sidhoah8 5
  • Subnet address search with zero results raises incorrect exception

    Subnet address search with zero results raises incorrect exception

    Describe the bug When searching for addresses in an empty subnet a generic PHPyPAMException is raised instead of PHPyPAMEntityNotFoundException.

    To Reproduce Steps to reproduce the behavior:

    1. In phpIPAM, create a new subnet with no address entries.
    2. Search the subnet for addresses via phpypam: IPAM_API.get_entity(controller='subnets', controller_path=subnet['id']+'/addresses/')
    3. PHPyPAMException is raised with message "No addresses found"

    Expected behavior PHPyPAMEntityNotFoundException should be raised instead.

    Versions:

    • python: 3.8.10
    • phpypam: 1.0.2

    Additional context None.

    bug good first issue 
    opened by alexbb 3
  • fix #51 - wrong Exception on search on empty subnet

    fix #51 - wrong Exception on search on empty subnet

    • Fix #51 - When searching for addresses in an empty subnet
    • extend script to setup local test env to use podman if available
    • add make target to setup local phpipam test env with one command
    bug enhancement 
    opened by cmeissner 1
  • Initial Update

    Initial Update

    The bot created this issue to inform you that pyup.io has been set up on this repo. Once you have closed it, the bot will open pull requests for updates as soon as they are available.

    opened by pyup-bot 1
  • Bugfix: fix local test environment

    Bugfix: fix local test environment

    As most distributions switch from docker to podman we adapt our local test environment to make use of podman. We also make more data in for setting up the local test environment variable.

    opened by cmeissner 0
  • feat: enable matrix tests

    feat: enable matrix tests

    As phpipam-action now support different phpipam versions we switch all tests to matrix builds. So we can test different combinations of phpipam and python versions.

    opened by cmeissner 0
  • Switch test to containerized services

    Switch test to containerized services

    Like in codeaffen/phpipam-ansible-modules we want to run tests agains phpipam installation with containerized services here too. So we adapt the solution from there and switch our CI workflow to that approach For that we have to add ssl_verify to connection params and set default in Makefile

    opened by cmeissner 0
  • Search for non-existing hostname results not in correct exception

    Search for non-existing hostname results not in correct exception

    Describe the bug

    Look up for a non existing call raises a PHPyPAMException not PHPyPAMEntityNotFoundException.

    To Reproduce Steps to reproduce the behavior:

    pi.get_entity(controller='addresses', controller_path=f"search_hostname/{hostname}/")

    Expected behavior

    PHPyPAMEntityNotFoundException should be raised instead.

    Versions:

    phpypam <= 1.0.1

    Additional context

    bug 
    opened by cmeissner 0
  • provide pytests

    provide pytests

    • Add modules needed for recording and replaying
    • Record tests for replay in CI
    • Add CI workflow
    • create a valid server.xml before running tests
    • Add phpypam.api as fixture for most tests
    • remove unused imports
    opened by cmeissner 0
  • add a headers arg to create_entity()

    add a headers arg to create_entity()

    Hi, Thank you for this nice wrapper.

    Describe the bug Sometimes I run into this error https://github.com/phpipam/phpipam/issues/3177 and as stated in this issue, I have to pass {"content-type: "application/x-www-form-urlencoded"} in the headers to solve it. Currently create_entity() does not have a 'headers' argument, so I have to call _query() directly to pass the header to the request.

    Expected behavior It is a bite dirty to have to call an internal function directly, so I would like to be able to pass an 'headers' arg to create_entity(), and also to update_entity() and delete_entity for consistency I guess.

    Versions:

    • python 3.10
    • phpypam 1.0.2
    enhancement help wanted 
    opened by positiveEV 2
Releases(v1.0.2)
A Python wrapper around the Pushbullet API to send different types of push notifications to your phone or/and computer.

pushbullet-python A Python wrapper around the Pushbullet API to send different types of push notifications to your phone or/and computer. Installation

Janu Lingeswaran 1 Jan 14, 2022
Tinyman Python SDK

tinyman-py-sdk Tinyman Python SDK Design Goal This SDK is designed for automated interaction with the Tinyman AMM. It will be most useful for develope

Tinyman 113 Dec 30, 2022
A python library for anti-captcha.com

AntiCaptcha A python library for anti-captcha.com Documentation for the API Requirements git Install git clone https://github.com/ShayBox/AntiCaptcha.

Shayne Hartford 3 Dec 16, 2022
Select random winners for a Twitter giveaway

twitter_picker Select random winners for a Twitter giveaway Once the Twitter giveaway (or airdrop) is closed, assign a number to each participant. The

Michael Rawner 1 Dec 11, 2021
Python Twitter API

Python Twitter Tools The Minimalist Twitter API for Python is a Python API for Twitter, everyone's favorite Web 2.0 Facebook-style status updater for

2.9k Dec 29, 2022
Discord Token Generator based on HTTPX, makes unverified tokens and automatically joins your server! this is used for memberboosting

Discord Token Generator | 2021 Features: (1) hCaptcha Bypasser, latest hfuck.py Updated by me (2) Free Proxy Support/Scrapper (3) Custom Realistic Dat

2 Nov 30, 2021
Twitter-Scrapping - Tweeter tweets extracting using python

Twitter-Scrapping Twitter tweets extracting using python This project is to extr

Suryadeepsinh Gohil 2 Feb 04, 2022
Neofetch/pfetch, but for weather

Wfetch Neofetch/pfetch, but for weather Features Information about the weather outside: Weather condition Temperature Humidity Pressure Wind Sunrise-s

G_cat 72 Nov 18, 2022
Telegram bot for logistic - Telegram bot for logistic

Демонстрационный телеграм-бот для нужд транспортной компании Цель проекта Реализ

M1chigun 1 Feb 05, 2022
The python SDK for Eto, the AI focused data platform for teams bringing AI models to production

Eto Labs Python SDK This is the python SDK for Eto, the AI focused data platform for teams bringing AI models to production. The python SDK makes it e

5 Apr 21, 2022
Yes, it's true :revolving_hearts: This repository has 301 stars.

Yes, it's true! Inspired by a similar repository from @RealPeha, but implemented using a webhook on AWS Lambda and API Gateway, so it's serv

511 Dec 30, 2022
discord voice bot to stream radio

Radio-Id Bot (Discord Voice Bot) Radio-id-bot (Radio Indonesia) is a simple Discord Music Bot built with discord.py to play a radio from some Indonesi

Adi Fahmi 20 Sep 20, 2022
Discord Mass Edit is a unique, purging related Discord tool that differs from the regular mass delete.

Discord Mass Edit is a unique, purging related Discord tool that differs from the regular mass delete. This tool will automatically edit every message in a chosen channel and change it to a random st

c0mpt0 1 Jul 27, 2022
fair-test is a library to build and deploy FAIR metrics tests APIs supporting the specifications used by the FAIRMetrics working group.

☑️ FAIR test fair-test is a library to build and deploy FAIR metrics tests APIs supporting the specifications used by the FAIRMetrics working group. I

Maastricht University IDS 6 Oct 30, 2022
A Telegram Repo For Devs To Controll The Bots Under Maintenance.This Bot Is For Developers, If Your Bot Is Down, Use This Repo To Give Your Dear Subscribers Some Support By Providing Them Response.

Maintenance Bot A Telegram Repo For Devs To Controll The Bots Under Maintenance About This Bot This Bot Is For Developers, If Your Bot Is Down, Use Th

Vɪᴠᴇᴋ 47 Dec 29, 2022
A curated list of awesome Amazon Web Services (AWS) libraries, open source repos, guides, blogs, and other resources.

A curated list of awesome Amazon Web Services (AWS) libraries, open source repos, guides, blogs, and other resources. Featuring the Fiery Meter of AWSome.

Donne Martin 11.1k Jan 04, 2023
This program is an automated trading bot that uses TDAmeritrades Thinkorswim trading platform's scanners and alerts system.

Python Trading Bot w/ Thinkorswim Description This program is an automated trading bot that uses TDAmeritrades Thinkorswim trading platform's scanners

Trey Thomas 201 Jan 03, 2023
Automation that uses Github Actions, Google Drive API, YouTube Data API and youtube-dl together to feed BackJam app with new music

Automation that uses Github Actions, Google Drive API, YouTube Data API and youtube-dl together to feed BackJam app with new music

Antônio Oliveira 1 Nov 21, 2021
Discord Token Finder - Find half of your target's token with just their ID.

Discord Token Finder - Find half of your target's token with just their ID.

Ttawi 2 Apr 07, 2022
Data Platform com AWS CDK

Welcome to your CDK Python project! This is a blank project for Python development with CDK. The cdk.json file tells the CDK Toolkit how to execute yo

Andre Sionek 8 Jul 02, 2022