sdk

package module
v0.1.8 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 2, 2023 License: Apache-2.0 Imports: 0 Imported by: 0

README

GoDoc

phpipam-sdk-go - Partial SDK for PHPIPAM

phpipam-sdk-go is a partial SDK for the PHPIPAM API.

This is a WIP and this README along with the rest of the code will develop until it reaches an acceptable level of maturity that it can be used with some CLI tools that we are developing to work with PHPIPAM, and possibly a Terraform provider to help insert data gathered from AWS and beyond.

Reference

See the GoDoc for the SDK usage details.

A Note on Custom Fields

The controllers in this SDK can access custom fields in one of two ways: using the embedded CustomFields map in each controller's data type, or using the Get and Update methods in each controller designed to work with custom fields. Which one you use depends on if you are using the Nested custom fields feature in PHPIPAM (requires 1.3 or higher). Nested custom fields require that you use the CustomFields map, non-nested require the use of the aforementioned functions.

Note that when you are using un-nested custom fields, you cannot use required fields - this is due to the fact that entries get added ahead of time without custom fields as there is no easy way to predict the shape of the data necessary to send to PHPIPAM in the initial creation request. If you require required fields, enable the nested functionality - otherwise, ensure that your fields are not required and choose sane defaults if it's absolutely necessary for data to be present.

A Note on Logging

This software uses apex library to handle logging. You can control verbosity by setting environment variable PHPIPAMSDK_LOGLEVEL to one of supported value:

  • debug
  • info
  • warn
  • error
  • fatal

License

Copyright 2017 PayByPhone Technologies, Inc.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

Documentation

Overview

Package sdk is a partial SDK for the PHPIPAM API.

This is a WIP and this README along with the rest of the code will develop until it reaches an acceptable level of maturity that it can be used with some CLI tools that we are developing to work with PHPIPAM, and possibly a Terraform provider to help insert data gathered from AWS and beyond.

For SDK usage, see the GoDoc at https://godoc.org/github.com/pavel-z1/phpipam-sdk-go.

Directories

Path Synopsis
controllers
addresses
Package addresses provides types and methods for working with the addresses controller.
Package addresses provides types and methods for working with the addresses controller.
l2domains
Package l2domains provides types and methods for working with the l2domains controller.
Package l2domains provides types and methods for working with the l2domains controller.
sections
Package sections provides types and methods for working with the sections controller.
Package sections provides types and methods for working with the sections controller.
subnets
Package subnets provides types and methods for working with the subnets controller.
Package subnets provides types and methods for working with the subnets controller.
vlans
Package vlans provides types and methods for working with the VLAN controller.
Package vlans provides types and methods for working with the VLAN controller.
Package phpipam contains any top-level configuration structures necessary to work with the rest of the SDK and API.
Package phpipam contains any top-level configuration structures necessary to work with the rest of the SDK and API.
client
Package client contains generic client structs and methods that are designed to be used by specific PHPIPAM services and resources.
Package client contains generic client structs and methods that are designed to be used by specific PHPIPAM services and resources.
request
Package request provides the HTTP request functionality for the PHPIPAM API.
Package request provides the HTTP request functionality for the PHPIPAM API.
session
Package session provides session management utility and token storage.
Package session provides session management utility and token storage.
Package testacc contains helper methods for running acceptance tests.
Package testacc contains helper methods for running acceptance tests.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL