Skip to content

Commit

Permalink
📚 docs: update README.md #17
Browse files Browse the repository at this point in the history
  • Loading branch information
pnguyen215 committed Sep 7, 2024
1 parent 4d876a8 commit 975920f
Showing 1 changed file with 120 additions and 13 deletions.
133 changes: 120 additions & 13 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,16 +1,14 @@
# VoipKit

The Asterisk VOIP library, implemented in the Go programming language (Golang), is a versatile and powerful tool for building robust voice over IP (VOIP) communication systems. Leveraging the efficiency and concurrency of Golang, this library enables developers to create scalable and high-performance VOIP applications with ease.
_VoipKit_ is an Asterisk VOIP library implemented in the Go programming language (Golang). It provides a powerful and flexible toolkit for building scalable and high-performance VOIP applications. This user guide will walk you through the installation, requirements, and key features of VoipKit.

Asterisk in Golang provides a wide range of features, including call routing, real-time call control, voice recording, and support for various VOIP protocols. Its modular architecture allows for customization and integration with other systems and services, making it suitable for diverse applications, from call centers to telemedicine platforms.
## Requirement

With Asterisk in Golang, developers benefit from the strengths of both the Golang language and the Asterisk ecosystem, resulting in reliable and efficient VOIP solutions that meet the demands of modern communication systems.
Go version 1.20 or higher

### Requirement
## Installation

The go version 1.20

### Installation
You can install VoipKit using one of the following methods:

- Use a specific version (tag)

Expand All @@ -24,12 +22,121 @@ go get github.com/pnguyen215/[email protected]
go get -u github.com/pnguyen215/voipkit@latest
```

### Github Action
## Features

VoipKit provides a comprehensive set of features for building and managing VOIP applications, including:

- **Asterisk Manager Interface (AMI)**: Enables communication between the Go application and the Asterisk server.
- **Event Socket**: Allows real-time event handling and monitoring.
- **Call Control**: Provides advanced call handling capabilities.
- **Configuration Management**: Supports configuration management and easy integration with existing Asterisk configurations.
- **Error Handling**: Includes detailed error handling and logging for easy debugging.

## Usage

To start using VoipKit in your Go project, import the library:

```go
import (
"github.com/pnguyen215/voipkit"
)
```

### Connecting to Asterisk

To establish a connection with the Asterisk server, you need to create an AMI instance and provide the necessary configuration:

```go
func CreateConn() (*ami.AMI, error) {
c := ami.GetAmiClientSample().
SetEnabled(true).
SetHost("127.0.0.1").
SetPort(5038).
SetUsername("username").
SetPassword("password").
SetTimeout(10 * time.Second)
ami.D().Debug("Asterisk server credentials: %v", c.String())
return ami.NewClient(ami.NewTcp(), *c)
}
```

### Retrieving SIP Peers

To retrieve the list of SIP peers from Asterisk, you can use the _GetSIPPeers_ method:

```go
func GetSIPPeers() {
c, err := CreateConn()
if err != nil {
ami.D().Error(err.Error())
return
}
c.Core().AddSession()
peers, err := c.Core().GetSIPPeers(c.Context())
if err != nil {
ami.D().Error(err.Error())
return
}
for _, v := range peers {
ami.D().Info("Peer: %v", v.Get("object_name"))
}
}
```

### Retrieving SIP Peer Status

To retrieve the status of a specific SIP peer, you can use the _GetSIPPeerStatus_ method:

```go
func GetSIPPeerStatus() {
c, err := createConn()
if err != nil {
ami.D().Error(err.Error())
return
}
c.Core().AddSession()
peer, err := c.Core().GetSIPPeerStatus(c.Context(), "1004")
if err != nil {
ami.D().Error(err.Error())
return
}
ami.D().Info("Peer: %v| Status: %v", peer.Get("peer"), peer.Get("peer_status"))
}
```

### Executing Asterisk CLI Commands

To execute Asterisk CLI commands, you can use the Command method:

```go
func ExecuteCLICommand() {
c, err := CreateConn()
if err != nil {
ami.D().Error(err.Error())
return
}
c.Socket().SetDebugMode(true)
c.Core().AddSession()
response, err := c.Core().Command(c.Context(), "sip show users")
if err != nil {
ami.D().Error(err.Error())
return
}
fmt.Println(ami.JsonString(response))
```
## Github Action
VoipKit leverages Github Actions for continuous integration and deployment. The following actions are used:
- [Action gh-release](https://github.com/softprops/action-gh-release): This action automates the creation of Github releases.
- [Github Security guides](https://docs.github.com/en/actions/security-guides): Follow these security guides to ensure the safety and integrity of your Github Actions workflows.
## Reference
- [Action gh-release](https://github.com/softprops/action-gh-release)
- [Github Security guides](https://docs.github.com/en/actions/security-guides)
- [Asterisk Documentation](https://docs.asterisk.org): Official documentation for Asterisk, providing comprehensive guides and reference materials.
- [Official Asterisk Repositories](https://github.com/asterisk/documentation): Github repositories containing Asterisk documentation and related resources.
### Reference
## Conclusion
- [Asterisk Documentation](https://docs.asterisk.org)
- [Official Asterisk Repositories](https://github.com/asterisk/documentation)
VoipKit is a powerful and flexible library for building VOIP applications using Go and Asterisk. With its rich set of features and modular architecture, it enables developers to create scalable and efficient VOIP solutions. By following this user guide and leveraging the provided resources, you can quickly get started with VoipKit and build robust VOIP applications.

0 comments on commit 975920f

Please sign in to comment.