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.
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
- Node.js 18+
npxwrapperi 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.
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_IDMERIT_API_KEYMERIT_API_COUNTRYon valikuline,EEvõiPL, vaikimisiEE
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=EEKui 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_instructionsjää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
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-mcpTeised 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 |
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_mcpServer 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 |
| 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 |
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_datamerit_read_salesmerit_read_purchasesmerit_read_financialmerit_read_inventorymerit_read_reports
Muutmise/kirjutamise tööriistad toimivad kahe käsuna, et vältida vigaste andmete sisestust:
merit_write_customers(eelvaade) jamerit_write_customers_confirm(kinnitatud muutmine)merit_write_sales(eelvaade) jamerit_write_sales_confirm(kinnitatud muutmine)merit_write_purchases(eelvaade) jamerit_write_purchases_confirm(kinnitatud muutmine)merit_write_financial(eelvaade) jamerit_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.
Kui MCP server on ühendatud, saad AI assistendiga suhelda eesti, inglise (tegelikult enamvähem mistahes) keeles.
"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 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 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.
"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, kas Merit MCP server on õigesti seadistatud ja saan Meritiga ühenduda"
Assistant saab kasutada get_setup_instructions ja merit://server/info.
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
Uuendamise viis sõltub sellest, kuidas serverit käivitad.
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@latestSeejärel taaskäivita oma AI töövahend oma kliendis, see taaskäivitab ise lokaalse MCP serveri
git pull
pip install -e ./merit_api
pip install -e ./mcpSeejärel taaskäivita oma AI töövahend.
See repository on jaotatud eraldi alamprojektideks:
- merit_api/ SDK jaoks
- mcp/ Pythoni MCP serveri jaoks
- root
package.jsonnpm wrapperi jaoks
SDK testid:
cd merit_api
python3 -m pytest -qMCP testid:
cd mcp
python3 -m pytest -qKontrolli npm wrapperi tarballi:
npm pack --dry-runSDK live integratsioonitestid on opt-in:
cd merit_api
MERIT_API_INTEGRATION_TEST=true python3 -m pytest -q- 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.