Skip to content

Instantly share code, notes, and snippets.

Embed
What would you like to do?
Определить самозанятого по ИНН

Определить самозанятого по ИНН

В поддержку «Дадаты» иногда обращаются с вопросом «как проверить, является ли физлицо самозанятым». Налоговая служба не предоставляет открытых данных по самозанятым, поэтому такого сервиса нет в «Дадате».

Но можно воспользоваться API налоговой. Мы подготовили примеры, как это сделать на самых популярных языках — Python, PHP и JavaScript.

API налоговой бесплатное, но используете его вы на свой страх и риск. Никто не гарантирует, что оно будет работать корректно и стабильно.

Пример ответа API налоговой, если ИНН принадлежит самозанятому:

{
    "status": true,
    "message": "xxxxxxxxxxxx является плательщиком налога на профессиональный доход"
}

Пример ответа API, если ИНН не принадлежит самозанятому:

{
    "status": false,
    "message": "xxxxxxxxxxxx не является плательщиком налога на профессиональный доход"
}

Примеры вызова на JS, PHP и Python — ниже.

const fetch = require("node-fetch");
function checkStatus(inn, date) {
if (!date) {
date = new Date();
}
const dateStr = date.toISOString().substring(0, 10);
const url = "https://statusnpd.nalog.ru/api/v1/tracker/taxpayer_status";
const data = {
inn: inn,
requestDate: dateStr,
};
resp = fetch(url, {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify(data),
});
return resp;
}
checkStatus("027714145906")
.then((response) => {
return response.json();
})
.then((response) => {
console.log(response);
});
<?php
function checkStatus($inn, $date = null)
{
if (!$date) {
$date = new DateTime("now");;
}
$dateStr = $date->format("Y-m-d");
$url = "https://statusnpd.nalog.ru/api/v1/tracker/taxpayer_status";
$data = array(
"inn" => $inn,
"requestDate" => $dateStr
);
$options = array(
'http' => array(
'method' => 'POST',
'header' => array(
'Content-type: application/json',
),
'content' => json_encode($data)
),
);
$context = stream_context_create($options);
$result = file_get_contents($url, false, $context);
return json_decode($result);
}
$resp = checkStatus("027714145906");
var_dump($resp);
import datetime as dt
import httpx
def check_status(inn: str, date: dt.date = None) -> dict:
date = date or dt.date.today()
date_str = date.isoformat()
url = "https://statusnpd.nalog.ru/api/v1/tracker/taxpayer_status"
data = {
"inn": inn,
"requestDate": date_str,
}
resp = httpx.post(url=url, json=data)
return resp.json()
if __name__ == "__main__":
response = check_status("027714145906")
print(response)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
You can’t perform that action at this time.