Netbox - NetAPI
Tämä dokumentaatio on päivitetty viimeksi 5.2.2020.
Netboxin NetAPI on ohjelmointirajapinta partnereille. NetAPI on yksityinen palvelu, johon pääsy vaatii käyttäjätunnuksen, asiakastunnuksen ja salasanan perusteella muodostetun käyttöoikeustiivisteen.
Partnereilla on mahdollisuus kokeilla rajapintaa testiympäristössä pyytämällä tunnukset esimerkiksi Netboxin asiakaspalvelusta (tuki@netbox.fi).
Lisäksi omaan käyttöön saa myös valmiin toteutuksen PHP- ja C# -kielillä, joiden avulla partneri voi esimerkkien avulla toteuttaa helpommin integraation järjestelmäänsä.
Palvelut ovat luonteeltaan REST-tyylisiä palvelupyyntöjä.
Palvelut suoritetaan salatulla HTTPS-yhteydellä.
Tietorakenteiden siirtomuotona käytetään JSON-muotoa.
Palvelukutsujen onnistuminen ilmaistaan standardein http- paluukoodein (katso kohta HTTP-tilakoodeja alempana).
NetAPI on taaksepäin yhteensopiva, joka tarkoittaa olemassa olevien rakenteiden säilymistä tai laajentamista ei-pakottavalla tavalla. NetAPIa käyttävien ohjelmistojen on hyvä ottaa tämä huomioon ja vält>
Tässä dokumentissa kuvatun palvelun versio on 1.01. Versionumeroinnin tarkoitus on ilmaista taaksepäin yhteensopivuuden varmistamista: MAJOR.MINOR; Kun MAJOR versionumero vaihtuu (esimerkiksi 1.0 seuraajaksi tulee 2.0), palvelurajapinta ei välttämättä ole kaikilta osin yhteensopiva. Kun ainoastaan MINOR numero vaihtuu, palvelurajapinnan taaksepäin yhteensopivuus varmistetaan.
API - palvelupyynnöt:
Asiakkaat:GET palveluosoite/customers?search=<pattern>
GET palveluosoite/customers/<customer_identifier>
POST palveluosoite/customers/<customer_identifier>
Sanomat:
GET palveluosoite/messages/available
GET palveluosoite/messages/headers
GET palveluosoite/messages/headers/<type>
GET palveluosoite/messages/<type>
GET palveluosoite/messages/id/<id>
POST palveluosoite/messages
POST palveluosoite/messages (resend)
Yritystiedot:
GET palveluosoite/companies/<vat_identifier>
GET palveluosoite/companies?search=<company_name>
Tuetut tiedostotyypit
Täällä voit testata NetAPI Demo tunnuksia, kyselyjä ja nähdä mitä ne palauttaa:
NetAPI Demo -portaali
Netbox Postman Collection: Download Link
HTTP-tilakoodeja
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Autentikaatio
Käyttöoikeustietue muodostetaan kahdessa vaiheessa.Vaihe 1:
Palvelukutsuissa vaaditaan kirjautumisessa saatu käyttöoikeustietue (access token).
GET palveluosoite/tickets/<username>[/<customer_identifier>]
username = NetAPI -käyttäjätunnus
customer_identifier = asiakastunnus (esim. Y-tunnus tai optio -any-)
Muodostetaan käyttäjätunnuksen ja asiakastunnuksen perusteella tiketti kirjautumista varten. Pyynnössä ei välitetä salasanaa lainkaan palvelimelle.
Käyttäjätunnuksen parina voidaan antaa asiakastunnus. Asiakastunnuksen puuttuessa toimitaan kuten kättäjätunnuksen arvoa olisi käytetty asiakastunnuksena. Asiakastunnus voi olla myös arvoa ” -any- " ("viiva any viiva").
Huomioitavaa, että muodostaessa tikettiä ”-any-” optiolla (kentässä <customer_identifier> ) antaa admin -oikeuden kaikkiin tunnuksen alla olevien yritysten aineistoihin (sanomat, data ja asiakastietojen tallennus ja muokkaus).
Vaihtoehtoisesti annettaessa esim. Y-tunnus kentässä <customer_identifier>, rajataan oikeudet vain kyseisen yrityksen aineistoihin, dataan ja asiakastietoihin.
| url | username | NetAPI käyttäjätunnus | |
| url | customer identifier | NetAPI käyttäjätunnukseen kytketty asiakastunnus |
TicketRecord
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| version | string | rakenteen versio:"1.01" |
| ticket | string | tiketti |
| expires | date-time | tiketin voimassaolo päättyy |
URL: https://<palveluosoite>/tickets/NB1234DEMTEST/1234567-8
Palaute:
{
"version":"1.01",
"ticket":"a33fe7c61bd51ef7c510fdeb7d840f75a105acaf",
"expires":"Thu, 14 Dec 2017 14:05:18 EET"
}
Vaihe 2:
GET palveluosoite/tokens/<secured_hash>
Muodostetaan varmennetun tiivisteen (secured hash) perusteella käyttöoikeustietue (access token). Pyynnössä ei välitetä käyttäjätunnusta, asiakastunnusta eikä salasanaa lainkaan palvelimelle.
| url | secured_hash | Heksadesimaalinen sha1-tuottama varmennettu tiiviste peräkkäin yhteenliitetystä salasanasta ja tiketistä. |
TokenRecord
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| version | string | rakenteen versio:"1.01" |
| token | string | Käyttöoikeustietue |
| expires | date-time | Käyttöoikeustietueen voimassaolo päättyy |
URL: https://<palveluosoite>/tokens/8ea7d2e8f5dd2260d225e563f04ba7afe956c7f2
Palaute:
{
"version":"1.01",
"token":"eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VyIjoiTkI0MTA4QVNLVEVTVCIsImN1c3Rvb...f-Lds",
"expires":"Thu, 14 Dec 2017 16:36:26 EET"
}
Kaikki muut kutsut vaativat palautetun käyttöoikeustietueen (access token) Authorization headerinä:
Authorization: Bearer <käyttöoikeustietue>
Istunnon toiminnot rajautuvat autentikoinnissa ilmaistuun asiakkuuteen. Esimerkiksi, sanoman poiminta poimii vain asiakkaalle tulevia sanomia.
Asiakastunnuksen ollessa tyhjä tai käyttäjätunnus itsessään, toiminnot rajautuvat käyttäjätunnuksen tietoihin. Asiakastunnuksen ollessa ” -any- ”, toiminnot rajautuva käyttäjätunnuksen kaikkiin asiakkuuksiin.
ASIAKASTIEDOT
GET palveluosoite/customers?search=<pattern>
| url | pattern | Hakutekijä Voit käyttää %-merkkiä, esim. Yritysnim%, hakee kaikki asiakkaat, joiden nimi alkaa "Yritysnim" -sanalla. |
CustomerItemRecord
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| version | string | rakenteen versio:"1.01" |
| identifier | string | Asiakkaan tunniste (asiakkaan/HUBin ohjelmistossa, yleensä Y-tunnus). |
| name | string | Asiakkaan nimi. |
| vat_identifier | string | Asiakkaan y-tunnus. |
| edi_identifier | string | Asiakkaan OVT-tunnus. |
| free_text | string | Vapaata tekstiä. |
| open_invoice_channels | string |
• Jos open_invoice_channels arvo on 0, silloin myyntilaskukanava on OFF ja ostolaskukanava on OFF (molemmat kiinni). • Jos open_invoice_channels arvo on 1, silloin myyntilaskukanava on ON ja ostolaskukanava on OFF. • Jos open_invoice_channels arvo on 2, silloin myyntilaskukanava on OFF ja ostolaskukanava on ON. • Jos open_invoice_channels arvo on 3, silloin myyntilaskukanava on ON ja ostolaskukanava on ON (molemmat auki). Jos ostolaskukanava on kiinni (OFF = arvo 0 tai 1), silloin verkkolaskun lähettäjän operaattori saa automaattisesti virheilmoituksen (negatiivinen ACK -sanoma), että vastaanottajalle ei voida toimittaa verkkolaskua. |
URL: https://<palveluosoite>/customers?search=Yritys%20%Software%20%Oy
Palaute:
{
"version": "1.01",
"identifier": "1234567-8",
"name": "Yritys Software Oy",
"vat_identifier": "1234567-8",
"edi_identifier": "003712345678",
"free_text": "Vapaata lisätietoa",
"open_invoice_channels": "3"
}
GET palveluosoite/customers/<customer_identifier>
| url | customer_identifier | Asiakastunnus. |
CustomerItemRecord
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| version | string | rakenteen versio:"1.01" |
| identifier | string | Asiakkaan tunniste. |
| name | string | Asiakkaan nimi. |
| vat_identifier | string | Asiakkaan y-tunnus. |
| edi_identifier | string | Asiakkaan OVT-tunnus. |
| eaddress_send | boolean | Laskun lähetystieto verkkolaskuosoitteistoon |
| eaddress_receive | boolean | Laskun vastaanottotieto verkkolaskuosoitteistoon |
| free_text | string | Vapaata tekstiä. |
| open_invoice_channels | string |
• Jos open_invoice_channels arvo on 0, silloin myyntilaskukanava on OFF ja ostolaskukanava on OFF (molemmat kiinni). • Jos open_invoice_channels arvo on 1, silloin myyntilaskukanava on ON ja ostolaskukanava on OFF. • Jos open_invoice_channels arvo on 2, silloin myyntilaskukanava on OFF ja ostolaskukanava on ON. • Jos open_invoice_channels arvo on 3, silloin myyntilaskukanava on ON ja ostolaskukanava on ON (molemmat auki). Jos ostolaskukanava on kiinni (OFF = arvo 0 tai 1), silloin verkkolaskun lähettäjän operaattori saa automaattisesti virheilmoituksen (negatiivinen ACK -sanoma), että vastaanottajalle ei voida toimittaa verkkolaskua. |
URL: https://<palveluosoite>/customers/1234567-8
Palaute:
{
"version": "1.01",
"identifier": "1234567-8",
"name": "Yritys Software Oy",
"vat_identifier": "1234567-8",
"edi_identifier": "003712345678",
"eaddress_send": true,
"eaddress_receive": true,
"free_text": "Vapaata lisätietoa"
"open_invoice_channels": "3",
"address": {
"street": [
"Valtatie 66",
null,
null
],
"zipcode": "09100",
"city": "Kalihvornia",
"district": "Pirkanmaa",
"country": "Finland",
"phone": "044-7660001"
}
}
POST palveluosoite/customers/<customer_identifier>
| url | customer_identifier | Asiakastunnus.Jos ei annettu, yritetään luoda asiakas, muutoin koitetaan päivittää asiakkaan tiedot. | |
| body | CustomerRecord | Asiakkaan tiedot. Päivitettäessä asiakastunnuksen on täsmättävä url-parametrissa annetun tunnuksen kanssa. |
CustomerRecord
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| version | string | rakenteen versio:"1.01" |
| identifier | string | Asiakkaan tunniste (asiakkaan/HUBin ohjelmistossa, yleensä Y-tunnus). |
| name | string | Asiakkaan nimi. |
| vat_identifier | string | Asiakkaan y-tunnus |
| edi_identifier | string | Asiakkaan OVT-tunnus |
| eaddress_send | boolean | Laskun lähetystieto verkkolaskuosoitteistoon |
| eaddress_receive | boolean | Laskun vastaanottotieto verkkolaskuosoitteistoon |
| open_invoice_channels | string |
• Jos open_invoice_channels arvo on 0, silloin myyntilaskukanava on OFF ja ostolaskukanava on OFF (molemmat kiinni). • Jos open_invoice_channels arvo on 1, silloin myyntilaskukanava on ON ja ostolaskukanava on OFF. • Jos open_invoice_channels arvo on 2, silloin myyntilaskukanava on OFF ja ostolaskukanava on ON. • Jos open_invoice_channels arvo on 3, silloin myyntilaskukanava on ON ja ostolaskukanava on ON (molemmat auki). Jos ostolaskukanava on kiinni (OFF = arvo 0 tai 1), silloin verkkolaskun lähettäjän operaattori saa automaattisesti virheilmoituksen (negatiivinen ACK -sanoma), että vastaanottajalle ei voida toimittaa verkkolaskua. |
| secret | string | Asiakkaan salasana. Kenttää käytetään vain asiakastietojen päivityksissä Mekanismin avulla NetAPI käyttäjä voi tarjota asiakkuuksilleen asiakastunnukseen kytketyn salasanan halutessaan. |
| address | CustomerRecord.Address | Osoite (katso rakenne alla) |
| contact | CustomerRecord.Contact | Kontaktitiedot (katso rakenne alla) |
| support | CustomerRecord.Support | Tuen kontaktitiedot (katso rakenne alla) |
| free_text | string | Vapaata tekstiä |
CustomerRecord.Address
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| street | [string] | Katuosoite. 1-4 riviä |
| zipcode | string | Postinumero |
| city | string | Kaupunki |
| district | string | Lääni |
| country | string | Maa |
| phone | string | Puhelin |
CustomerRecord.Support
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| string | Sähköpostiosoite |
URL: https://<palveluosoite>/customers/1234567-8
body:
{
"version":"1.01",
"identifier":"1234567-8",
"name": "Yritys Software Oy",
"vat_identifier": "1234567-8",
"edi_identifier": "003712345678",
"secret": "valinnainen",
"eaddress_send": "true",
"eaddress_receive": "false",
"free_text": "Tuki klo 09-13",
"open_invoice_channels": "1",
"address": [
{
"street": "Yrityksen nimi",
"zipcode": "01-01-2018",
"city": "31-12-2080",
"district": false,
"country": "Finland",
"phone": "040123456789"
}
],
"contact": [
{
"first_name": "Matti",
"middle_name": "Masi",
"surname": "Meikäläinen",
"phone": "0401234567",
"email": "sahko.posti@osoite.net"
}
],
"support": [
{
"email": "sahko.posti@osoite.net"
}
]
}
SANOMAT
GET palveluosoite/messages/available
| Ei parametreja |
IncomingInfo
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| version | string | rakenteen versio:"1.01" |
| items | int | Saapuvien sanomatiedostojen lukumäärä |
| details | [IncomingInfo.Details] | Saapuvista sanomista erittelytietoa (katso alla) |
URL: https://<palveluosoite>/messages/available
Palaute:
{
"version": "1.01",
"items": 12
"details": [
{
"receiver": "003702823456",
"name": "Yritys Liikenne Ky",
"items": {
"messages": "12",
"acks": "11",
"errors": "1"
}
}
]
}
GET palveluosoite/messages/headers
| Ei parametreja |
IncomingInfo
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| version | string | rakenteen versio:"1.01" |
| items | int | Saapuvien sanomatiedostojen lukumäärä |
| details | [IncomingInfo.Details] | Saapuvista sanomista erittelytietoa (katso alla) |
URL: https://<palveluosoite>/messages/headers
Palaute:
[
{
"messageid": "1036",
"type": invoice,
"original_filename": "kollektor-Koll_20180410055506_0001",
"handled": "2018-05-04 12:11:17",
"sender": {
"address": "14756079",
"intermediator": "KOLLEKTORSCAN",
"name": "Laskuttaja Lex Oy",
"messageid": "75856097",
"timestamp": "2018-04-08T13:40:00+0000"
},
"receiver": {
"address": "003724563330",
"intermediator": "003726044706",
"name": "CRM House Oy"
}
}
GET palveluosoite/messages/headers/<type>
| url | type | Valinnainen rajaus haluttuun sanomatyyppin. Sanomatyypit löytyvät MessageData –rakenteen kuvauksen yhteydessä. |
IncomingInfo
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| version | string | rakenteen versio:"1.01" |
| items | int | Saapuvien sanomatiedostojen lukumäärä |
| details | [IncomingInfo.Details] | Saapuvista sanomista erittelytietoa (katso alla) |
URL: https://<palveluosoite>/messages/headers/invoice
Palaute:
[
{
"messageid": "1036",
"type": invoice,
"original_filename": "kollektor-Koll_20180410055506_0001",
"handled": "2018-05-04 12:11:17",
"sender": {
"address": "14756079",
"intermediator": "KOLLEKTORSCAN",
"name": "Laskuttaja Lex Oy",
"messageid": "75856097",
"timestamp": "2018-04-08T13:40:00+0000"
},
"receiver": {
"address": "003724563330",
"intermediator": "003726044706",
"name": "CRM House Oy"
}
}
GET palveluosoite/messages/<type>
Sanomat tulevat fifo:n mukaan, eli vanhin sanoma ensin.
| url | type | Valinnainen rajaus haluttuun sanomatyyppin. Sanomatyypit löytyvät MessageData –rakenteen kuvauksen yhteydessä. |
MessageData
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| version | string | rakenteen versio:"1.01" |
| identifier | string | Sanoman tunniste |
| ref_identifier | string | Lähetetty sanoman tunniste(demo) |
| type | enum | Sanoman tyyppi |
| datafiles | [MessageData.DataFile] | Sanoman tiedostot (katso alla) |
URL: https://<palveluosoite>/messages
Palaute:
{
"version": "1.01",
"identifier": "xml",
"ref_identifier": "1001",
"type": "ack",
"datafiles":
[
{
"data":"PFNPQVAtRU5WOkVudmV...2b2ljZWFjaz4K",
"filename":"ERR-171219150010860-52.xml",
"filesize":3684,
"filetime":"2017-12-19T15:03:55+0200",
"sha1":"d0357bd3543d322eb26cf04c8bc4094956390881"
}
]
}
GET palveluosoite/messages/id/<id>
Haku ei poista sanomaa sanoma jonosta, vaan on edelleen noudettavsissa jonohaulla.
| url | id | Tietyn sanoman sanomatunniste. Sanomatunnisteen voit noutaa /headers/ - kutsulla. |
MessageData
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| version | string | rakenteen versio:"1.01" |
| identifier | string | Sanoman tunniste |
| ref_identifier | string | Lähetetty sanoman tunniste(demo) |
| type | enum | Sanoman tyyppi |
| datafiles | [MessageData.DataFile] | Sanoman tiedostot (katso alla) |
URL: https://<palveluosoite>/id/123456
Palaute:
{
"version": "1.01",
"identifier": "1043",
"ref_identifier": "1001",
"type": "ack",
"datafiles":
[
{
"data":"PFNPQVAtRU5WOkVudmV...2b2ljZWFjaz4K",
"filename":"ERR-171219150010860-52.xml",
"filesize":3684,
"filetime":"2017-12-19T15:03:55+0200",
"sha1":"d0357bd3543d322eb26cf04c8bc4094956390881"
}
]
}
POST palveluosoite/messages
Sanoma suositellaan lähetettävän kokonaisuudessaan ZIP-tiedostona. Tiedostot voidaan lähettää myös erikseen, joka yhtenä palvelukutsuna tai erillisinä palvelukutsuina. Sanomatunniste on viitteellinen tieto. Erillisiä tiedostoja ei kytketä sanomaan sanomatunnisteen avulla, vaan ainoastaan sisältöjen perusteella. Sanomatunnisteen tulee olla pysyvästi yksikäsitteinen. Tiedostojen nimien tulee olla yksikäsitteisiä 6kk ajan.
| url | type | Valinnainen rajaus haluttuun sanomatyyppin. |
MessageData
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| version | string | rakenteen versio:"1.01" |
| identifier | string | Sanoman tunniste |
| type | enum | Sanoman tyyppi |
| datafiles | [MessageData.DataFile] | Sanoman tiedostot (katso yllä) |
POST palveluosoite/messages
Jo lähetetyn sanoman esim. laskun "resend".
| url | type | Valinnainen rajaus haluttuun sanomatyyppin. |
MessageData
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| version | string | rakenteen versio:"1.01" |
| identifier | string | Sanoman tunniste |
| type | enum | Sanoman tyyppi |
| datafiles | [MessageData.DataFile] | Sanoman tiedostot (katso yllä) |
URL: https://<palveluosoite>/messages
Body:
{
"datafiles": [
{
"data": "...base64_encode...",
"filename": "invoice_543_1234567890.xml",
"filesize": 1122
},
{
"data": "...base64_encode...",
"filename": "invoice_543_1234567890.pdf",
"filesize": 10022
}
],
"resend": {
"receiver": {
"address": "receiver_eaddress",
"intermediator": "receiver_intermediator_address"
},
"sender": {
"address": "sender_eaddress",
"intermediator": "sender_intermediator_address",
"messageid": "sender_message_id"
}
},
"type": "invoice"
}
YRITYSTIEDOT
GET palveluosoite/companies/<vat_identifier>
| url | vat_identifier | Yrityksen y-tunnus |
CompanyRecord
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| version | string | rakenteen versio:"1.01" |
| vat_identifier | string | Yrityksen y-tunnus |
| names | [CompanyRecord.Name] | Yrityksen nimitiedot (katso alla) |
| addresses | [CompanyRecord.Address] | Yrityksen osoitetiedot (katso alla) |
| eaddresses | [CompanyRecord.Eaddress] | Yrityksen sähköiset osoitetiedot (katso alla) |
URL: https://<palveluosoite>/companies/1234567-8
Palaute:
{
"version": "1.01",
"vat_identifier": "2604470-6",
"names": [
{
"name": "Netbox Finland Oy",
"start_date": "2014-03-04",
"end_date": "",
"aux": "false"
}
],
"addresses": [
{
"street": "Rautatienkatu 21",
"zipcode": "33100",
"city": "TAMPERE",
"country": "",
"type": "postal",
"start_date": "2018-02-17",
"end_date": ""
},
{
"street": "Rautatienkatu 21",
"zipcode": "33100",
"city": "TAMPERE",
"country": "",
"type": "visiting",
"start_date": "2018-02-17",
"end_date": ""
}
],
"eaddresses": [
{
"type": "ovt",
"context": "einvoice",
"direction": "send",
"address": "003726044706",
"service_type": "ovt",
"service_identifier": "003726044706"
},
{
"type": "ovt",
"context": "einvoice",
"direction": "receive",
"address": "003726044706",
"service_type": "ovt",
"service_identifier": "003726044706"
}
]
}
GET palveluosoite/companies?search=<company_name>
Hakusana(t) tulee olla enkoodattu esim. PHP:ssä urlencode($hakusana);
| url | ?search= | Yrityksen nimi tai osa nimestä. Haku on "case insensitive". |
CompanyRecord
| Kenttä | Tyyppi | Kuvaus |
|---|---|---|
| version | string | rakenteen versio:"1.01" |
URL: https://<palveluosoite>/companies?search=netbox%20%finland
Palaute:
{
"version": "1.01",
"results": [
{
"vat_identifier": "2604470-6",
"name": "Netbox Finland Oy",
"street": "Rautatienkatu 21 ",
"zipcode": "33100",
"city": "TAMPERE",
"domicile": "TAMPERE"
},
{
"vat_identifier": "1306336-9",
"name": "Tmi Netbox",
"street": " ",
"zipcode": null,
"city": null,
"domicile": "PAIMIO"
},
{
"vat_identifier": "2938504-7",
"name": "NETBOX PL SP. Z O.O.",
"street": " ",
"zipcode": null,
"city": null,
"domicile": "ULKOMAAT"
}
]
}
| Kuvaus | Formaatti | Tekninen kuvaus | Lisätietoa |
|---|---|---|---|
| Verkkolasku | Finvoice 3.0 | Finvoice | Tuemme myös vanhempia versioita |
| Verkkolasku | TEAPPSXML 3.0 | TEAPPS | Tuemme myös vanhempia versioita |
| Verkkolasku | PEPPOLBIS UBL Invoice | PEPPOL Invoice | |
| Verkkolasku | PEPPOLBIS UBL Credit Note | Peppol Credit Note | |
| Palaute | Finvoiceack | Finvoiceack | |
| Viitesuoritukset | camt.054.001.02 | CAMT54 | |
| Tiliote | camt.053.001.02 | CAMT54 | |
| SEPA-maksu | pain.001.001.03 | SEPA-maksu |