Skip to content

Logging

Ingest structured logs and run full-text log search across your application.

Overview

Base path: https://api.infrai.cc/v1/logs
Auth header: Authorization: Bearer $INFRAI_API_KEY
bash
# Call any /v1/logs capability over raw HTTP — no SDK to install.
# curl:
curl https://api.infrai.cc/v1/logs/... \
  -H "Authorization: Bearer $INFRAI_API_KEY" \
  -H "Content-Type: application/json"

Methods

logs.ingest

POST /v1/logs/ingest

批量摄取日志条目

Parameters

NameTypeRequiredDescription
entriesLogEntry[]
Required
日志条目数组
idempotency_keystringOptional幂等键,用于避免重复写入

Returns

AcceptedResult

Example

一次性前置(每个范例都假定已完成):

bash
# No SDK to install — every call is a plain HTTPS request.
# Get a project key by signing in at https://infrai.cc/login (Google/GitHub gives
# you $2 free credit; email sign-in starts at $0). On 402 INSUFFICIENT_CREDIT, add
# funds at https://infrai.cc/billing (or POST /v1/account/topup and open the
# returned checkout_url).
export INFRAI_API_KEY="ifr_..."
bash
curl -X POST https://api.infrai.cc/v1/logs/ingest \
  -H "Authorization: Bearer $INFRAI_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{"entries": []}'

logs.search

GET /v1/logs/search

搜索日志

Parameters

NameTypeRequiredDescription
qstringOptional搜索关键词
filterRecord<string, unknown>Optional过滤条件(观测过滤 DSL)
sincestringOptional起始时间
untilstringOptional结束时间
cursorstringOptional分页游标
limitnumberOptional每页返回数量

Returns

LogQueryResult

Example

一次性前置(每个范例都假定已完成):

bash
# No SDK to install — every call is a plain HTTPS request.
# Get a project key by signing in at https://infrai.cc/login (Google/GitHub gives
# you $2 free credit; email sign-in starts at $0). On 402 INSUFFICIENT_CREDIT, add
# funds at https://infrai.cc/billing (or POST /v1/account/topup and open the
# returned checkout_url).
export INFRAI_API_KEY="ifr_..."
bash
curl -X GET https://api.infrai.cc/v1/logs/search \
  -H "Authorization: Bearer $INFRAI_API_KEY"

All capabilities

Every routed capability in this module — the complete public REST contract. The methods above are the guided walkthrough; this index is the full reference.

CapabilityEndpointDescription
logs.ingestPOST /v1/logs/ingestIngest a batch of log entries.
logs.searchGET /v1/logs/searchSearch logs by keyword and time range.

End-to-end example

A production-style walkthrough of this module: configure once, then run the flow. It exercises most of the module's APIs.

A copy-paste-runnable single-file Python program (stdlib only, no SDK): set your INFRAI_API_KEY, run it, and walk this module's core flow with REAL billed calls — later steps reuse real fields returned by earlier ones. The 12-line helper is the entire integration.

python
#!/usr/bin/env python3
"""Infrai · logs — runnable real-app example (single file, zero deps).

Copy this file, set your key, run it: every step is a REAL call to
api.infrai.cc, billed at the real (tiny) per-call price, printing the
live JSON response. Get a key at https://infrai.cc/login (Google/
GitHub sign-in grants $2 free credit); add funds at
https://infrai.cc/billing. No SDK — the 12-line helper below is the
entire integration."""
import json
import os
from urllib import error, request

KEY = os.environ.get("INFRAI_API_KEY") or "ifr_..."  # <- your key
BASE = "https://api.infrai.cc"


# Same raw HTTPS POST/GET as every per-method example on this page —
# wrapped once for reuse. There is nothing else to it: no SDK.
def infrai(method, path, body=None):
    req = request.Request(
        BASE + path, method=method,
        data=json.dumps(body).encode() if body is not None else None,
        headers={"Authorization": f"Bearer {KEY}",
                 "Content-Type": "application/json"})
    try:
        with request.urlopen(req, timeout=60) as r:
            return json.loads(r.read())
    except error.HTTPError as e:
        return json.loads(e.read())


def show(label, resp):
    print(f"\n== {label} ==")
    print(json.dumps(resp, indent=2, ensure_ascii=False))
    return resp


# 1) logs.ingest — POST /v1/logs/ingest · Ingest a batch of log entries.
r1 = show("logs.ingest", infrai("POST", "/v1/logs/ingest", {"entries":[]}))

# 2) logs.search — GET /v1/logs/search · Search logs by keyword and time range.
r2 = show("logs.search", infrai("GET", "/v1/logs/search"))