Skip to content

jaakla/merit_api

Repository files navigation

Merit Unofficial MCP Server

MCP server ja Pythoni SDK Merit Aktiva REST API jaoks. MCP server eksponeerib praegu 29 tööriista, 3 töövoo prompti ja 2 ressurssi. See on mõeldud töötama MCP klientidega nagu Claude Code, Codex CLI, Cursor, Windsurf, Cline, Gemini CLI ja sarnased tööriistad.

Aktiivne arendus. See projekt areneb endiselt. MCP kiht on kasutatav, kuid see ei ole veel täisfunktsionaalne raamatupidamise töövoosüsteem. Kontrolli iga kirjutava operatsiooni tulemust live-raamatupidamisandmete vastu enne selle usaldamist.

Vastutusest loobumine

See on eksperimentaalne ja mitteametlik projekt. See ei ole seotud AS Merit Tarkvaraga, ei ole nende poolt toetatud ega ametlikult kinnitatud.

Kasutad seda täielikult omal vastutusel. See tarkvara saab lugeda ja muuta live-raamatupidamisandmeid, sh kliente, hankijaid, artikleid, arveid, makseid, makse ja dimensioone. Autorid ei vastuta vigaste kannete, kustutatud kirjete ega muu kaudse kahju eest.

Seda tarkvara kasutades nõustud, et:

  • vastutad ise kõigi loodud või muudetud raamatupidamisandmete kontrollimise eest
  • peaksid enne tähtsate live-andmete vastu kasutamist põhjalikult testima
  • tegemist on eksperimentaalse tarkvaraga ilma igasuguse garantiita

Eeltingimused

  • Node.js 18+ npx wrapperi jaoks
  • Python 3.10+ peab olema masinas olemas

npm-pakett eemaldab vajaduse Pythoni sõltuvusi käsitsi paigaldada, kuid server ise on kirjutatud Pythonis, seega on lokaalne Python interpreter siiski vajalik.

Kasutaja API võtmed

Server vajab järgmisi võtmeid, mille saab Meriti Aktivast Ettevõtte andmete > API Seadistustes, vajalik piisav kasutaja õiguste tase (haldaja) ja pakett (Premium või parem):

  • MERIT_API_ID
  • MERIT_API_KEY
  • MERIT_API_COUNTRY on valikuline, EE või PL, vaikimisi EE

Käsurea-vahendites saab need panna keskkonda (environment variables):

export MERIT_API_ID=your-api-id
export MERIT_API_KEY=your-api-key
export MERIT_API_COUNTRY=EE

Kui MERIT_API_ID või MERIT_API_KEY puudub, võib käivituda server seadistusrežiimis, aga kindlam on need seadistada json failis nagu kirjas allpool. Seadistusrežiimis:

  • get_setup_instructions jääb kättesaadavaks
  • ressursid jäävad kättesaadavaks
  • promptid jäävad kättesaadavaks
  • API-põhised tööriistad tagastavad seadistusjuhise ega kutsu Merit API-t

Paigaldus ja seadistus

1. Lisa MCP server

Server töötab kasutaja arvutis oleva skriptina, mis ühendub otse Meriti teenusega. Kolmandat osapoolt ei ole ja kusagile mujale andmeid ei saadeta.

Claude Code: (käsurealt)

claude mcp add merit-api -- npx -y merit-unofficial-mcp

Teised tööriistad JSON-konfiguratsiooniga:

{
  "mcpServers": {
    "merit-api": {
      "command": "npx",
      "args": ["-y", "merit-unofficial-mcp"],
      "env": {
        "MERIT_API_ID": "your-api-id-here",
        "MERIT_API_KEY": "your-api-key-here",
        "MERIT_API_COUNTRY": "EE"
      }
    }
  }
}

Seadistusfail Claude Desktop-is:

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%\Claude\claude_desktop_config.json
  • Linux: ~/.config/Claude/claude_desktop_config.json

Codex CLI TOML-konfiguratsiooniga:

[mcp_servers.merit-api]
command = "npx"
args = ["-y", "merit-unofficial-mcp"]

npm wrapper npx paigaldab vajalikud Pythoni moodulid ja käivitab MCP serveri.

