fix: Correct urlId format for documents (10 chars)
Outline uses 10-char alphanumeric urlId, not 21-char hex. Documents with wrong format returned 404 "Not found". Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -2,6 +2,15 @@
|
|||||||
|
|
||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
|
|
||||||
|
## [1.3.10] - 2026-01-31
|
||||||
|
|
||||||
|
### Fixed
|
||||||
|
|
||||||
|
- **Document urlId Format:** Fixed urlId generation to match Outline format
|
||||||
|
- Was: 21-char hex string (e.g., `86734d15885647618cb16`)
|
||||||
|
- Now: 10-char alphanumeric (e.g., `b0a14475ff`)
|
||||||
|
- Documents with wrong urlId format returned 404 "Not found"
|
||||||
|
|
||||||
## [1.3.9] - 2026-01-31
|
## [1.3.9] - 2026-01-31
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ This file provides guidance to Claude Code (claude.ai/code) when working with co
|
|||||||
|
|
||||||
MCP server for direct PostgreSQL access to Outline Wiki database. Follows patterns established by `mcp-desk-crm-sql-v3`.
|
MCP server for direct PostgreSQL access to Outline Wiki database. Follows patterns established by `mcp-desk-crm-sql-v3`.
|
||||||
|
|
||||||
**Version:** 1.3.9
|
**Version:** 1.3.10
|
||||||
**Total Tools:** 164 tools across 33 modules
|
**Total Tools:** 164 tools across 33 modules
|
||||||
**Production:** hub.descomplicar.pt (via SSH tunnel)
|
**Production:** hub.descomplicar.pt (via SSH tunnel)
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
# MCP Outline PostgreSQL - Continuacao de Testes
|
# MCP Outline PostgreSQL - Continuacao de Testes
|
||||||
|
|
||||||
**Ultima Sessao:** 2026-01-31 (actualizado)
|
**Ultima Sessao:** 2026-01-31 (actualizado)
|
||||||
**Versao Actual:** 1.3.9
|
**Versao Actual:** 1.3.10
|
||||||
**Progresso:** ~95/164 tools testadas (58%) - **CÓDIGO VALIDADO**
|
**Progresso:** ~95/164 tools testadas (58%) - **CÓDIGO VALIDADO**
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|||||||
4
package-lock.json
generated
4
package-lock.json
generated
@@ -1,12 +1,12 @@
|
|||||||
{
|
{
|
||||||
"name": "mcp-outline-postgresql",
|
"name": "mcp-outline-postgresql",
|
||||||
"version": "1.3.9",
|
"version": "1.3.10",
|
||||||
"lockfileVersion": 3,
|
"lockfileVersion": 3,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"packages": {
|
"packages": {
|
||||||
"": {
|
"": {
|
||||||
"name": "mcp-outline-postgresql",
|
"name": "mcp-outline-postgresql",
|
||||||
"version": "1.3.9",
|
"version": "1.3.10",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@modelcontextprotocol/sdk": "^1.0.0",
|
"@modelcontextprotocol/sdk": "^1.0.0",
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "mcp-outline-postgresql",
|
"name": "mcp-outline-postgresql",
|
||||||
"version": "1.3.9",
|
"version": "1.3.10",
|
||||||
"description": "MCP Server for Outline Wiki via PostgreSQL direct access",
|
"description": "MCP Server for Outline Wiki via PostgreSQL direct access",
|
||||||
"main": "dist/index.js",
|
"main": "dist/index.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
|||||||
@@ -68,7 +68,7 @@ async function main() {
|
|||||||
JSON.stringify({
|
JSON.stringify({
|
||||||
status: 'ok',
|
status: 'ok',
|
||||||
transport: 'streamable-http',
|
transport: 'streamable-http',
|
||||||
version: '1.3.9',
|
version: '1.3.10',
|
||||||
sessions: sessions.size,
|
sessions: sessions.size,
|
||||||
stateful: STATEFUL,
|
stateful: STATEFUL,
|
||||||
tools: allTools.length
|
tools: allTools.length
|
||||||
@@ -101,7 +101,7 @@ async function main() {
|
|||||||
// Create MCP server
|
// Create MCP server
|
||||||
const server = createMcpServer(pgClient.getPool(), {
|
const server = createMcpServer(pgClient.getPool(), {
|
||||||
name: 'mcp-outline-http',
|
name: 'mcp-outline-http',
|
||||||
version: '1.3.9'
|
version: '1.3.10'
|
||||||
});
|
});
|
||||||
|
|
||||||
// Track session if stateful
|
// Track session if stateful
|
||||||
|
|||||||
@@ -39,7 +39,7 @@ async function main() {
|
|||||||
// Create MCP server with shared configuration
|
// Create MCP server with shared configuration
|
||||||
const server = createMcpServer(pgClient.getPool(), {
|
const server = createMcpServer(pgClient.getPool(), {
|
||||||
name: 'mcp-outline-postgresql',
|
name: 'mcp-outline-postgresql',
|
||||||
version: '1.3.9'
|
version: '1.3.10'
|
||||||
});
|
});
|
||||||
|
|
||||||
// Connect stdio transport
|
// Connect stdio transport
|
||||||
|
|||||||
@@ -122,7 +122,7 @@ export function createMcpServer(
|
|||||||
): Server {
|
): Server {
|
||||||
const server = new Server({
|
const server = new Server({
|
||||||
name: config.name || 'mcp-outline-postgresql',
|
name: config.name || 'mcp-outline-postgresql',
|
||||||
version: config.version || '1.3.9'
|
version: config.version || '1.3.10'
|
||||||
});
|
});
|
||||||
|
|
||||||
// Set capabilities (required for MCP v2.2+)
|
// Set capabilities (required for MCP v2.2+)
|
||||||
|
|||||||
@@ -248,7 +248,7 @@ const createDocument: BaseTool<CreateDocumentArgs> = {
|
|||||||
)
|
)
|
||||||
VALUES (
|
VALUES (
|
||||||
gen_random_uuid(),
|
gen_random_uuid(),
|
||||||
substring(replace(gen_random_uuid()::text, '-', '') from 1 for 21),
|
substring(md5(random()::text) from 1 for 10),
|
||||||
$1, $2, $3, $4, $5, $6, $7, $8, $9, NOW(), NOW(), 1, false, false, false
|
$1, $2, $3, $4, $5, $6, $7, $8, $9, NOW(), NOW(), 1, false, false, false
|
||||||
)
|
)
|
||||||
RETURNING id, "urlId", title, "collectionId", "publishedAt", "createdAt"
|
RETURNING id, "urlId", title, "collectionId", "publishedAt", "createdAt"
|
||||||
|
|||||||
Reference in New Issue
Block a user