\n\n
This is the first of a series of Audit-related articles I'll be posting over the next few months. The goal is to discuss how to use existing systems and augment existing processes to track better, report on, and improve the security of your applications. The articles may touch various F5 technologies, or they may wander to adjacent technologies that I see our customers use. I invite you to comment below on my articles, add your own ideas or things you've done… maybe even contribute an article or two.
\n
This article deals with a problem that is all too common … how do I audit my SecOps tools? In a future article, we'll address config drift … that's another one that comes up all the time. In another article, we'll talk about what reports are useful for your day-to-day operations and what helps steer and inform your management.
\n
Let's start with a little story…
\n\n
You get the calendar invite for the \"Annual Security Audit,\" and the panic starts.
\n
What are they going to ask this year?
\n
How do I even know what I've done this year half of my year was panicked changes. What did we even do for Log4Shell?
\n
The other half was planning for changes that never happened.
\n
If there was only a way that we could report the things that have happened.
\n
I feel the pain here… \"looking back\" is nearly impossible in today's business world. The speed of change and the number of things we all are responsible for are increasing while the amount of time we have for those items is inversely proportional and decreasing steadily.
\n
The key to managing these reports is to create a way to see the changes in 'real-time' and then use the tools at hand to surface them when you need to see them.
\n
I got this question from a FinTech customer earlier this year.
\n
They wanted to show their auditors how their security policy is maintained throughout the year. They want to make sure that if there is a change, they are notified of the change so they can track those changes.
\n
This customer uses F5 BIG-IP Advanced WAF, which provides a mechanism to track any changes to the configuration. This information is stored in a database and is available for querying through the Management API. So, we set about to build a process that would allow them to query these changes and then output a log of them.
\n
I thought BIG-IP’s iControlREST API would be the way to get this information. Whenever a change is made to a Security Policy, there is an Audit record created. This record includes the date/time of the change but also what was changed, who did the change, and info about the entities in the policy impacted. You can learn more here: K42009442: Exporting ASM Policy audit logs manually
\n\n
My Postman calls started by getting an Auth Token from the BIG-IP:
\n
curl --location --request POST 'https://management-ip/mgmt/shared/authn/login' \\
--header 'Content-Type: application/json' \\
--data-raw '{
\"username\": \"admin\",
\"password\": \"myPW\",
\"loginProviderName\": \"tmos\"
}'
\n
Then I want to get the PolicyID using my Policy Name:
\n
curl --location --request GET 'https://management-ip/mgmt/tm/asm/policies?$filter=name eq scheff-working' \\
--header 'Content-type: application/json' \\
--header 'X-F5-Auth-Token;'
\n
Note that the filter uses an 'eq' so it should return only one item.
\n
Next, we request the audit logs for this policy-id:
\n
curl --location --request GET 'https://management-ip/mgmt/tm/asm/policies/h-lJz2aGTVbmbwcbU-DBCQ/audit-logs/' \\
--header 'Content-type: application/json' \\
--header 'X-F5-Auth-Token;'
\n
The returned data is an array of entry 'items'
\n
{
\"eventType\": \"update\",
\"lastUpdateMicros\": 1.676116936e+15,
\"description\": \"\",
\"deviceName\": \"/Common/ip-10-0-0-200.us-west-2.compute.internal\",
\"username\": \"\",
\"kind\": \"tm:asm:policies:audit-logs:audit-logstate\",
\"selfLink\": \"https://localhost/mgmt/tm/asm/policies/9qaSOCw0_eJtcHc-KbTpdg/audit-logs/h-lJz2aGTVbmbwcbU-DBCQ?ver=17.0.0\",
\"component\": \"SYSTEM\",
\"entityName\": \"Apply Policy\",
\"versionEvent\": false,
\"id\": \"h-lJz2aGTVbmbwcbU-DBCQ\"
}
\n
You can get a LOT of them. This is a list of the change items, tho you still need to iterate through each item and get the 'item details'. So, Python can make this all work seamlessly...
\n\n
Admittedly, writing this really was not a great effort, less than an hour in Postman and I was able to pull the information together. I took the basics from the Postman collection and used that to create a Python script.
\n
The Python script takes the management IP, username, password, and an optional Policy Name as parameters and then it gets an Authorization Token, gets the Policy-ID, and then iterates through the list of Audit Log Items for the details. There are a LOT of calls, but the information it gathers is very helpful and provides the details the customer needs for their Auditors.
\n
python policyauditdetails.py -h localhost -u admin -p MyP@assW3ird --name '?$filter=name eq aws-honeypot'
*********
Policy: aws-honeypot
Policy change info (update):
Change Detail:Parent Policy was set to empty value.
Type was set to Security.
Encoding Selected was set to true.
Application Language was set to utf-8.
Case Sensitivity was set to Case Sensitive.
Security Policy Description was set to Comprehensive Policy.
Template was set to POLICY_TEMPLATE_COMPREHENSIVE.
GUI Configuration Level was set to basic.
Active was set to true.
Differentiate between HTTP and HTTPS URLs was set to Protocol Specific.
Has Parent was set to false.
Policy Name was set to /Common/aws-honeypot.
Passive Mode was set to disabled.
Enforcement Mode was set to Blocking.
On: 2023-01-04 08:56:59
\n
I have posted this code up on Github, you can see it here: https://github.com/pmscheffler/policyAuditor If you have questions or ways to improve on it, please open an issue there. I look forward to seeing your ideas.
\n
My next article is a collaboration with another F5er, we’re going to show you some other cool reporting you can do to understand your Policy effectiveness against today’s common attacks.
\n
Please feel free to comment on this or other auditing ideas you have... maybe we can collaborate on a future article on how you solved your needs.
\n
","body@stringLength":"7181","rawBody":"\n
First in a series ... hopefully
\n
This is the first of a series of Audit-related articles I'll be posting over the next few months. The goal is to discuss how to use existing systems and augment existing processes to track better, report on, and improve the security of your applications. The articles may touch various F5 technologies, or they may wander to adjacent technologies that I see our customers use. I invite you to comment below on my articles, add your own ideas or things you've done… maybe even contribute an article or two.
\n
This article deals with a problem that is all too common … how do I audit my SecOps tools? In a future article, we'll address config drift … that's another one that comes up all the time. In another article, we'll talk about what reports are useful for your day-to-day operations and what helps steer and inform your management.
\n
Let's start with a little story…
\n
Panic at the SecOps
\n
You get the calendar invite for the \"Annual Security Audit,\" and the panic starts.
\n
What are they going to ask this year?
\n
How do I even know what I've done this year half of my year was panicked changes. What did we even do for Log4Shell?
\n
The other half was planning for changes that never happened.
\n
If there was only a way that we could report the things that have happened.
\n
I feel the pain here… \"looking back\" is nearly impossible in today's business world. The speed of change and the number of things we all are responsible for are increasing while the amount of time we have for those items is inversely proportional and decreasing steadily.
\n
The key to managing these reports is to create a way to see the changes in 'real-time' and then use the tools at hand to surface them when you need to see them.
\n
I got this question from a FinTech customer earlier this year.
\n
They wanted to show their auditors how their security policy is maintained throughout the year. They want to make sure that if there is a change, they are notified of the change so they can track those changes.
\n
This customer uses F5 BIG-IP Advanced WAF, which provides a mechanism to track any changes to the configuration. This information is stored in a database and is available for querying through the Management API. So, we set about to build a process that would allow them to query these changes and then output a log of them.
\n
I thought BIG-IP’s iControlREST API would be the way to get this information. Whenever a change is made to a Security Policy, there is an Audit record created. This record includes the date/time of the change but also what was changed, who did the change, and info about the entities in the policy impacted. You can learn more here: K42009442: Exporting ASM Policy audit logs manually
\n
Hey there, Mr Postman
\n
My Postman calls started by getting an Auth Token from the BIG-IP:
\n
curl --location --request POST 'https://management-ip/mgmt/shared/authn/login' \\
--header 'Content-Type: application/json' \\
--data-raw '{
\"username\": \"admin\",
\"password\": \"myPW\",
\"loginProviderName\": \"tmos\"
}'
\n
Then I want to get the PolicyID using my Policy Name:
\n
curl --location --request GET 'https://management-ip/mgmt/tm/asm/policies?$filter=name eq scheff-working' \\
--header 'Content-type: application/json' \\
--header 'X-F5-Auth-Token;'
\n
Note that the filter uses an 'eq' so it should return only one item.
\n
Next, we request the audit logs for this policy-id:
\n
curl --location --request GET 'https://management-ip/mgmt/tm/asm/policies/h-lJz2aGTVbmbwcbU-DBCQ/audit-logs/' \\
--header 'Content-type: application/json' \\
--header 'X-F5-Auth-Token;'
\n
The returned data is an array of entry 'items'
\n
{
\"eventType\": \"update\",
\"lastUpdateMicros\": 1.676116936e+15,
\"description\": \"\",
\"deviceName\": \"/Common/ip-10-0-0-200.us-west-2.compute.internal\",
\"username\": \"\",
\"kind\": \"tm:asm:policies:audit-logs:audit-logstate\",
\"selfLink\": \"https://localhost/mgmt/tm/asm/policies/9qaSOCw0_eJtcHc-KbTpdg/audit-logs/h-lJz2aGTVbmbwcbU-DBCQ?ver=17.0.0\",
\"component\": \"SYSTEM\",
\"entityName\": \"Apply Policy\",
\"versionEvent\": false,
\"id\": \"h-lJz2aGTVbmbwcbU-DBCQ\"
}
\n
You can get a LOT of them. This is a list of the change items, tho you still need to iterate through each item and get the 'item details'. So, Python can make this all work seamlessly...
\n
Enter Python
\n
Admittedly, writing this really was not a great effort, less than an hour in Postman and I was able to pull the information together. I took the basics from the Postman collection and used that to create a Python script.
\n
The Python script takes the management IP, username, password, and an optional Policy Name as parameters and then it gets an Authorization Token, gets the Policy-ID, and then iterates through the list of Audit Log Items for the details. There are a LOT of calls, but the information it gathers is very helpful and provides the details the customer needs for their Auditors.
\n
python policyauditdetails.py -h localhost -u admin -p MyP@assW3ird --name '?$filter=name eq aws-honeypot'
*********
Policy: aws-honeypot
Policy change info (update):
Change Detail:Parent Policy was set to empty value.
Type was set to Security.
Encoding Selected was set to true.
Application Language was set to utf-8.
Case Sensitivity was set to Case Sensitive.
Security Policy Description was set to Comprehensive Policy.
Template was set to POLICY_TEMPLATE_COMPREHENSIVE.
GUI Configuration Level was set to basic.
Active was set to true.
Differentiate between HTTP and HTTPS URLs was set to Protocol Specific.
Has Parent was set to false.
Policy Name was set to /Common/aws-honeypot.
Passive Mode was set to disabled.
Enforcement Mode was set to Blocking.
On: 2023-01-04 08:56:59
\n
I have posted this code up on Github, you can see it here: https://github.com/pmscheffler/policyAuditor If you have questions or ways to improve on it, please open an issue there. I look forward to seeing your ideas.
\n
My next article is a collaboration with another F5er, we’re going to show you some other cool reporting you can do to understand your Policy effectiveness against today’s common attacks.
\n
Please feel free to comment on this or other auditing ideas you have... maybe we can collaborate on a future article on how you solved your needs.
\n
","kudosSumWeight":1,"postTime":"2024-03-19T11:23:04.571-07:00","images":{"__typename":"AssociatedImageConnection","edges":[{"__typename":"AssociatedImageEdge","cursor":"MjQuMTF8Mi4xfG98MjV8X05WX3wx","node":{"__ref":"AssociatedImage:{\"url\":\"https://community.f5.com/t5/s/zihoc95639/images/bS0zMTAzODYtRE1SNGFO?revision=7\"}"}}],"totalCount":1,"pageInfo":{"__typename":"PageInfo","hasNextPage":false,"endCursor":null,"hasPreviousPage":false,"startCursor":null}},"attachments":{"__typename":"AttachmentConnection","pageInfo":{"__typename":"PageInfo","hasNextPage":false,"endCursor":null,"hasPreviousPage":false,"startCursor":null},"edges":[]},"tags":{"__typename":"TagConnection","pageInfo":{"__typename":"PageInfo","hasNextPage":false,"endCursor":null,"hasPreviousPage":false,"startCursor":null},"edges":[{"__typename":"TagEdge","cursor":"MjQuMTF8Mi4xfG98MTB8X05WX3wx","node":{"__typename":"Tag","id":"tag:application delivery","text":"application delivery","time":"2021-06-30T01:48:44.000-07:00","lastActivityTime":null,"messagesCount":null,"followersCount":null}},{"__typename":"TagEdge","cursor":"MjQuMTF8Mi4xfG98MTB8X05WX3wy","node":{"__typename":"Tag","id":"tag:BIG-IP Advanced WAF","text":"BIG-IP Advanced WAF","time":"2024-03-11T12:43:54.902-07:00","lastActivityTime":null,"messagesCount":null,"followersCount":null}},{"__typename":"TagEdge","cursor":"MjQuMTF8Mi4xfG98MTB8X05WX3wz","node":{"__typename":"Tag","id":"tag:devops","text":"devops","time":"2011-10-19T17:50:55.000-07:00","lastActivityTime":null,"messagesCount":null,"followersCount":null}},{"__typename":"TagEdge","cursor":"MjQuMTF8Mi4xfG98MTB8X05WX3w0","node":{"__typename":"Tag","id":"tag:security","text":"security","time":"2009-07-03T08:19:36.000-07:00","lastActivityTime":null,"messagesCount":null,"followersCount":null}}]},"timeToRead":5,"rawTeaser":"