Tööriistade konfiguratsioonifailide asukohad
Tööriist Konfiguratsioonifail
Claude Code ~/.claude/settings.json või projekti .claude/settings.json
Codex CLI ~/.codex/config.toml
Gemini CLI ~/.gemini/settings.json
Cursor projekti .cursor/mcp.json
Windsurf ~/.codeium/windsurf/mcp_config.json
Cline VS Code seadetes cline.mcpServers all

2. Käivitamine lähtekoodist (arenduseks)

git clone https://github.com/jaakla/merit_api.git
cd merit_api
pip install -e ./merit_api
pip install -e ./mcp
python3 -m merit_api_mcp

MCP promptid

Server sisaldab kolme lihtsat näidisprompti, kuid kasutada saab ka mistahes teistsuguseid, keerukamaid käske:

Prompt Kirjeldus
setup-merit-api Selgitab, kuidas seadistada vajalikud keskkonnamuutujad ja server käivitada
create-sales-invoice Juhendab assistenti kliendi leidmisel ja müügiarve loomisel
find-or-create-customer Juhendab assistenti kliendi andmete otsimisel ja loomisel

Ressursid

Ressurss Kirjeldus
merit://server/info Serveri metaandmed, seadistusrežiimi staatus, toetatud env muutujad ja hoiatus
merit://tools/catalog Tööriistade kataloog koos konsolideeritud tööriistade, nende action'ite ja nõutud väljadega

Tööriistad (tools)

Merit võimaldab kümneid erinevaid käske, see MCP server koondab need üldistatud tööriistadeks, et vältida liiga pikka nimekirja käskudest. Üldine tööriist kasutab action välja, et valida konkreetne Merit'i workflow.

Lugemise, Read-only tööriistad:

  • merit_read_master_data
  • merit_read_sales
  • merit_read_purchases
  • merit_read_financial
  • merit_read_inventory
  • merit_read_reports

Muutmise/kirjutamise tööriistad toimivad kahe käsuna, et vältida vigaste andmete sisestust:

  • merit_write_customers (eelvaade) ja merit_write_customers_confirm (kinnitatud muutmine)
  • merit_write_sales (eelvaade) ja merit_write_sales_confirm (kinnitatud muutmine)
  • merit_write_purchases (eelvaade) ja merit_write_purchases_confirm (kinnitatud muutmine)
  • merit_write_financial (eelvaade) ja merit_write_financial_confirm (kinnitatud muutmine)

Kirjutavad tööriistad on kahe sammuga. Esimene merit_write_* kutse ei tee Merit'is muudatusi: see tagastab eelvaate, confirmation_tool nime ja unikaalse confirmation_code väärtuse. Pärast eelvaate ülevaatamist tuleb sama action'i ja samade argumentidega kutsuda vastavat *_confirm tööriista ning anda kaasa confirmation_code ja confirmed=true. Kood on seotud konkreetsete argumentidega ja seda ei saa kasutada teise muudatuse kinnitamiseks.

NB! mõned AI mudelid püüavad olla "abivalmid" ja proovivad teha _confirm käsku automaatselt ise. Ole tähelepanelik, enne kui vajutad "Allow".

Kõigi tööriistade täielik action-kataloog on ressursis merit://tools/catalog.

Kasutusnäited

Kui MCP server on ühendatud, saad AI assistendiga suhelda eesti, inglise (tegelikult enamvähem mistahes) keeles.

Uuri põhiandmeid

"Näita kliente, mis vastavad nimele Acme"

Töövahend peaks kasutama merit_read_master_data tööriista action'iga customers_list ja filters={"Name": "Acme"}.

Loo või uuenda kliendi andmeid

"Loo uus klient Example OÜ"

Töövahend peaks koostama kliendi andmete faili ja kutsuma merit_write_customers tööriista action'iga customer_upsert.

Merit nõuab teatud (ja kahjuks mitte dokumenteeritud) minimaalset komplekti andmeid, seega esimene katse võib ebaõnnestuda. Siiski paremad AI mudelid oskavad neid automaatselt juurde otsida veebist, küsida kasutajalt ja ka mitu korda erinevalt andmeid proovida, kuni toimib.

Loo müügiarve

"Loo kliendile Acme müügiarve aprilli konsultatsiooniteenuse eest"

