diff --git a/content/docs/web/burp/00-whatisit.md b/content/docs/web/burp/00-whatisit.md
index cec260e4..c5ec6e8b 100644
--- a/content/docs/web/burp/00-whatisit.md
+++ b/content/docs/web/burp/00-whatisit.md
@@ -63,7 +63,7 @@ This handbook provides the answers: what you can precisely do to enhance the sec
We give you strategic ideas with links to the official documentation.
At this point in the Testing Handbook, we recommend that you do the following:
-* Reach out to free of charge [PortSwigger Web Security Academy](https://portswigger.net/web-security) to obtain
+* Reach out for free to [PortSwigger Web Security Academy](https://portswigger.net/web-security) to obtain
knowledge of web vulnerabilities.
* Go to the [PortSwigger website](https://portswigger.net/burp/pro) to request a trial or buy a license
(we mostly work on the paid Burp Suite Professional version).
diff --git a/content/docs/web/burp/stepbystep/02-workingmanually/01-repeater/_index.md b/content/docs/web/burp/stepbystep/02-workingmanually/01-repeater/_index.md
index 3e412492..5014bb15 100644
--- a/content/docs/web/burp/stepbystep/02-workingmanually/01-repeater/_index.md
+++ b/content/docs/web/burp/stepbystep/02-workingmanually/01-repeater/_index.md
@@ -127,12 +127,12 @@ It’s also possible to configure Burp Repeater. Specific options are crucial in
- [Client-side desync attacks](https://portswigger.net/web-security/request-smuggling/browser/client-side-desync)
- [HTTP request smuggling](https://portswigger.net/web-security/request-smuggling)
-There are two levels of Burp Repeater configuration - a global configuration that is applied to all Repeater tabs by default
+There are two levels of Burp Repeater configurations: a global configuration that is applied to all Burp Repeater tabs by default
(figure 5) and a local configuration for each individual tab (figure 6) that can override the global settings
if you need to do something different in that scenario.
{{< resourceFigure "repeater_options.png" >}}
-Possible options for the Repeater feature in Burp
+Possible options for the Burp Repeater feature
{{< / resourceFigure >}}
{{< resourceFigure "repeater_tab_options.png" >}}
diff --git a/content/docs/web/burp/stepbystep/02-workingmanually/02-intruder/_index.md b/content/docs/web/burp/stepbystep/02-workingmanually/02-intruder/_index.md
index 5f941c0f..dfc2dd34 100644
--- a/content/docs/web/burp/stepbystep/02-workingmanually/02-intruder/_index.md
+++ b/content/docs/web/burp/stepbystep/02-workingmanually/02-intruder/_index.md
@@ -45,7 +45,7 @@ Here are some scenarios:
wordlist could yield more fruitful results. For instance, the SecLists [big English wordlist](https://github.com/danielmiessler/SecLists/blob/master/Discovery/Web-Content/raft-large-words-lowercase.txt) is useful when looking for hidden
or undocumented POST, GET, or JSON parameters.
2. **Vulnerability-specific lists**. Some wordlists are designed to detect specific vulnerabilities.
-If you want to test for SQL injection, you would use a wordlist packed with SQL injection payloads.
+If you wanted to test for SQL injection, you would use a wordlist packed with SQL injection payloads.
Similarly, if you are looking for file or directory enumeration vulnerabilities, wordlists with common
file and directory names could help uncover them.
3. **Technology stack lists**. Depending on the application's underlying technology, some wordlists might be better suited
@@ -79,18 +79,18 @@ to attack in your HTTP request? Well, bugs can be anywhere, so choose placeholde
(e.g., path, middle of path, parameter, parameter name, header values, additional headers, etc.).
Your success depends on the target, the bugs you are looking for, the wordlists you use, your creativity, and your experience.
-Also, you can add payload markers (`§§`) to the target to parameterize the different URLs that the request is sent (figure 3).
+Additionally, you can add payload markers `§§` to the target to parameterize the different URLs that the request
+is sent to (figure 3).
{{< resourceFigure "target-payload-markers.png" >}}
-Adding payload markers in Burp Intruder to the target
+Adding payload markers to the target in Burp Intruder
{{< / resourceFigure >}}
{{< hint info >}}
You can use the [Auto feature](https://portswigger.net/burp/documentation/desktop/tools/intruder/configure-attack/positions#:~:text=Apply%20automatic%20payload%20markers%20%2D%20click%20Auto%20%C2%A7)
-in Burp Intruder to automatically place payload markers in common positions within the request, such as query parameters,
-body parameters, etc.
+in Burp Intruder to automatically place payload markers in common positions within the request,
+such as query parameters, body parameters, and so on.
{{< /hint >}}
-
## What to look for?
@@ -128,8 +128,8 @@ When using Taborator, interactions will be displayed in the **Taborator** tab in
## Various Burp Intruder tips
-1. [Create a specific resource pool](https://portswigger.net/burp/documentation/desktop/tools/intruder/configure-attack/resource-pool)
-for Intruder attacks so that the scanner and Intruder are not competing against each other for workers to issue the requests.
+1. [Create a specific resource pool](https://portswigger.net/burp/documentation/desktop/tools/intruder/configure-attack/resource-pool)
+for Burp Intruder attacks so that Burp Scanner and Burp Intruder are not competing against each other for workers to issue the requests.
2. By default, a Burp Intruder URL encodes specific characters within the final payload.
Consider running the attack twice—with enabled and disabled payload encoding. Refer to [Burp Intruder payload processing](https://portswigger.net/burp/documentation/desktop/tools/intruder/configure-attack/processing#:~:text=Configuring%20payload%20encoding)
@@ -151,9 +151,9 @@ and then choosing the specific payload setting, as shown in figure 4:
5. You can use the [Recursive grep](https://portswigger.net/burp/documentation/desktop/tools/intruder/configure-attack/payload-types#:~:text=WIENER%0APeter%20wiener-,Recursive%20grep,-This%20enables%20you)
payload type to extract text from the response to the previous request and use that text as the payload for the current request.
See the [NahamCon2023: Bug Bounty Village workshop](https://youtu.be/rM61brpBV48?t=9199) (starts at 2:33:19) for an example configuration.
-
-6. Always run attacks in temporary project mode (do not click [save attack in the attack configuration](https://portswigger.net/burp/documentation/desktop/tools/intruder/configure-attack/settings#:~:text=Intruder%20settings.-,Save%20attack,-Professional)),
-and then [save the attack to the project file](https://portswigger.net/burp/documentation/desktop/tools/intruder/results/saving-attacks)
+
+6. Always run attacks in temporary project mode (do *not* click [**Save attack to project file** in the attack configuration](https://portswigger.net/burp/documentation/desktop/tools/intruder/configure-attack/settings#:~:text=Intruder%20settings.-,Save%20attack,-Professional)),
+and then click [**Save the attack to the project file**](https://portswigger.net/burp/documentation/desktop/tools/intruder/results/saving-attacks)
if you want to preserve the results afterward.
7. [Intruder can automatically generate collaborator payloads](https://portswigger.net/burp/documentation/desktop/tools/intruder/configure-attack/payload-types#:~:text=processing%20rule.-,Collaborator%20payloads,-This%20generates%20and)
@@ -162,11 +162,9 @@ it will update the results with the interaction count and raise the issue in the
providing that the attack has not been deleted.
{{< resourceFigure "collabo-event-log.png" >}}
-An issue raised in the Event log upon a collaborator payload interaction
+An issue raised in the Event log upon a Burp Collaborator payload interaction
{{< / resourceFigure >}}
{{< resourceFigure "collabo-interaction-column.png" >}}
-The Interactions column in Burp Intruder attack upon a collaborator payload interaction
+The Interactions column in a Burp Intruder attack upon a Burp Collaborator payload interaction
{{< / resourceFigure >}}
-
-
\ No newline at end of file
diff --git a/content/docs/web/burp/stepbystep/_index.md b/content/docs/web/burp/stepbystep/_index.md
index 849753f0..00702d7f 100644
--- a/content/docs/web/burp/stepbystep/_index.md
+++ b/content/docs/web/burp/stepbystep/_index.md
@@ -62,7 +62,7 @@ Some extensions fall under the category of “turn on and forget.” They are mo
Burp Scanner task without user interaction, with results appearing in the **Issue activity** pane of the **Dashboard** tab.
We generally recommend the following extensions, which should apply to most web applications:
-1. [**ActiveScan++**](https://portswigger.net/bappstore/3123d5b5f25c4128894d97ea1acc4976) enhances the default active and
+1. [**Active Scan++**](https://portswigger.net/bappstore/3123d5b5f25c4128894d97ea1acc4976) enhances the default active and
passive scanning capabilities of Burp Suite.
It adds checks for vulnerabilities that the default Burp Scanner might miss.
2. [**Backslash Powered Scanner**](https://portswigger.net/bappstore/9cff8c55432a45808432e26dbb2b41d8) extends the active
@@ -82,8 +82,9 @@ Some of the above extensions need
configured in Burp.
{{< hint warning >}}
-Because of the performance impact of enabling too many extensions, you should only enable extensions that you are actively
-using. We encourage you to periodically review your currently enabled extensions and unload any that you don't currently use.
+Because of the performance impact of enabling too many extensions,
+you should enable only extensions that you are actively using.
+We encourage you to periodically review your enabled extensions and unload any that you don't currently use.
{{< /hint >}}
## First run with a live task
diff --git a/content/docs/web/burp/tips/_index.md b/content/docs/web/burp/tips/_index.md
index f487dce3..69da15f2 100644
--- a/content/docs/web/burp/tips/_index.md
+++ b/content/docs/web/burp/tips/_index.md
@@ -31,3 +31,435 @@ To conveniently detect race conditions, Burp allows you to group multiple reques
So you can prepare multiple requests in Burp Repeater, send them almost simultaneously, and observe the system's behavior.
To group multiple requests in Burp Repeater, click the **+** sign and select **Add tab**:
+{{< resourceFigure "repeater-add-tab.png" >}}
+Adding a tab in the **Repeater** tab
+{{< / resourceFigure >}}
+
+Then click on **Create new group** and select tabs (previously prepared requests) for the group:
+
+{{< resourceFigure "create-new-tab-group.png" >}}
+Creating new group of Burp Repeater tabs
+{{< / resourceFigure >}}
+
+Then select **Send group (parallel)**:
+
+{{< resourceFigure "send-in-parallel.png" >}}
+The options for the group send in Burp Repeater
+{{< / resourceFigure >}}
+
+Burp will then send all grouped requests using the following techniques based on the HTTP version of requests:
+
+- For HTTP/1 — last-byte technique
+- For HTTP/2 — single-packet attack
+
+You can find more information on specific attack types in the original research,
+[Smashing the state machine: the true potential of web race conditions](https://portswigger.net/research/smashing-the-state-machine).
+
+### Using Turbo Intruder to test for race conditions
+
+You can also send multiple instances of a request in parallel using Turbo Intruder. Select the specific
+request in Burp (e.g., from Burp Repeater), then right-click on the request
+and choose **Extensions** > **Turbo Intruder** > **Send to Turbo Intruder**. Then select the example script, `**examples/race-single-packet-attack.py**`:
+
+{{< resourceFigure "turbo-intruder.png" >}}
+The example `race-single-packet-attack.py` Turbo Intruder script
+{{< / resourceFigure >}}
+
+Next, following comments in the chosen script, adjust the engine (line 8) to the number of queued requests in line 14,
+click **Attack**, and observe the results.
+
+If you need to differentiate specific parameters in requests, you can do the following:
+
+1. Use Hackvertor tags in the request:
+ {{< resourceFigure "hackvertor-turbo-intruder.png" >}}
+ An example use of the Hackvertor tag in the requests in Turbo Intruder
+ {{< / resourceFigure >}}
+
+2. Use the `%s` injection point (e.g., iterator `i` of the `for` loop). To configure the injection point, put the `%s` placeholder
+in the request and edit the engine queue to include the iterator `i` as follows:
+
+ ```py
+ engine.queue(target.req, str(i), gate=’race1’):
+ ```
+
+ {{< resourceFigure "injection-pt-turbo-intruder.png" >}}
+ The example injection point configuration in Turbo Intruder
+ {{< / resourceFigure >}}
+
+ This way, wherever you place `%s`, it will be replaced with an iterative number in the request.
+
+### Using Backslash Powered Scanner for automated identification of potential race conditions
+
+To automatically probe for potential race conditions in your target, you must enable the Backslash Powered Scanner
+and run an active scan.
+
+The following is an example issue raised by the extension in the **Issues** tab:
+
+{{< resourceFigure "request-interference.png" >}}
+The example race condition issue raised by the Backslash Powered Scanner extension
+{{< / resourceFigure >}}
+
+## Testing for access control issues
+
+{{< hint info >}}
+You can learn about access control issues in [Access control vulnerabilities and privilege escalation](https://portswigger.net/web-security/access-control).
+{{< /hint >}}
+
+Access controls in web applications are typically defined by [user roles](https://en.wikipedia.org/wiki/Role-based_access_control).
+For example, there may be regular end-user accounts and
+administrator accounts. Each of these roles may have different access rights within the application. In this context, each role
+should be validated on the server side based on the authorization cookie or header.
+The [Autorize](https://portswigger.net/bappstore/f9bbac8c4acf4aefa4d7dc92a991af2f) extension is tailored to make testing access
+controls in web applications flexible and efficient.
+
+The general rule for using Autorize is to add the authorization cookie or headers of another application role to the extension,
+configure optional detectors, and browse the application. When you go through the application, requests are resent with modified
+parts (such as headers or cookies). We are essentially forging a different user role than what is expected.
+Autorize automatically modifies and resends intercepted requests with these substituted session identifiers.
+This allows us to investigate whether the server appropriately authorizes each incoming request, revealing any discrepancies in
+access controls, such as a regular user accessing administrative functions. Also, it’s possible to check out the unauthenticated
+perspective, where requests are sent without a specific header or cookie.
+
+The Autorize table displays the request URL and enforcement status:
+
+{{< resourceFigure "autorize.png" >}}
+The example Autorize configuration with the results table
+{{< / resourceFigure >}}
+
+The following are useful tips when using the Autorize extension:
+
+- Don’t forget to use the **Check Unauthenticated** functionality.
+- Narrow down the source of the request sent to Autorize by setting up interception filters. For example, include only scope items
+and ignore `OPTIONS` requests and other unnecessary requests from an authorization testing perspective.
+- Always adjust the **Enforcement Detector** and **Detector Unauthenticated** functionalities accordingly to avoid missing bugs.
+- Carefully review the results. Be aware of caveats. For example, some parameters in requests must be unique, so Autorize will not
+analyze authorization issues properly because the application can return an error due to that uniqueness. To solve this problem,
+you can use the Hackvertor extension in the original request sent to Autorize, and Autorize will process its tags.
+To use Hackvertor tags in Burp Proxy, enable them in the settings by selecting **Allow tags in Proxy**:
+
+{{< resourceFigure "allow-tags-in-proxy.png" >}}
+The possible settings for the Hackvertor extension in Burp
+{{< / resourceFigure >}}
+
+References:
+
+- [Autorize](https://github.com/PortSwigger/autorize): automatic authorization enforcement detection extension
+- [Finding “BAC - IDOR -PE” Within a Minute using Autorize Tool](https://medium.com/@Cyber_siva/finding-bac-idor-pe-within-a-minute-using-autorize-tool-5aad4f0b563f)
+- [Burp Suite tutorial: IDOR vulnerability automation using Autorize and AutoRepeater (bug bounty)](https://www.youtube.com/watch?v=3K1-a7dnA60)
+
+If the Autorize extension is not enough for your target, try using the [AutoRepeater](https://portswigger.net/bappstore/f89f2837c22c4ab4b772f31522647ed8)
+extension, which can automatically duplicate, modify, and resend any request. It also has many conditional replacement options.
+For more information, see the following resources:
+
+- [Burp Repeater - whether user permissions are working properly](https://security-szurek-pl.translate.goog/burp-autorepeater-czy-uprawnienia-dzialaja-prawidlowo/?_x_tr_sl=en&_x_tr_tl=pl&_x_tr_hl=en&_x_tr_pto=wapp)
+- [BSides Rochester 2018 - AutoRepeater: Automated HTTP Request Repeating With Burp Suite](https://www.youtube.com/watch?v=IYFLp_4ccrw)
+- [AutoRepeater: Automated HTTP Request Repeating With Burp Suite](https://github.com/nccgroup/AutoRepeater)
+
+## Run Collaborator Everywhere
+
+The Collaborator Everywhere extension adds noninvasive headers designed to reveal back-end systems by triggering pingbacks
+to Burp Collaborator. You can also detect potential IP spoofing when the web application returns the potentially real IP address
+based on the user-controlled header. However, the added headers may interfere with the normal functionality
+of the web application. So you don’t need to have the extension enabled all the time, but we recommend taking at least one shot
+in each corner of the application.
+
+The Collaborator Everywhere extension adds appropriate headers and a payload to the `User-Agent` header in the in-scope proxy traffic:
+
+{{< resourceFigure "collaborator-everywhere.png" >}}
+The example request processed by the Collaborator Everywhere extension
+{{< / resourceFigure >}}
+
+For more information on exploitation issues raised by Collaborator Everywhere, see [Cracking the lens: targeting HTTP's hidden attack-surface](https://portswigger.net/research/cracking-the-lens-targeting-https-hidden-attack-surface).
+
+## Responses can be intercepted/changed too
+
+Even though we generally intercept requests and modify them to obtain specific results in Burp, intercepting HTTP responses can
+be beneficial for the following reasons:
+
+1. To analyze how the content is rendered in a mobile application
+2. To remove/modify specific response headers (such as `Content-Security-Policy`)
+3. To modify the response:
+
+ a. [**Unhide hidden form fields**](https://portswigger.net/support/using-burp-to-bypass-hidden-form-fields)
+
+ b. **Enable disabled form fields**
+
+ c. **Remove input field length limits**
+
+For example, to remove the `Content-Security-Policy` header from the response, under the **Match and replace rules** header,
+select **Add**:
+
+{{< resourceFigure "match-and-replace-rules.png" >}}
+The Proxy settings in Burp that allow request and response modification
+{{< / resourceFigure >}}
+
+{{< resourceFigure "remove-csp.png" >}}
+The example match/replace rule that removes the CSP header from a response’s headers
+{{< / resourceFigure >}}
+
+Then, in HTTP history, you can see a tick in **Edited**.
+
+After selecting the request, choose the **Auto-modified response** to show that Burp removed the CSP header:
+
+{{< resourceFigure "auto-modified.png" >}}
+Showing the auto-modified response
+{{< / resourceFigure >}}
+
+Resources:
+
+- [Using Burp Suite match and replace settings to escalate your user privileges and find hidden features](https://www.jonbottarini.com/2019/06/17/using-burp-suite-match-and-replace-settings-to-escalate-your-user-privileges-and-find-hidden-features/)
+
+## Shutting down all tasks
+
+If you want to shut down all tasks (e.g., active Burp Scanner, Burp Intruder) in Burp, you generally can use this power button:
+
+{{< resourceFigure "pause-tasks.png" >}}
+Showing the auto-modified response
+{{< / resourceFigure >}}
+
+The button pauses all tasks but does not pause running extensions. So if you have a running extension issuing requests,
+they are still being sent. For example, when you use the Param Miner extension, you can see in Logger that when you
+pause task execution, requests are still being sent.
+
+If you want to pull the red emergency brake (i.e., pause all traffic), use the [Distribute Damage](https://portswigger.net/bappstore/543ab7a08d954390bd1a5f4253d3763b)
+extension and select **pause all traffic**:
+
+{{< resourceFigure "distributed-damage.png" >}}
+The configuration of the Distribute Damage extension that pauses all traffic
+{{< / resourceFigure >}}
+
+## BChecks
+
+The standard library of passive and active scan checks in Burp is extensive. Also, all the available extensions
+expand the library significantly. Nevertheless, what if you would like custom checks tailored to your organization or want
+to hunt for a specific bug not covered by Burp? The simple solution is BChecks.
+
+### What are BChecks?
+
+The official documentation states the following:
+
+> *BChecks are custom scan checks that you can create and import. Burp Scanner runs these checks in addition
+to its built-in scanning routine, helping you to target your scans and make your testing workflow as efficient as possible.*
+
+BChecks are written in a `.bcheck` file extension with a plaintext, custom definition language to declare the behavior of the check.
+For more information, see [BCheck examples](https://github.com/PortSwigger/BChecks).
+
+See the example, `suspicious-input-transformation.bcheck`. Taking a closer look at this BCheck file,
+we notice that this particular check is designed to identify suspicious input transformation that might suggest the application
+is vulnerable to some kind of server-side code injection, such as server-side template injection.
+
+Here is what’s happening in `suspicious-input-transformation.bcheck`:
+
+1. **metadata:** This section provides basic information about the BCheck.
+
+2. **define:** This section defines two variables. The calculation variable is set to a string representation
+of a mathematical calculation (`1337*1337`), and the answer variable is set to the result of that calculation (`1787569`).
+
+3. **given insertion point then:** This is the start of the BCheck’s main logic.
+
+4. **report issue:** This section describes the reported issue (severity, confidence, details, and remediation).
+
+{{< customFigure "The example `suspicious-input-transformation.bcheck` file" >}}
+
+```yaml
+metadata:
+ language: v1-beta
+ name: "Insertion-point-level"
+ description: "Inserts a calculation into each parameter to detect suspicious input transformation"
+ author: "Carlos Montoya"
+
+define:
+ calculation = "{{1337*1337}}"
+ answer = "1787569"
+
+# we will automatically insert into nested insertion points
+given insertion point then
+ # prevent false positives by checking answer isn't
+ # already in base response
+ if not({answer} in {base.response}) then
+ send payload:
+ appending: {calculation}
+
+ if {answer} in {latest.response} then
+ report issue:
+ severity: high
+ confidence: tentative
+ detail: "The application transforms input in a way that suggests it might be
+ vulnerable to some kind of server-side code injection."
+ remediation: "Manual investigation is advised."
+ end if
+ end if
+```
+
+{{< /customFigure >}}
+
+### Why BChecks?
+
+Crafting your extension to add custom checks is an option, but it's not a trivial process. It requires a significant amount
+of time and expertise in programming. BChecks, on the other hand, offers a simpler solution. It allows you to automate your
+passive and active hunts without extensive coding.
+
+For example, you can [automate the search with a regex](https://karol-mazurek.medium.com/appsec-tales-xxii-ldapi-fcef1f40e9b2#:~:text=You%20can%20automate%20the%20search%20with%20the%20regex%20using%20BChecks)
+to see if there is any information disclosing LDAP in use. This can be particularly useful if you're looking for potential
+application information disclosure. With BChecks, you can set up this check once and run it automatically in all future scans.
+
+### BChecks collection
+
+For more examples of what you can do with BChecks, check out the [official BChecks collection](https://github.com/PortSwigger/BChecks)
+for Burp Suite Professional. It can serve as a good starting point for creating your checks. You can learn from the examples
+and modify them to suit your needs.
+
+### BChecks for Organizations
+
+BChecks are not only personal but can also be applicable across an entire organization. You can distribute the BChecks
+(in the form of `*.bcheck` files) to team members, enabling everyone to look for the same bugs.
+
+## Filtering the HTTP history with Bambdas
+
+Bambda mode allows you to use small snippets of Java to customize your Burp tools. For example, the following [Bambda](https://github.com/PortSwigger/bambdas/blob/main/Filter/Proxy/HTTP/FindJSONresponsesWithIncorrectContentType.bambda)
+allows you to find JSON responses with the wrong `Content-Type` in the HTTP history.
+
+{{< resourceFigure "bambda.png" >}}
+The example Bambda in the HTTP history
+{{< / resourceFigure >}}
+
+See more Bambdas in the [Bambdas collection on GitHub](https://github.com/PortSwigger/bambdas)
+and read the documentation on [Filtering the HTTP history with Bambdas](https://portswigger.net/burp/documentation/desktop/tools/proxy/http-history/bambdas).
+
+## Custom Hackvertor tags
+
+The Hackvertor extension allows you to configure your own tags based on Python or JavaScript.
+
+See this example usage:
+
+{{< rawHtml "" >}}
+
+{{< /rawHtml >}}
+
+Also see the official Hackvertor tag store:
+
+{{< resourceFigure "hackvertor-store.png" >}}
+The Hackvertor tag store that is accessible from Burp’s top menu bar
+{{< / resourceFigure >}}
+
+## Leveraging Easy Auto Refresh Chrome extension with Burp
+
+Combine the [Easy Auto Refresh](https://chromewebstore.google.com/detail/easy-auto-refresh/aabcgdmkeabbnleenpncegpcngjpnjkc)
+Chrome extension with Burp for the easiest way to extend your session and prevent automatic logout. Just set the appropriate
+refresh time in the extension and proxy the traffic through Burp. The site should keep you logged in. If the cookies change,
+Burp’s cookie jar will automatically update the cookies in the appropriate requests issued by Burp Scanner.
+
+{{< resourceFigure "easy-auto-refresh.png" >}}
+The Easy Auto Refresh popup in Chrome browser
+{{< / resourceFigure >}}
+
+If the refresh action in the target site automatically goes through the entire authentication flow and obtains
+a new `Authorization: Bearer` token required by the target, you can install the Authorization Bearer Detector and Replacer
+custom extension (figure 22). This will avoid the situation where the authorization header expires and requests sent by Burp
+return a “401 Unauthorized” error. The extension reads the authorization header from traffic proxied by the browser and replaces
+it when the old header expires in requests sent by Burp.
+
+To make it work, install the extension (figure 23), edit the target hostname (line 20), and add a new session handling rule
+to enable the custom extension in Burp Scanner and Burp’s extensions. In Burp’s settings, go to the **Sessions** tab and add
+a new session handling rule. In **Rule actions**, select **Add** and **Invoke a Burp extension**, then select
+the **Replace Authorization Bearer Token** in the extension action handler. In the **Session handling rule editor** window,
+go to the **Scope** tab and select the **Scanner** and **Extensions** in the **Tools scope**.
+
+![session handling rule](session-handling-rule.png)
+{{< resourceFigure "session-handling-rule-scope.png" >}}
+The session handling rule configuration
+{{< / resourceFigure >}}
+
+{{< customFigure "A custom Burp extension to replace the `Authorization` header" >}}
+
+```python
+from burp import IBurpExtender, IProxyListener, IHttpRequestResponse, IExtensionHelpers, ISessionHandlingAction, IRequestInfo
+from java.util import ArrayList
+from java.net import URL
+
+class BurpExtender(IBurpExtender, IProxyListener, ISessionHandlingAction):
+ def registerExtenderCallbacks(self, callbacks):
+ self._callbacks = callbacks
+ self._helpers = callbacks.getHelpers()
+ callbacks.setExtensionName("Authorization Bearer Detector and Replacer")
+ callbacks.registerProxyListener(self)
+ callbacks.registerSessionHandlingAction(self)
+ self.previous_token = None
+ print("Authorization Bearer Detector and Replacer extension loaded.")
+
+ def processProxyMessage(self, messageIsRequest, message):
+ if messageIsRequest:
+ http_service = message.getMessageInfo().getHttpService()
+ url = URL(http_service.getProtocol(), http_service.getHost(), http_service.getPort(), "")
+ if url.toString().startswith("https://XX.com"):
+ request = message.getMessageInfo().getRequest()
+ headers = self._helpers.analyzeRequest(request).getHeaders()
+ for header in headers:
+ if header.startswith("Authorization: Bearer"):
+ token = header.split(" ")[2]
+ if self.previous_token != token:
+ print("New Authorization Bearer found in a request to " + url.toString() + ": " + token)
+ self.previous_token = token
+ self.replaceToken(message.getMessageInfo())
+
+ def replaceToken(self, messageInfo):
+ request = messageInfo.getRequest()
+ requestInfo = self._helpers.analyzeRequest(request)
+ headers = requestInfo.getHeaders()
+ newHeaders = []
+ for header in headers:
+ if header.startswith("Authorization: Bearer"):
+ newHeader = "Authorization: Bearer " + self.previous_token
+ newHeaders.append(newHeader)
+ else:
+ newHeaders.append(header)
+ newRequest = self._helpers.buildHttpMessage(newHeaders, request[requestInfo.getBodyOffset():])
+ messageInfo.setRequest(newRequest)
+
+ def getActionName(self):
+ return "Replace Authorization Bearer Token"
+
+ def performAction(self, currentRequest, macroItems):
+ self.replaceToken(currentRequest)
+ return None
+```
+
+{{< /customFigure >}}
+
+## Configuring an upstream proxy in Burp Suite
+
+### Proxy chaining
+
+Some web applications require traffic to be routed through a predefined proxy. In such scenarios, configuring our browser with the
+predefined proxy for the destination web server will prevent intercepting traffic with Burp Suite. To solve this issue, Burp Suite
+allows the configuration of an upstream proxy, enabling you to intercept traffic with Burp and forward it to the proxy used to
+access the web application.
+
+Upstream proxies are also useful when using several web application testing tools. For example, Burp Suite can be chained with
+[Zed Attack Proxy (ZAP)](https://www.zaproxy.org/) or a custom automation script built upon [mitmproxy](https://mitmproxy.org/).
+Chaining proxies allows us to leverage the strengths of each tool simultaneously during testing.
+
+### Configuration in Burp Suite
+
+To configure an upstream proxy, go to **Settings** > **Network** > **Connections** and scroll down to the
+**Upstream proxy servers** section. Click **Add** to configure a new upstream proxy. In the pop-up window, specify the destination
+host, the proxy host or IP address, and the proxy port. If the proxy requires authentication, further specify
+authentication-relevant information such as the authentication type, username, and password.
+
+### Proxying Burp through ZAP
+
+In the following example, Burp is proxied through ZAP. Burp listens on `localhost:8080`, while ZAP listens on `localhost:8081`.
+Burp is configured with ZAP as an upstream proxy. In the configuration below, traffic to all hosts is proxied to ZAP:
+
+{{< resourceFigure "upstream-proxy-rule.png" >}}
+The example configuration of the upstream proxy rule
+{{< / resourceFigure >}}
+
+In Burp Suite's built-in browser, opening `trailofbits.com` appears as follows:
+
+{{< resourceFigure "browser-with-hud.png" >}}
+Burp’s built-in browser showing the website that is also proxied through ZAP, with ZAP’s HUD added to the website
+{{< / resourceFigure >}}
+
+Note the new elements on the sides of the browser. ZAP injects these elements into the page to provide a heads-up display (HUD).
+Looking into Burp Suite's HTTP history, we also find the corresponding requests to `trailofbits.com`.
diff --git a/content/docs/web/burp/tips/allow-tags-in-proxy.png b/content/docs/web/burp/tips/allow-tags-in-proxy.png
new file mode 100644
index 00000000..59b27a44
Binary files /dev/null and b/content/docs/web/burp/tips/allow-tags-in-proxy.png differ
diff --git a/content/docs/web/burp/tips/auto-modified.png b/content/docs/web/burp/tips/auto-modified.png
new file mode 100644
index 00000000..c64d446d
Binary files /dev/null and b/content/docs/web/burp/tips/auto-modified.png differ
diff --git a/content/docs/web/burp/tips/autorize.png b/content/docs/web/burp/tips/autorize.png
new file mode 100644
index 00000000..598d5290
Binary files /dev/null and b/content/docs/web/burp/tips/autorize.png differ
diff --git a/content/docs/web/burp/tips/bambda.png b/content/docs/web/burp/tips/bambda.png
new file mode 100644
index 00000000..de3ffbbc
Binary files /dev/null and b/content/docs/web/burp/tips/bambda.png differ
diff --git a/content/docs/web/burp/tips/browser-with-hud.png b/content/docs/web/burp/tips/browser-with-hud.png
new file mode 100644
index 00000000..4d617cd3
Binary files /dev/null and b/content/docs/web/burp/tips/browser-with-hud.png differ
diff --git a/content/docs/web/burp/tips/collaborator-everywhere.png b/content/docs/web/burp/tips/collaborator-everywhere.png
new file mode 100644
index 00000000..56938d14
Binary files /dev/null and b/content/docs/web/burp/tips/collaborator-everywhere.png differ
diff --git a/content/docs/web/burp/tips/create-new-tab-group.png b/content/docs/web/burp/tips/create-new-tab-group.png
new file mode 100644
index 00000000..4342a6af
Binary files /dev/null and b/content/docs/web/burp/tips/create-new-tab-group.png differ
diff --git a/content/docs/web/burp/tips/distributed-damage.png b/content/docs/web/burp/tips/distributed-damage.png
new file mode 100644
index 00000000..0e4d2fa1
Binary files /dev/null and b/content/docs/web/burp/tips/distributed-damage.png differ
diff --git a/content/docs/web/burp/tips/easy-auto-refresh.png b/content/docs/web/burp/tips/easy-auto-refresh.png
new file mode 100644
index 00000000..380902e1
Binary files /dev/null and b/content/docs/web/burp/tips/easy-auto-refresh.png differ
diff --git a/content/docs/web/burp/tips/hackvertor-store.png b/content/docs/web/burp/tips/hackvertor-store.png
new file mode 100644
index 00000000..4f9e4b1e
Binary files /dev/null and b/content/docs/web/burp/tips/hackvertor-store.png differ
diff --git a/content/docs/web/burp/tips/hackvertor-turbo-intruder.png b/content/docs/web/burp/tips/hackvertor-turbo-intruder.png
new file mode 100644
index 00000000..b69a7779
Binary files /dev/null and b/content/docs/web/burp/tips/hackvertor-turbo-intruder.png differ
diff --git a/content/docs/web/burp/tips/injection-pt-turbo-intruder.png b/content/docs/web/burp/tips/injection-pt-turbo-intruder.png
new file mode 100644
index 00000000..60014a08
Binary files /dev/null and b/content/docs/web/burp/tips/injection-pt-turbo-intruder.png differ
diff --git a/content/docs/web/burp/tips/match-and-replace-rules.png b/content/docs/web/burp/tips/match-and-replace-rules.png
new file mode 100644
index 00000000..71004533
Binary files /dev/null and b/content/docs/web/burp/tips/match-and-replace-rules.png differ
diff --git a/content/docs/web/burp/tips/pause-tasks.png b/content/docs/web/burp/tips/pause-tasks.png
new file mode 100644
index 00000000..830517f1
Binary files /dev/null and b/content/docs/web/burp/tips/pause-tasks.png differ
diff --git a/content/docs/web/burp/tips/remove-csp.png b/content/docs/web/burp/tips/remove-csp.png
new file mode 100644
index 00000000..810b47bf
Binary files /dev/null and b/content/docs/web/burp/tips/remove-csp.png differ
diff --git a/content/docs/web/burp/tips/repeater-add-tab.png b/content/docs/web/burp/tips/repeater-add-tab.png
new file mode 100644
index 00000000..5d1b2b3a
Binary files /dev/null and b/content/docs/web/burp/tips/repeater-add-tab.png differ
diff --git a/content/docs/web/burp/tips/request-interference.png b/content/docs/web/burp/tips/request-interference.png
new file mode 100644
index 00000000..fd2e84c4
Binary files /dev/null and b/content/docs/web/burp/tips/request-interference.png differ
diff --git a/content/docs/web/burp/tips/send-in-parallel.png b/content/docs/web/burp/tips/send-in-parallel.png
new file mode 100644
index 00000000..598a98c6
Binary files /dev/null and b/content/docs/web/burp/tips/send-in-parallel.png differ
diff --git a/content/docs/web/burp/tips/session-handling-rule-scope.png b/content/docs/web/burp/tips/session-handling-rule-scope.png
new file mode 100644
index 00000000..771b4fe6
Binary files /dev/null and b/content/docs/web/burp/tips/session-handling-rule-scope.png differ
diff --git a/content/docs/web/burp/tips/session-handling-rule.png b/content/docs/web/burp/tips/session-handling-rule.png
new file mode 100644
index 00000000..1cb5417c
Binary files /dev/null and b/content/docs/web/burp/tips/session-handling-rule.png differ
diff --git a/content/docs/web/burp/tips/turbo-intruder.png b/content/docs/web/burp/tips/turbo-intruder.png
new file mode 100644
index 00000000..6174dbad
Binary files /dev/null and b/content/docs/web/burp/tips/turbo-intruder.png differ
diff --git a/content/docs/web/burp/tips/upstream-proxy-rule.png b/content/docs/web/burp/tips/upstream-proxy-rule.png
new file mode 100644
index 00000000..3c5b52bc
Binary files /dev/null and b/content/docs/web/burp/tips/upstream-proxy-rule.png differ