Coolify
Leverage the Coolify API to create, control, and manage all your Coolify products through a simple API interface.
Authentication
Before using the API, you'll need to generate an API token from your Coolify dashboard. Visit the Coolify API Authorization docs for detailed instructions.
Server Utilities
The module provides built-in server utilities to interact with Coolify's API endpoints. Here's how to use them:
List All Instances
Create an API endpoint at server/api/v1/coolify/instances/index.get.ts
:
export default defineEventHandler(async (_event) => {
// Add your authentication check here
return useCoolify().instances()
})
Get Specific Instance
Create an API endpoint at server/api/v1/coolify/instances/[name]/index.get.ts
:
import type { Instance } from 'nuxt-coolify'
export default defineEventHandler(async (event) => {
const name = getRouterParam(event, 'name')
const { instances } = useRuntimeConfig().coolify
if (name && !Object.prototype.hasOwnProperty.call(instances, name)) {
throw createError({
statusCode: 404,
message: 'Instance not found or not configured.',
})
}
// Add your authentication check here
return useCoolify().instances(name as Instance)
})
Client Usage
You can easily consume these API endpoints in your Nuxt components using the useFetch
composable:
<script setup lang="ts">
const {
data: instances,
status,
error,
refresh
} = useFetch('/api/v1/coolify/instances')
</script>
<template>
<div>
<h2>Coolify Instances</h2>
<div v-if="status === 'pending'">Loading...</div>
<div v-else-if="error">{{ error.message }}</div>
<div v-else>
<pre>{{ instances }}</pre>
<button @click="refresh">
Refresh Instances
</button>
</div>
</div>
</template>
Available Utilities
The module provides several utility functions through the useCoolify()
composable:
instances()
- Get all instances or a specific instancehealthcheck()
- Check the health of your Coolify server- More utilities coming soon!
Check the Coolify API Reference for a complete list of available endpoints and their usage.