mirror of
https://github.com/mukul975/Anthropic-Cybersecurity-Skills.git
synced 2026-06-13 06:34:57 +03:00
c47eed6a64
- Fix 25 shell=True subprocess calls with list-based commands - Fix 49 verify=False in defensive skills (env-var override) - Add timeout to 231 HTTP/subprocess/socket calls - Fix 6 SQL injection patterns with whitelist validation - Replace 8 __import__() with standard imports - Remove 701 unused imports across 442 files - Add authorized-testing disclaimers to all offensive skills - Complete 11 incomplete skill directories - Expand 10 stub SKILL.md files with full content - Fix 2 YAML parse errors in frontmatter - Fix 5 pre-existing syntax errors - Convert 22 hardcoded paths/ports to environment variables - Back up 21 redundant skill pairs to .bak - Fix 2 global declaration errors - 724/724 skills with full folder anatomy (SKILL.md + agent.py + api-reference.md + LICENSE) - 0 compile errors across all 724 agent.py files
4.5 KiB
4.5 KiB
API Reference: CyberArk Privileged Access Management
Libraries Used
| Library | Purpose |
|---|---|
requests |
HTTP client for CyberArk PVWA REST API |
json |
Parse CyberArk JSON responses |
os |
Read environment variables for credentials |
urllib.parse |
URL-encode safe and account query parameters |
Installation
pip install requests
Authentication
CyberArk PVWA REST API requires session token authentication:
import requests
import os
PVWA_URL = os.environ.get("CYBERARK_URL", "https://pvwa.example.com")
# CyberArk credential authentication
resp = requests.post(
f"{PVWA_URL}/PasswordVault/api/auth/cyberark/logon",
json={
"username": os.environ["CYBERARK_USER"],
"password": os.environ["CYBERARK_PASS"],
},
timeout=30,
verify=True,
)
session_token = resp.json() # Returns session token string
headers = {"Authorization": session_token}
LDAP Authentication
resp = requests.post(
f"{PVWA_URL}/PasswordVault/api/auth/ldap/logon",
json={"username": user, "password": password},
timeout=30,
verify=True,
)
RADIUS Authentication
resp = requests.post(
f"{PVWA_URL}/PasswordVault/api/auth/radius/logon",
json={"username": user, "password": otp_code},
timeout=30,
verify=True,
)
REST API Endpoints
| Method | Endpoint | Description |
|---|---|---|
| POST | /api/auth/{method}/logon |
Authenticate (cyberark, ldap, radius) |
| POST | /api/auth/logoff |
End session |
| GET | /api/Accounts |
List privileged accounts |
| GET | /api/Accounts/{id} |
Get account details |
| POST | /api/Accounts |
Add a new privileged account |
| PATCH | /api/Accounts/{id} |
Update account properties |
| DELETE | /api/Accounts/{id} |
Delete an account |
| POST | /api/Accounts/{id}/Password/Retrieve |
Retrieve account password |
| POST | /api/Accounts/{id}/Change |
Trigger password change |
| POST | /api/Accounts/{id}/Reconcile |
Reconcile password |
| POST | /api/Accounts/{id}/Verify |
Verify password on target |
| GET | /api/Safes |
List safes |
| GET | /api/Safes/{name} |
Get safe details |
| POST | /api/Safes |
Create a safe |
| GET | /api/Safes/{name}/Members |
List safe members |
| POST | /api/Safes/{name}/Members |
Add safe member |
| GET | /api/Platforms |
List platforms |
| GET | /api/ComponentsMonitoringDetails/{component} |
System health |
Core Operations
List Privileged Accounts
resp = requests.get(
f"{PVWA_URL}/PasswordVault/api/Accounts",
headers=headers,
params={"search": "Linux", "limit": 100},
timeout=30,
verify=True,
)
accounts = resp.json()
for acct in accounts.get("value", []):
print(f"{acct['name']} — platform: {acct['platformId']}, safe: {acct['safeName']}")
Retrieve a Password (Check-Out)
resp = requests.post(
f"{PVWA_URL}/PasswordVault/api/Accounts/{account_id}/Password/Retrieve",
headers=headers,
json={"reason": "Automated security audit"},
timeout=30,
verify=True,
)
password = resp.text # Returns the password as plain text
List Safes and Audit Permissions
resp = requests.get(
f"{PVWA_URL}/PasswordVault/api/Safes",
headers=headers,
params={"limit": 200},
timeout=30,
verify=True,
)
for safe in resp.json().get("value", []):
members_resp = requests.get(
f"{PVWA_URL}/PasswordVault/api/Safes/{safe['safeName']}/Members",
headers=headers,
timeout=30,
verify=True,
)
members = members_resp.json().get("value", [])
print(f"Safe: {safe['safeName']} — {len(members)} members")
Trigger Password Rotation
resp = requests.post(
f"{PVWA_URL}/PasswordVault/api/Accounts/{account_id}/Change",
headers=headers,
json={"ChangeEntireGroup": False},
timeout=60,
verify=True,
)
Logoff
requests.post(
f"{PVWA_URL}/PasswordVault/api/auth/logoff",
headers=headers,
timeout=10,
verify=True,
)
Output Format
{
"value": [
{
"id": "42_8",
"name": "root-linux-prod01",
"address": "10.0.1.50",
"userName": "root",
"platformId": "UnixSSH",
"safeName": "LinuxRoot",
"secretType": "password",
"platformAccountProperties": {
"LogonDomain": "",
"Port": "22"
},
"secretManagement": {
"automaticManagementEnabled": true,
"lastModifiedTime": 1705334400
}
}
],
"count": 1
}