Töövahend saab kasutada merit_read_master_data action'iga customers_list, vajadusel find-or-create-customer, ja seejärel merit_write_sales action'iga sales_invoice_create. merit_write_sales tagastab eelvaate; arve luuakse alles merit_write_sales_confirm kutsega, kui kasutaja on eelvaate üle vaadanud.

Uuri sisestatud andmeid

"Mis pangad, kulukohad, projektid ja maksud Merit'is olemas on?"

Assistant saab kasutada merit_read_master_data tööriista action'eid banks_list, cost_centers_list, projects_list ja taxes_list.

Kontrolli seadistuse seisu

"Kontrolli, kas Merit MCP server on õigesti seadistatud ja saan Meritiga ühenduda"

Assistant saab kasutada get_setup_instructions ja merit://server/info.

SDK kasutamine

See repository sisaldab ka eraldi avatud koodiga Pythoni SDK projekti kataloogis merit_api/. Siit saad kontrollida, mida täpselt tarkvara teeb, ja arendusoskuse korral pakkuda välja koodiparandusi ja -täiendusi.

Näide:

from merit_api import MeritAPI

client = MeritAPI(api_id="YOUR_API_ID", api_key="YOUR_API_KEY")

customers = client.customers.get_list()
invoices = client.sales.get_invoices(
    PeriodStart="2024-01-01",
    PeriodEnd="2024-01-31",
)

SDK sisaldab praegu:

  • deterministlikku request body serialiseerimist signeerimiseks
  • seadistatavat timeouti ja retry käitumist
  • request/response logger hooke koos saladuste redaktsiooniga
  • valikulist idempotency headeri genereerimist
  • API taseme vigade haldust, eristust HTTP 200 vastustest

Uuendamine

Uuendamise viis sõltub sellest, kuidas serverit käivitad.

Kui kasutad npx

Kui sinu MCP konfiguratsioon kasutab npx -y merit-unofficial-mcp, piisab tavaliselt AI töövahendi (nt Claude Desktop) taaskäivitamisest. Järgmisel käivitamisel tõmbab npx viimase avaldatud versiooni.

Kui klient jääb kasutama vanemat cache'itud versiooni, sunni ühe korra värskendus:

npx -y merit-unofficial-mcp@latest

Seejärel taaskäivita oma AI töövahend oma kliendis, see taaskäivitab ise lokaalse MCP serveri

Kui jooksutad algkoodist, lokaalsest GIT checkout'ist

git pull
pip install -e ./merit_api
pip install -e ./mcp

Seejärel taaskäivita oma AI töövahend.

Arendus

See repository on jaotatud eraldi alamprojektideks:

  • merit_api/ SDK jaoks
  • mcp/ Pythoni MCP serveri jaoks
  • root package.json npm wrapperi jaoks

SDK testid:

cd merit_api
python3 -m pytest -q

MCP testid:

cd mcp
python3 -m pytest -q

Kontrolli npm wrapperi tarballi:

npm pack --dry-run

SDK live integratsioonitestid on opt-in:

cd merit_api
MERIT_API_INTEGRATION_TEST=true python3 -m pytest -q

Hea teada

  • Kasuta tipptasemel AI/LLM mudeleid, kuigi need on pisut kallimad : Opus/Pro tase, ja mitte Light, mini või Haiku tase.
  • Praegune MCP server toetab ainult ühte ühendust korraga, ehk siis ühe ettevõttega tööd. Kui sa oled raamatupidamisfirma, kes soovib selle tasuta ja garaantiita koodi ning AI abil kõikide oma klientide raamatupidamist automaatselt hallata, siis olgu Jumala arm sinuga (loe: ei ole hea mõte).
  • Auditeerimiseks logi püsisalvestust ei ole
  • Dry-run kirjutusvooge veel ei ole — aga kirjutus käib läbi kontrolli, see peaks asendama dry-run enamuse juhtudel
  • Dokumentide sisestust mis nõuaks OCR töövoogu veel ei ole - nt ostuarvete sisestuseks kasuta muud AI tööriista või -mudelit, mis teeb selle tekstiks. PDF faili saab manusega ostuarvele lisada küll.

Litsents - tasuta, omal vastutusel

MIT

About

MCP and Python API SDK for Merit Activa financial software - unofficial

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors