-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
13 changed files
with
648 additions
and
384 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1,11 @@ | ||
requests==2.28.2 | ||
annotated-types==0.6.0 | ||
certifi==2023.11.17 | ||
charset-normalizer==3.3.2 | ||
idna==3.6 | ||
pydantic==2.5.3 | ||
pydantic_core==2.14.6 | ||
requests==2.28.2 | ||
retrying==1.3.4 | ||
six==1.16.0 | ||
typing_extensions==4.9.0 | ||
urllib3==1.26.18 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,67 +1,130 @@ | ||
import os | ||
import argparse | ||
import json | ||
from constants import URL | ||
import logging | ||
import os | ||
import requests | ||
import stat | ||
from pathlib import Path | ||
from urllib.parse import urljoin | ||
|
||
import constants | ||
|
||
def create_credentials_file(file_name: str, value: str): | ||
with open(os.path.dirname(os.path.abspath(__file__)) + f"/.{file_name}", "w") as f: | ||
f.write(value) | ||
|
||
logger = logging.getLogger(__name__) | ||
|
||
def read_credentials_file(file_name: str) -> str: | ||
credentials_file_path = ( | ||
os.path.dirname(os.path.abspath(__file__)) + f"/.{file_name}" | ||
) | ||
|
||
if not os.path.exists(credentials_file_path): | ||
return None | ||
def _warn_if_wide_permissions(path): | ||
file_stat = os.stat(path) | ||
mode = file_stat.st_mode | ||
if mode & stat.S_IRWXG or mode & stat.S_IRWXO: | ||
logger.warning(f"File {path} has too wide permissions: {oct(mode & 0o777)}") | ||
|
||
return open(credentials_file_path, "r").read().strip("\n") | ||
|
||
class Authenticator: | ||
USER_ENV = "NIL_USER" | ||
SECRET_ENV = "NIL_SECRET" | ||
STORAGE_DIR = Path.home().joinpath(".config", "proof-market") | ||
CREDENTIALS_BASENAME = "credentials.json" | ||
AUTH_BASENAME = "auth.json" | ||
|
||
secret = read_credentials_file("secret") | ||
user = read_credentials_file("user") | ||
class Helpers: | ||
@staticmethod | ||
def get_base_dir(directory): | ||
return Authenticator.STORAGE_DIR if directory is None else Path(directory) | ||
|
||
@staticmethod | ||
def get_auth_file_path(directory): | ||
return Authenticator.Helpers.get_base_dir(directory) / Authenticator.AUTH_BASENAME | ||
|
||
def update_auth(auth): | ||
@staticmethod | ||
def get_credentials_file_path(directory): | ||
return Authenticator.Helpers.get_base_dir(directory) / Authenticator.CREDENTIALS_BASENAME | ||
|
||
url = URL + "/user/signin" | ||
body = {"username": user, "password": secret} | ||
def __init__(self, url: str, directory: str | None = None): | ||
self.credentials_path = Authenticator.Helpers.get_credentials_file_path(directory) | ||
self.auth_path = Authenticator.Helpers.get_auth_file_path(directory) | ||
self.username, self.secret = self.get_credentials() | ||
self.url = url | ||
|
||
response = requests.post(url, json=body) | ||
if response.status_code != 200: | ||
print(f"Update auth error: {response.status_code} {response.text}") | ||
else: | ||
with open(auth, "w") as f: | ||
headers = {"Authorization": f'Bearer {response.json()["jwt"]}'} | ||
json.dump(headers, f) | ||
return response | ||
def get_credentials(self) -> tuple[str, str]: | ||
username = os.environ.get(self.USER_ENV) | ||
secret = os.environ.get(self.SECRET_ENV) | ||
|
||
if username is None or secret is None: | ||
logger.info(f"Environment variables not set. Reading credentials from {self.credentials_path}.") | ||
_warn_if_wide_permissions(self.credentials_path) | ||
with open(self.credentials_path, 'r') as file: | ||
data = json.load(file) | ||
username = data.get('username') | ||
secret = data.get('secret') | ||
if not username or not secret: | ||
raise ValueError("Credentials not found in JSON file.") | ||
return username, secret | ||
|
||
def get_headers(auth): | ||
headers = {} | ||
if auth is None: | ||
auth = "auth.json" | ||
response = update_auth(auth) | ||
def update_auth_file(self): | ||
url = urljoin(self.url, "/user/signin") | ||
body = {"username": self.username, "password": self.secret} | ||
|
||
response = requests.post(url, json=body) | ||
if response.status_code != 200: | ||
return | ||
with open(auth, "r") as f: | ||
raise RuntimeError(f"Failed to fetch auth: {response.status_code} {response.text}") | ||
with open(self.auth_path, "w", opener=lambda path, flags: os.open(path, flags, 0o600)) as f: | ||
headers = {"Authorization": f"Bearer {response.json()['jwt']}"} | ||
json.dump(headers, f) | ||
logger.info("Auth file updated.") | ||
|
||
@staticmethod | ||
def create_credentials_file(username: str, secret: str, directory: str | None = None): | ||
credentials_data = { | ||
"username": username, | ||
"secret": secret, | ||
} | ||
credentials_json = json.dumps(credentials_data) | ||
credentials_path = Authenticator.Helpers.get_credentials_file_path(directory) | ||
os.makedirs(os.path.dirname(credentials_path), exist_ok=True) | ||
with open(credentials_path, "w", opener=lambda path, flags: os.open(path, flags, 0o600)) as f: | ||
f.write(credentials_json) | ||
logger.info(f"Credentials saved to {credentials_path}") | ||
|
||
|
||
def get_headers(directory=None, url=None): | ||
auth_path = Authenticator.Helpers.get_auth_file_path(directory) | ||
if not os.path.exists(auth_path): | ||
logger.info(f"Auth file {auth_path} does not exist.") | ||
if url is not None: | ||
logger.info(f"Trying to create it with request to {url}") | ||
authenticator = Authenticator(url) | ||
authenticator.update_auth_file() | ||
else: | ||
raise RuntimeError("No way to fetch auth.json") | ||
|
||
_warn_if_wide_permissions(auth_path) | ||
with open(auth_path, "r") as f: | ||
auth_data = json.load(f) | ||
headers.update(auth_data) | ||
return headers | ||
return auth_data | ||
|
||
|
||
if __name__ == "__main__": | ||
def main(): | ||
parser = argparse.ArgumentParser() | ||
parser.add_argument( | ||
"-a", | ||
"--auth", | ||
"-u", | ||
"--url", | ||
action="store", | ||
default="auth.json", | ||
help="file to store jwt token", | ||
default=constants.URL, | ||
help="URL of proof market API", | ||
) | ||
parser.add_argument( | ||
"-d", | ||
"--dir", | ||
action="store", | ||
default=constants.URL, | ||
help="Directory to store credentials and auth file", | ||
) | ||
args = parser.parse_args() | ||
|
||
update_auth(args.auth) | ||
Authenticator(args.url, args.dir).update_auth_path() | ||
logger.info(f"Auth file at {args.dir} updated") | ||
|
||
|
||
if __name__ == "__main__": | ||
main() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,8 +1,7 @@ | ||
import os | ||
|
||
VERSION = open(os.path.dirname(os.path.abspath(__file__)) + "/../VERSION", "r").read() | ||
URL = "https://api.proof.market.nil.foundation/" | ||
URL = "http://49.12.15.40:3000" | ||
DB_NAME = "market" | ||
MOUNT = "/v" + VERSION.replace(".", "_") | ||
AUTH_FILE = "./.auth.json" | ||
REQUEST_TIMEOUT = 100 |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.