|
import streamlit as st |
|
import pandas as pd |
|
import requests |
|
import base64 |
|
|
|
def get_backlinks(api_login, api_key, target_url, filters): |
|
|
|
encoded_credentials = base64.b64encode(f"{api_login}:{api_key}".encode()).decode() |
|
|
|
|
|
headers = { |
|
'Authorization': f'Basic {encoded_credentials}' |
|
} |
|
|
|
|
|
post_data = { |
|
0: { |
|
"target": target_url, |
|
"limit": 1000, |
|
"mode": "as_is", |
|
"filters": filters |
|
} |
|
} |
|
|
|
|
|
response = requests.post("https://api.dataforseo.com/v3/backlinks/backlinks/live", json=post_data, headers=headers) |
|
|
|
|
|
st.text("API Response:") |
|
st.text(f"Response Status Code: {response.status_code}") |
|
st.text(f"Response Headers: {response.headers}") |
|
try: |
|
response_json = response.json() |
|
st.text(f"Response Body: {response_json}") |
|
except ValueError as e: |
|
st.text(f"Response Body: <Not a JSON response>\nError: {e}") |
|
|
|
|
|
if response.status_code == 200 and 'results' in response_json: |
|
results = response_json['results'] |
|
if results: |
|
|
|
st.text(f"Results: {results}") |
|
|
|
|
|
df = pd.json_normalize(results) |
|
return df |
|
else: |
|
st.error("Received empty data from API.") |
|
return None |
|
else: |
|
|
|
st.error(f"Error: Code: {response.status_code} Message: {response_json.get('status_message', 'No specific error message provided')}") |
|
return None |
|
|
|
def convert_df_to_csv(df): |
|
|
|
return df.to_csv(index=False).encode('utf-8') |
|
|
|
|
|
st.sidebar.title("DataForSEO API Parameters") |
|
api_login = st.sidebar.text_input("API Login", value="[email protected]") |
|
api_key = st.sidebar.text_input("API Key", type="password") |
|
|
|
|
|
url_from_not_contain = st.sidebar.text_input("URL from does not contain (comma-separated)") |
|
is_lost = st.sidebar.checkbox("Is Lost", value=False) |
|
dofollow = st.sidebar.checkbox("Dofollow", value=True) |
|
backlink_spam_score = st.sidebar.slider("Backlink Spam Score ≤", 0, 100, 10) |
|
page_from_language = st.sidebar.selectbox("Page From Language", ['en', 'other']) |
|
|
|
|
|
filters = [] |
|
|
|
if url_from_not_contain: |
|
for url in url_from_not_contain.split(','): |
|
filters.append(["url_from", "not_like", url.strip()]) |
|
filters.append("and") |
|
|
|
if is_lost: |
|
filters.append(["is_lost", "=", is_lost]) |
|
filters.append("and") |
|
|
|
if dofollow: |
|
filters.append(["dofollow", "=", dofollow]) |
|
filters.append("and") |
|
|
|
filters.append(["backlink_spam_score", "<=", backlink_spam_score]) |
|
filters.append("and") |
|
filters.append(["page_from_language", "=", page_from_language]) |
|
|
|
|
|
if filters and filters[-1] == "and": |
|
filters.pop() |
|
|
|
|
|
col1, col2 = st.columns(2) |
|
|
|
with col1: |
|
st.header("Input") |
|
target_url = st.text_input("Enter the target URL") |
|
|
|
generate_button = st.sidebar.button("Generate All") |
|
reset_button = st.sidebar.button("Reset") |
|
|
|
|
|
if generate_button and target_url: |
|
df = get_backlinks(api_login, api_key, target_url, filters) |
|
if df is not None: |
|
csv = convert_df_to_csv(df) |
|
st.download_button( |
|
label="Download data as CSV", |
|
data=csv, |
|
file_name='backlinks.csv', |
|
mime='text/csv', |
|
) |
|
else: |
|
st.error("Failed to generate CSV: No data returned from the API or data processing error.") |
|
|
|
|
|
if reset_button: |
|
st.experimental_rerun() |
|
|
|
|
|
if df is not None: |
|
csv = convert_df_to_csv(df) |
|
st.download_button( |
|
label="Download data as CSV", |
|
data=csv, |
|
file_name='backlinks.csv', |
|
mime='text/csv', |
|
) |