-
Notifications
You must be signed in to change notification settings - Fork 0
/
sistrix-url-search-visibility
37 lines (33 loc) · 1.53 KB
/
sistrix-url-search-visibility
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
// Get Sistrix mobile Search Visibility for certain URL, with country setup
// Set url parameter "mobile" to false for desktop visibility
const API_KEY = 'YourKey';
const FORMAT = 'json'; // Ensure format is set to 'json' for JSON responses
const DATA_PATH = ['answer', 0, 'sichtbarkeitsindex', 0, 'value']; // Path to the desired data
const COUNTRY = 'de'; // Set the country parameter (modify as needed)
// Possible country values: de, at, ch, it, es, fr, pl, nl, uk, us, se, br, tr, be, ie, pt, dk, no, fi, gr, hu, sk, cz, au, jp, ca, ro, hr, bg, si
function fetchApi() {
const url = `https://api.sistrix.com/domain.sichtbarkeitsindex?api_key=${API_KEY}&mobile=true&format=${FORMAT}&country=${COUNTRY}&url=` + document.URL;
return fetch(url)
.then(response => {
if (!response.ok) {
return response.text().then(text => { throw new Error(text) });
}
return response.json();
})
.then(data => {
// Dynamically navigate through the JSON to get the desired value
let result = data;
for (let key of DATA_PATH) {
if (result[key] !== undefined) {
result = result[key];
} else {
throw new Error('Value not found in the API response');
}
}
return result;
});
}
// Use the fetchApi function and handle results with seoSpider
return fetchApi()
.then(value => seoSpider.data(value))
.catch(error => seoSpider.error(error));