Skip to content

Commit

Permalink
Merge branch 'main' into one-step-protect
Browse files Browse the repository at this point in the history
  • Loading branch information
odysseus0 authored Dec 4, 2023
2 parents 655584e + 71f3ccf commit cb29458
Show file tree
Hide file tree
Showing 13 changed files with 292 additions and 7 deletions.
4 changes: 2 additions & 2 deletions docs/flashbots-auction/advanced/rpc-endpoint.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -295,7 +295,7 @@ This method has the following JSON-RPC format:
tx, // String, raw signed transaction
maxBlockNumber, // Hex-encoded number string, optional. Highest block number in which the transaction should be included.
preferences?: {
fast: boolean, // Deprecated; required until this is removed from the API. Value has no effect.
fast: boolean, // Sends transactions to all registered block builders, sets MEV-Share revenue share to 50%
privacy?: { // MEV-Share options; optional
hints?: Array< // data about tx to share w/ searchers on mev-share
"contract_address" |
Expand Down Expand Up @@ -329,7 +329,7 @@ example request:
"tx": "0x123abc...",
"maxBlockNumber": "0xcd23a0",
"preferences": {
"fast": true, // left for backwards compatibility; may be removed in a future version
"fast": true,
"privacy": {
"hints": ["calldata", "transaction_hash"],
"builders": ["default"]
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,6 @@ title: MEV-Boost Block Proposal
As depicted above and described in the [Builder — Honest Validator](https://github.com/ethereum/builder-specs) repository, the MEV-Boost block proposal process begins with a [registration step](https://github.com/ethereum/builder-specs) that validators must perform ahead of proposal duties. Registration ensures builders can craft blocks for a given validator’ block proposal. Once registered, validators wait until selected to propose a block. Once selected, a block proposer building a block on top of a beacon `state` in a given `slot` must take the following actions to obtain an [execution payload](https://github.com/ethereum/consensus-specs/blob/a45ee9bf5b1fde766d69e551a6b1a21fe2531734/specs/merge/beacon-chain.md#executionpayload):

1. Users/searchers send transactions to block builders through public or private peer-to-peer transaction pools.
2. Builders construct execution payloads using received transactions, and parameters the block proposer provided during registration. To process MEV payment, builders set their own address as the payload’s coinbase address and append a transaction to the [block proposers’ feeRecipient address](https://flashbots.notion.site/WIP-Builder-Payments-to-Block-Proposers-530eb36c60ad417a8702dd26da810b72)at the end of their proposed block. The block is then forwarded to relays.
2. Builders construct execution payloads using received transactions, and parameters the block proposer provided during registration. To process MEV payment, builders set their own address as the payload’s coinbase address and append a transaction to the [block proposers’ feeRecipient address](https://flashbots.notion.site/WIP-Builder-Payments-to-Block-Proposers-530eb36c60ad417a8702dd26da810b72) at the end of their proposed block. The block is then forwarded to relays.
3. Relays verify the validity of payloads (including amount of ETH paid to the block proposers’ feeRecipient), and send an [`ExecutionPayloadHeader`](https://github.com/ethereum/consensus-specs/blob/a45ee9bf5b1fde766d69e551a6b1a21fe2531734/specs/merge/beacon-chain.md#executionpayloadheader) (execution payloads stripped of transaction content) to MEV-Boost. MEV-boost selects the most valuable payload and forwards it to the block proposer.
4. The block proposer signs the payload and passes it back to MEV-Boost via a [`submitBlindedBlock`](https://ethereum.github.io/builder-specs/#/Builder/submitBlindedBlock) call, which is forwarded to the relay. Once the relay verifies the proposers’ signature, it responds with the full execution payload body for the validator to use when proposing a `SignedBeaconBlock` to the network.
Original file line number Diff line number Diff line change
Expand Up @@ -123,7 +123,7 @@ Detailed JSON-RPC structure for the method are below:
tx, // String, raw signed transaction
maxBlockNumber, // Hex-encoded number string, optional. Highest block number in which the transaction should be included.
preferences?: {
fast: boolean, // Deprecated; required until this is removed from the API. Value has no effect.
fast: boolean, // Sends transactions to all registered block builders, sets MEV-Share revenue share to 50%
privacy?: { // MEV-Share options; optional
hints?: Array< // data about tx to share w/ searchers on mev-share
"contract_address" |
Expand Down Expand Up @@ -157,7 +157,7 @@ example request:
"tx": "0x123abc...",
"maxBlockNumber": "0xcd23a0",
"preferences": {
"fast": true, // left for backwards compatibility; may be removed in a future version
"fast": true,
"privacy": {
"hints": ["calldata", "transaction_hash"],
"builders": ["default"]
Expand Down
1 change: 1 addition & 0 deletions docusaurus.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,7 @@ module.exports = async function createConfigAsync() {
},
};
},
'docusaurus-plugin-sass'
],
}
}
2 changes: 2 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
"axios": "^1.4.0",
"change-case": "^5.1.2",
"clsx": "^1.1.1",
"docusaurus-plugin-sass": "^0.2.5",
"dotenv": "^8.2.0",
"ethers": "^6.7.1",
"postcss": "^8.4.31",
Expand All @@ -45,6 +46,7 @@
"react-loadable": "^5.5.0",
"rehype-katex": "^7",
"remark-math": "^6",
"sass": "^1.69.5",
"search-insights": "^2.8.3",
"tailwindcss": "^3.3.3",
"webpack": "^5.88.1"
Expand Down
21 changes: 21 additions & 0 deletions src/components/Banner/Banner.custom.module.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
@use '_base';

/*
Add custom CSS styling for your banner here
You can add any classes you'd like based on the markup for your banner
The .banner class is already provided and apply to the parent element of
the banner.
The '@extend %banner-structure' defines the structural properties for the
banner and should not be removed.
*/

.banner {
@extend %banner-structure; // Do not remove
}


[data-theme=dark] .banner {
@extend %banner-structure; // Do not remove
}
12 changes: 12 additions & 0 deletions src/components/Banner/Banner.module.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
@use 'base';

.banner {
@extend %banner-structure;

background-color: var(--banner-background-color, var(--ifm-navbar-background-color));
color: var(--banner-text-color, var(--ifm-font-color-base));

a {
color: var(--banner-text-color , var(--ifm-font-color-base));
}
}
82 changes: 82 additions & 0 deletions src/components/Banner/Banner.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
/* Custom Banner Module
Use it to quickly deploy a simple banner to the Flashbots homepage
To add a new banner all you need to do is edit the ./banner.config.tsx
file and set the applicable properties. No other work is necessary.
You'll find more in-depth documentation there.
*/

import React from 'react'
import clsx from 'clsx'
import bannerConfig from './banner.config'
import customStyles from './Banner.custom.module.scss'
import bannerStyles from './Banner.module.scss'

export interface BannerOptions {
bannerContent?: JSX.Element | string | null
backgroundColor: string
textColor: string
startDate: string | null
endDate: string | null
customBannerCSS: boolean
}

class BannerConfigs {
options: BannerOptions

constructor(options: BannerOptions) {
this.options = options
}

// Sets the appropriate CSS rules for the element
// based on the `customCSS` option
getBannerStyle(): React.CSSProperties | null {
return !this.options.customBannerCSS
? {
"--banner-text-color": this.options.textColor,
"--banner-background-color": this.options.backgroundColor
}
: null
}

// Sets the appropriate class name for the element
// based on the `customCSS` option
getBannerClass(): string {
const styles = this.options.customBannerCSS ? customStyles : bannerStyles

return clsx(styles.banner)
}

// Determines whether the banner should appear based on:
// 1. Whether there is content to be shown
// 2. The start and end dates exist and are valid
shouldShowBanner(): boolean {
if (!this.options.bannerContent) {
return false
}

const parsedStart = Date.parse(this.options.startDate)
const parsedEnd = Date.parse(this.options.endDate)
const currentDate = Date.now()

return (
(isNaN(parsedStart) || parsedStart <= currentDate) &&
(isNaN(parsedEnd) || parsedEnd >= currentDate)
)
}
}

export default function Banner(): JSX.Element {
const configs = new BannerConfigs(bannerConfig)

if (!configs.shouldShowBanner()) {
return null
}

return (
<div style={configs.getBannerStyle()} className={configs.getBannerClass()}>
{configs.options.bannerContent}
</div>
)
}
19 changes: 19 additions & 0 deletions src/components/Banner/_base.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
%banner-structure {
height: fit-content;
padding: 0.5rem 2rem;
text-align: center;
line-height: 1.25;

a{
cursor: pointer;
text-decoration: none;

&:hover {
text-decoration: underline;
}
}

@media (max-width: 720px){
padding: 0.5rem 2rem;
}
}
93 changes: 93 additions & 0 deletions src/components/Banner/banner.config.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
/* Custom Banner Module
Use it to quickly deploy a simple banner to the Flashbots homepage
To add a new banner all you need to do is edit the properties below and set them
to your desired values.
For simple banners with just a couple of colors - for copy and background - you
can use the properties here. But if the banner requires more sophisticated styling
you can override the color options by setting `customCSS: true` and adding your CSS
rules to ./Banner.custom.module.scss.
There are detailed explanations for each property below, but here's a quick guide:
- bannerContent: What should appear inside the banner
- backgroundColor: Solid, single color for the banner
- textColor: Solid, single color for all the copy inside the banner
- startDate: When should the banner start appearing on the site
- endDate: When should the banner stop appearing on the site
- customCSS: Whether the banner should make use of custom CSS rules loaded from ./Banner.custom.module.scss
*/

import React from 'react'
import BannerOptions from './Banner'

export const bannerConfig: BannerOptions = {
/*
bannerContent: The pure text or HTML markup to appear in the banner
- Banner won't appear when set to null
Examples:
- bannerContent: null
- bannerContent: "Banner content!"
- bannerContent: (<span>Banner content! <a href='https://example.com' target='_blank' rel='noreferrer'>Link</a></span>)
*/
bannerContent: null,

/*
backgroundColor: Single, solid background color for the banner
- Will default to the site's background when set to null
- Has no effect if customCSS is true
Examples:
- backgroundColor: null
- backgroundColor: "#023047"
*/
backgroundColor: null,

/*
textColor: Single, solid text color for the banner
- Will default to the site's text color when set to null
- Has no effect if customCSS is true
Examples:
- textColor: null
- textColor: "#ffb703"
*/
textColor: null,

/*
startDate: Date and time (UTC) when the banner should start appearing on the website
- When set to null a banner will always appear, provided there is content to be shown
and the endDate, if there is one, hasn't been reached
Format: "YYYY-MM-DD HH:mmZ"
Examples:
- startDate: null
- startDate: "2001-09-14 16:00Z"
*/
startDate: null,

/*
endDate: Date and time (UTC) when the banner should stop appearing on the website
- When set to null a banner will always appear, provided there is content to be shown
and the startDate, if there is one, has been reached
Format: "YYYY-MM-DD HH:mmZ"
Examples:
- endDate: null
- endDate: "2007-02-01 00:00Z"
*/
endDate: null,

/*
customCSS: Determines whether to use a custom CSS instead instead of the color options
- Custom CSS must be set in ./Banner.custom.module.scss
- Will completely bypass backgroundColor and textColor if set to true
Examples:
- customCSS: true
*/
customBannerCSS: false
}

export default bannerConfig
13 changes: 13 additions & 0 deletions src/theme/Navbar/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
import React from 'react';
import Navbar from '@theme-original/Navbar';
import Banner from '../../components/Banner/Banner'
import styles from './navbar.module.css'

export default function NavbarWrapper(props) {
return (
<div className={styles.combinedNavigation}>
<Banner/>
<Navbar {...props} />
</div>
);
}
5 changes: 5 additions & 0 deletions src/theme/Navbar/navbar.module.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
.combinedNavigation {
position: sticky;
top: 0px;
z-index: var(--ifm-z-index-fixed);
}
Loading

0 comments on commit cb29458

Please sign in to comment.