mirror of
https://github.com/not-lucky/GeminiKeyManagement.git
synced 2025-12-06 08:44:01 +05:30
116 lines
4.0 KiB
Python
116 lines
4.0 KiB
Python
import os
|
|
import google.auth
|
|
from google.oauth2.credentials import Credentials
|
|
from google_auth_oauthlib.flow import InstalledAppFlow
|
|
from google.cloud import resourcemanager_v3, service_usage_v1, api_keys_v2
|
|
from google.api_core import exceptions as google_exceptions
|
|
from google.oauth2 import id_token
|
|
from google.auth.transport import requests
|
|
|
|
# --- CONFIGURATION ---
|
|
EMAILS = [
|
|
"aetheriumglimmer"
|
|
]
|
|
CREDENTIALS_DIR = "credentials"
|
|
# ---------------------
|
|
|
|
SCOPES = [
|
|
"https://www.googleapis.com/auth/cloud-platform",
|
|
"https://www.googleapis.com/auth/userinfo.email",
|
|
"openid"
|
|
]
|
|
|
|
def main():
|
|
if not os.path.exists(CREDENTIALS_DIR):
|
|
os.makedirs(CREDENTIALS_DIR)
|
|
|
|
for email in EMAILS:
|
|
print(f"--- Processing account: {email} ---")
|
|
creds = get_credentials_for_email(email)
|
|
if not creds:
|
|
continue
|
|
|
|
try:
|
|
resource_manager = resourcemanager_v3.ProjectsClient(credentials=creds)
|
|
projects = resource_manager.search_projects()
|
|
|
|
print("Processing projects...")
|
|
for project in projects:
|
|
project_id = project.project_id
|
|
print(f"- {project_id}")
|
|
enable_api(project_id, creds)
|
|
key = create_api_key(project_id, creds)
|
|
if key:
|
|
save_api_key(email, key.key_string)
|
|
|
|
except google_exceptions.GoogleAPICallError as err:
|
|
print(f"An error occurred while processing account {email}: {err}")
|
|
|
|
def get_credentials_for_email(email):
|
|
token_file = os.path.join(CREDENTIALS_DIR, f"{email}.json")
|
|
creds = None
|
|
if os.path.exists(token_file):
|
|
creds = Credentials.from_authorized_user_file(token_file, SCOPES)
|
|
|
|
if not creds or not creds.valid:
|
|
if creds and creds.expired and creds.refresh_token:
|
|
creds.refresh(google.auth.transport.requests.Request())
|
|
else:
|
|
print(f"Please authenticate with: {email}")
|
|
flow = InstalledAppFlow.from_client_secrets_file(
|
|
"credentials.json", SCOPES
|
|
)
|
|
creds = flow.run_local_server(port=0)
|
|
with open(token_file, "w") as token:
|
|
token.write(creds.to_json())
|
|
return creds
|
|
|
|
def get_user_email(credentials):
|
|
try:
|
|
request = requests.Request()
|
|
id_info = id_token.verify_oauth2_token(
|
|
credentials.id_token, request, clock_skew_in_seconds=3
|
|
)
|
|
return id_info["email"]
|
|
except ValueError as err:
|
|
print(f"Error getting user email: {err}")
|
|
return None
|
|
|
|
def enable_api(project_id, credentials):
|
|
try:
|
|
service_usage_client = service_usage_v1.ServiceUsageClient(credentials=credentials)
|
|
service_name = "generativelanguage.googleapis.com"
|
|
request = service_usage_v1.EnableServiceRequest(
|
|
name=f"projects/{project_id}/services/{service_name}"
|
|
)
|
|
operation = service_usage_client.enable_service(request=request)
|
|
operation.result() # Wait for the operation to complete
|
|
print(f"Enabled Generative Language API for project {project_id}")
|
|
except google_exceptions.GoogleAPICallError as err:
|
|
print(f"Error enabling API for project {project_id}: {err}")
|
|
|
|
def create_api_key(project_id, credentials):
|
|
try:
|
|
api_keys_client = api_keys_v2.ApiKeysClient(credentials=credentials)
|
|
key = api_keys_v2.Key(
|
|
display_name="Gemini API Key"
|
|
)
|
|
request = api_keys_v2.CreateKeyRequest(
|
|
parent=f"projects/{project_id}/locations/global",
|
|
key=key,
|
|
)
|
|
operation = api_keys_client.create_key(request=request)
|
|
result = operation.result() # Wait for the operation to complete
|
|
print(f"Created API key for project {project_id}")
|
|
return result
|
|
except google_exceptions.GoogleAPICallError as err:
|
|
print(f"Error creating API key for project {project_id}: {err}")
|
|
return None
|
|
|
|
def save_api_key(email, api_key):
|
|
with open(f"{email}.key", "a") as f:
|
|
f.write(f"{api_key}\n")
|
|
|
|
if __name__ == "__main__":
|
|
main()
|