fix: frappecloud billing api helper
This commit is contained in:
parent
c62e7334bc
commit
cd8320b24c
1 changed files with 83 additions and 0 deletions
83
frappe/integrations/frappe_providers/frappecloud_billing.py
Normal file
83
frappe/integrations/frappe_providers/frappecloud_billing.py
Normal file
|
|
@ -0,0 +1,83 @@
|
||||||
|
import requests
|
||||||
|
|
||||||
|
import frappe
|
||||||
|
from frappe import _
|
||||||
|
|
||||||
|
|
||||||
|
def get_base_url():
|
||||||
|
url = frappe.conf.get("saas_billing_base_url") or "https://frappecloud.com"
|
||||||
|
if frappe.conf.developer_mode and frappe.conf.get("saas_billing_base_url"):
|
||||||
|
url = frappe.conf.get("saas_billing_base_url")
|
||||||
|
return url
|
||||||
|
|
||||||
|
|
||||||
|
def get_site_name():
|
||||||
|
site_name = frappe.local.site
|
||||||
|
if frappe.conf.developer_mode and frappe.conf.get("saas_billing_site_name"):
|
||||||
|
site_name = frappe.conf.get("saas_billing_site_name")
|
||||||
|
return site_name
|
||||||
|
|
||||||
|
|
||||||
|
def get_headers():
|
||||||
|
# check if user is system manager
|
||||||
|
if frappe.get_roles(frappe.session.user).count("System Manager") == 0:
|
||||||
|
frappe.throw(_("You are not allowed to access this resource"))
|
||||||
|
|
||||||
|
# check if communication secret is set
|
||||||
|
if not frappe.conf.get("fc_communication_secret"):
|
||||||
|
frappe.throw(_("Communication secret not set"))
|
||||||
|
|
||||||
|
return {
|
||||||
|
"X-Site-Token": frappe.conf.get("fc_communication_secret"),
|
||||||
|
"X-Site": get_site_name(),
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@frappe.whitelist()
|
||||||
|
def get_token_and_base_url():
|
||||||
|
request = requests.post(
|
||||||
|
f"{get_base_url()}/api/method/press.saas.api.auth.generate_access_token",
|
||||||
|
headers=get_headers(),
|
||||||
|
)
|
||||||
|
if request.status_code == 200:
|
||||||
|
return {
|
||||||
|
"base_url": get_base_url(),
|
||||||
|
"token": request.json()["message"],
|
||||||
|
}
|
||||||
|
else:
|
||||||
|
frappe.throw(_("Failed to generate access token"))
|
||||||
|
|
||||||
|
|
||||||
|
@frappe.whitelist()
|
||||||
|
def is_access_token_valid(token):
|
||||||
|
headers = {"Content-Type": "application/json"}
|
||||||
|
request = requests.post(
|
||||||
|
f"{get_base_url()}/api/method/press.saas.api.auth.is_access_token_valid",
|
||||||
|
headers,
|
||||||
|
json={token},
|
||||||
|
)
|
||||||
|
return request.json()["message"]
|
||||||
|
|
||||||
|
|
||||||
|
@frappe.whitelist()
|
||||||
|
def current_site_info():
|
||||||
|
request = requests.post(f"{get_base_url()}/api/method/press.saas.api.site.info", headers=get_headers())
|
||||||
|
if request.status_code == 200:
|
||||||
|
return request.json().get("message")
|
||||||
|
else:
|
||||||
|
frappe.throw(_("Failed to get site info"))
|
||||||
|
|
||||||
|
|
||||||
|
@frappe.whitelist()
|
||||||
|
def api(method, data=None):
|
||||||
|
if data is None:
|
||||||
|
data = {}
|
||||||
|
request = requests.post(
|
||||||
|
f"{get_base_url()}/api/method/press.saas.api.{method}",
|
||||||
|
headers=get_headers(),
|
||||||
|
json=data,
|
||||||
|
)
|
||||||
|
if request.status_code == 200:
|
||||||
|
return request.json().get("message")
|
||||||
|
else:
|
||||||
|
frappe.throw(_("Failed while calling API {0}", method))
|
||||||
Loading…
Add table
Reference in a new issue