Get local daemon identity (loopback/socket only)
const url = 'http://localhost:9477/api/instance';const options = {method: 'GET'};
try { const response = await fetch(url, options); const data = await response.json(); console.log(data);} catch (error) { console.error(error);}curl --request GET \ --url http://localhost:9477/api/instanceReturns the running daemon’s datadir, config path, socket path, pid, version and fingerprint. Used by a second runwisp that hit a port conflict to discover and offer to connect to or stop this daemon. Always 403 over non-loopback TCP — the paths are local-only.
Responses
Section titled “ Responses ”OK
object
A URL to the JSON Schema for this object.
Always “runwisp”; lets a caller confirm the port-holder is a RunWisp daemon.
Example
{ "$schema": "http://localhost:9477/schemas/InstanceInfo.json"}default
Section titled “default ”Error
object
A URL to the JSON Schema for this object.
A human-readable explanation specific to this occurrence of the problem.
Optional list of individual error details
object
Where the error occurred, e.g. ‘body.items[3].tags’ or ‘path.thing-id’
Error message text
The value at the given location
A URI reference that identifies the specific occurrence of the problem.
HTTP status code
A short, human-readable summary of the problem type. This value should not change between occurrences of the error.
A URI reference to human-readable documentation for the error.
Example
{ "$schema": "http://localhost:9477/schemas/ErrorModel.json", "detail": "Property foo is required but is missing.", "instance": "https://example.com/error-log/abc123", "status": 400, "title": "Bad Request", "type": "about:blank"}