API¶
Ella Core exposes a RESTful API for managing subscribers, radios, profiles, users, routes, and operator configuration.
Authentication¶
Almost every operation requires a client token. The client token must be sent as Authorization HTTP Header using the Bearer
Responses¶
Ella Core's API responses are JSON objects with the following structure:
{
"result": "Result content",
"error": "Error message",
}
Info
GET calls to the /metrics
endpoint don't follow this rule, it returns text response in the Prometheus exposition format.
Rate limiting¶
Ella Core uses rate limiting to prevent abuse of the API. The rate limit is set to 100 requests per second per client.
Status codes¶
- 200 - Success.
- 201 - Created.
- 400 - Bad request.
- 401 - Unauthorized.
- 429 - Too many requests.
- 500 - Internal server error.
Client¶
Ella Core provides a Go client for interacting with the API.
package main
import (
"log"
"github.com/ellanetworks/core/client"
)
func main() {
clientConfig := &client.Config{
BaseURL: "http://127.0.0.1:32308",
}
ella, err := client.New(clientConfig)
if err != nil {
log.Println("Failed to create client:", err)
}
loginOpts := &client.LoginOptions{
Email: "admin@ellanetworks.com",
Password: "admin",
}
err = ella.Login(loginOpts)
if err != nil {
log.Println("Failed to login:", err)
}
createSubscriberOpts := &client.CreateSubscriberOptions{
Imsi: "001010100000033",
Key: "5122250214c33e723a5dd523fc145fc0",
SequenceNumber: "000000000022",
ProfileName: "default",
}
err = ella.CreateSubscriber(createSubscriberOpts)
if err != nil {
log.Println("Failed to create subscriber:", err)
}
}