## List Page Shield scripts `page_shield.scripts.list(ScriptListParams**kwargs) -> SyncSinglePage[Script]` **get** `/zones/{zone_id}/page_shield/scripts` Lists all scripts detected by Page Shield. ### Parameters - `zone_id: str` Identifier - `direction: Optional[Literal["asc", "desc"]]` The direction used to sort returned scripts. - `"asc"` - `"desc"` - `exclude_cdn_cgi: Optional[bool]` When true, excludes scripts seen in a `/cdn-cgi` path from the returned scripts. The default value is true. - `exclude_duplicates: Optional[bool]` When true, excludes duplicate scripts. We consider a script duplicate of another if their javascript content matches and they share the same url host and zone hostname. In such case, we return the most recent script for the URL host and zone hostname combination. - `exclude_urls: Optional[str]` Excludes scripts whose URL contains one of the URL-encoded URLs separated by commas. - `export: Optional[Literal["csv"]]` Export the list of scripts as a file, limited to 50000 entries. - `"csv"` - `hosts: Optional[str]` Includes scripts that match one or more URL-encoded hostnames separated by commas. Wildcards are supported at the start and end of each hostname to support starts with, ends with and contains. If no wildcards are used, results will be filtered by exact match - `order_by: Optional[Literal["first_seen_at", "last_seen_at"]]` The field used to sort returned scripts. - `"first_seen_at"` - `"last_seen_at"` - `page: Optional[str]` The current page number of the paginated results. We additionally support a special value "all". When "all" is used, the API will return all the scripts with the applied filters in a single page. This feature is best-effort and it may only work for zones with a low number of scripts - `page_url: Optional[str]` Includes scripts that match one or more page URLs (separated by commas) where they were last seen Wildcards are supported at the start and end of each page URL to support starts with, ends with and contains. If no wildcards are used, results will be filtered by exact match - `per_page: Optional[float]` The number of results per page. - `prioritize_malicious: Optional[bool]` When true, malicious scripts appear first in the returned scripts. - `status: Optional[str]` Filters the returned scripts using a comma-separated list of scripts statuses. Accepted values: `active`, `infrequent`, and `inactive`. The default value is `active`. - `urls: Optional[str]` Includes scripts whose URL contain one or more URL-encoded URLs separated by commas. ### Returns - `class Script: …` - `id: str` Identifier - `added_at: datetime` - `first_seen_at: datetime` - `host: str` - `last_seen_at: datetime` - `url: str` - `url_contains_cdn_cgi_path: bool` - `cryptomining_score: Optional[int]` The cryptomining score of the JavaScript content. - `dataflow_score: Optional[int]` The dataflow score of the JavaScript content. This field has been deprecated in favour of js_integrity_score. - `domain_reported_malicious: Optional[bool]` - `fetched_at: Optional[str]` The timestamp of when the script was last fetched. - `first_page_url: Optional[str]` - `hash: Optional[str]` The computed hash of the analyzed script. - `js_integrity_score: Optional[int]` The integrity score of the JavaScript content. - `magecart_score: Optional[int]` The magecart score of the JavaScript content. - `malicious_domain_categories: Optional[List[str]]` - `malicious_url_categories: Optional[List[str]]` - `malware_score: Optional[int]` The malware score of the JavaScript content. - `obfuscation_score: Optional[int]` The obfuscation score of the JavaScript content. This field has been deprecated in favour of js_integrity_score. - `page_urls: Optional[List[str]]` - `url_reported_malicious: Optional[bool]` ### Example ```python import os from cloudflare import Cloudflare client = Cloudflare( api_email=os.environ.get("CLOUDFLARE_EMAIL"), # This is the default and can be omitted api_key=os.environ.get("CLOUDFLARE_API_KEY"), # This is the default and can be omitted ) page = client.page_shield.scripts.list( zone_id="023e105f4ecef8ad9ca31a8372d0c353", ) page = page.result[0] print(page.id) ``` #### Response ```json { "result": [ { "id": "023e105f4ecef8ad9ca31a8372d0c353", "added_at": "2021-08-18T10:51:10.09615Z", "first_seen_at": "2021-08-18T10:51:08Z", "host": "blog.cloudflare.com", "last_seen_at": "2021-09-02T09:57:54Z", "url": "https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.6.0/js/bootstrap.min.js", "url_contains_cdn_cgi_path": false, "cryptomining_score": 1, "dataflow_score": 1, "domain_reported_malicious": false, "fetched_at": "fetched_at", "first_page_url": "blog.cloudflare.com/page", "hash": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx", "js_integrity_score": 1, "magecart_score": 1, "malicious_domain_categories": [ "Malware" ], "malicious_url_categories": [ "Malware" ], "malware_score": 1, "obfuscation_score": 1, "page_urls": [ "blog.cloudflare.com/page1", "blog.cloudflare.com/page2" ], "url_reported_malicious": false } ], "result_info": { "count": 1, "page": 1, "per_page": 20, "total_count": 2000, "total_pages": 100 }, "success": true, "errors": [ { "code": 1000, "message": "message", "documentation_url": "documentation_url", "source": { "pointer": "pointer" } } ], "messages": [ { "code": 1000, "message": "message", "documentation_url": "documentation_url", "source": { "pointer": "pointer" } } ] } ```