RPC() — supabase Function Reference
Architecture documentation for the RPC() function in RPC.tsx from the supabase codebase.
Entity Profile
Relationship Graph
Source Code
apps/studio/components/interfaces/ProjectAPIDocs/Content/RPC.tsx lines 13–103
export const RPC = ({ language }: ContentProps) => {
const { ref } = useParams()
const snap = useAppStateSnapshot()
const { data: jsonSchema, refetch: refetchJsonSchema } = useProjectJsonSchemaQuery({
projectRef: ref,
})
const { data, refetch: refetchOpenAPISpec } = useOpenAPISpecQuery({ projectRef: ref })
const functions = data?.functions ?? []
const rpcName = snap.activeDocsSection[1]
const rpc = functions.find((fn) => fn.name === rpcName)
const {
post: { parameters: postParameters },
} = rpc ?? {}
const rpcJsonSchema = jsonSchema?.paths[rpc?.path]
const summary = rpcJsonSchema?.post?.summary
const rpcParamsObject =
postParameters &&
postParameters[0] &&
postParameters[0].schema &&
postParameters[0].schema.properties
? postParameters[0].schema.properties
: {}
const parameters: { name: string; format: string; type: string; required: boolean }[] =
Object.entries(rpcParamsObject)
.map(([k, v]: any) => ({
name: k,
...v,
required: postParameters[0].schema.required.includes(k),
}))
.filter((x) => !!x.name)
useEffect(() => {
if (rpcName !== undefined) {
refetchJsonSchema()
refetchOpenAPISpec()
}
}, [rpcName])
if (rpc === undefined) return null
return (
<div className="divide-y">
<div className="space-y-1 px-4 py-4">
<h2>{rpc.name}</h2>
<p className="text-sm text-foreground-light">{summary ?? 'No description available'}</p>
</div>
<div className="space-y-2 px-4 py-4">
<p className="text-sm text-foreground-light">Function arguments</p>
<Table
head={[
<Table.th key="name">Name</Table.th>,
<Table.th key="format">Format</Table.th>,
<Table.th key="type">Type</Table.th>,
<Table.th key="required"></Table.th>,
]}
body={parameters.map((parameter) => (
<Table.tr key={parameter.name}>
<Table.td title={parameter.name}>
<p className="font-mono text-xs text-foreground truncate">{parameter.name}</p>
</Table.td>
<Table.td title={parameter.format}>{parameter.format}</Table.td>
<Table.td title={parameter.type}>{parameter.type}</Table.td>
<Table.td>
{parameter.required ? (
<Badge variant="warning">Required</Badge>
) : (
<Badge variant="default">Optional</Badge>
)}
</Table.td>
</Table.tr>
))}
/>
</div>
<ResourceContent
selectedLanguage={language}
snippet={DOCS_RESOURCE_CONTENT.rpcSingle}
codeSnippets={DOCS_RESOURCE_CONTENT.rpcSingle.code({
rpcName,
rpcParams: parameters,
endpoint: 'endpoint',
apiKey: 'apiKey',
showBearer: true,
})}
/>
</div>
)
}
Domain
Subdomains
Source
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free