Guide for authors ๐ โ
The Hacker Recipes is a community-driven project, and we welcome contributions from anyone who wants to share their knowledge and help others learn. In order to keep the quality of the content high, in terms of readability and structure, we ask contributors to follow a consistent structure and best practices when writing articles.
This guide outlines the typical structure, file organization, and best practices for writing articles that align with the project's standards.
Files and folders โ
All articles are stored in the /docs/src
folder.
If the article doesn't include images (or other assets), if should be a markdown file with the .md
extension, and named after the topic it covers.
Navigation panel โ
For the article to be included in the navigation panel, it should be added to the config.mts
file, in the sidebar
array, with the following structure:
{
"text": 'Category',
"items": [
{
"text": 'Article without images',
"link": '/.../category/topic.md',
},
{
"text": 'Article with images',
"link": '/.../category/topic/index.md',
}
]
}
A category can be a container for articles, and/or be a container for other categories, and include (or not) an index.md
file to provide a brief introduction to the category. For the latter, the structure goes like this:
{
"text": 'Category',
"link": '/.../index.md'
"items": [
// ...
Content structure โ
A typical article in this project follows a three-part structure:
- Theory: provides an introduction to the topic, adds context, explains the concepts and ideas behind it.
- Practice: delves into the practical aspects: step-by-step explanations and examples, with commands and code snippets. This part should include, whenever possible, a tabs block with one tab for Unix-like commands, and another for Windows commands.
- Resources: lists the sources that helped build the article, and additional resources that one can use to further their learning (e.g. articles, blogposts, whitepapers, videos)
Writing style โ
When writing your article, one should keep the following tone & voice.
- Professional and Authoritative: The content should maintain a professional tone, suitable for a technical audience familiar with cybersecurity concepts.
- Instructional and Informative: The writing aims to educate the reader, with clear instructions and explanations. It avoids being overly casual, focusing instead on delivering detailed, technical knowledge.
- Impersonal and Objective: The writing should avoid directly addressing the reader (e.g., โyou") or using personal pronouns. Instead, use passive constructions or neutral phrasing (e.g., โThe attack can be conducted using tool XYZ" rather than โYou can conduct the attack with tool XYZ").
Examples to avoid
- "This attack is super easy to pull off!" โ โThis attack is straightforward to execute."
- "Hereโs a cool trick you can use to bypass the firewall" โ โA technique to bypass the firewall involvesโฆ"
- "Just try running this command and see what happens" โ โRun this command to observe its effect."
- "Donโt forget to check the logs!" โ โEnsure that the logs are reviewed."
- "You can conduct the attack with tool XYZ" โ โThe attack can be conducted with tool XYZ"
- "We recommend using tool ABC for this process" โ โTool ABC is recommended for this process"
- "First, you should verify the configuration settings" โ โThe configuration settings should first be verified"
ChatGPT (or similar LLM agents) can be used to review content before creating a Pull Request ๐ Below is an example prompt.
"Please proofread the following text for tone, voice, and style consistency based on these guidelines: professional, instructional, and impersonal. Highlight any instances where casual language, direct address (e.g., 'you'), or personal pronouns are used, and suggest revisions. Here is the text: [insert your content]."
Block Types โ
The project uses a variety of block types to organize and present content. While this guide focuses on the main blocks used in this project, additionnal blocks are listed in the official VitePress docs.
Code โ
Use triple backticks to delimit code blocks, specifying the language after the first set of backticks. VitePress supports extended usage of code blocks such as syntax highlighting, line highlighting, line focus, colored diffs, errors and warnings highlighting, line numbers, code groups.
But it can be as simple as that:
```python
print('hello world')
```
Giving the following output
print('hello world')
Tabs โ
Input
:::tabs
== tab a
Some content
== tab b
b content
:::
Output
Some content
Callouts โ
THR uses GitHub-flavored alerts to render most callouts. The most common callouts in The Hacker Recipes are:
NOTE
Note from the author, not critical to the main content. To calrify, offer references, add content or background.
TIP
Offer helpful advice or best practices. Providing shortcut or expert recommandation.
WARNING
Alert the reader to potentiel dangers. Provide OPSEC advice.
CAUTION
When there's critical information the reader needs to be aware of.
SUCCESS
When the author wants to highlight a successful outcome or scenario.
Details
Details blocks can also be used
The input for this goes like this:
> [!NOTE] NOTE
> Note from the author, not critical to the main content. To calrify, offer references, add content or background.
> [!TIP] TIP
> Offer helpful advice or best practices. Providing shortcut or expert recommandation.
> [!WARNING] WARNING
> Alert the reader to potentiel dangers. Provide OPSEC advice.
> [!CAUTION] CAUTION
> When there's critical information the reader needs to be aware of.
> [!SUCCESS] SUCCESS
> When the author wants to highlight a successful outcome or scenario.
::: details
Details blocks can also be used
:::
The title of a callout is optionnal.
> [!NOTE]
The title of a callout is optionnal.
Images and links โ
As simple as [title](link)
for links and ![](path/to/image)
for images.
If there are spaces in the image path, either spaces need to be URL-encded (%20
), or the following structure can be used (recommended): ![](<path/to/some image>)
Images can also be given a caption
![](path/to/image)
Some caption{.caption}
Which will output the following
To embed a YouTube link, use the following tag format:
> [!YOUTUBE] https://www.youtube.com/watch?v=example
This will create a clickable link that directs users to the specified YouTube video.
Which will output the following
Ensure you provide the full YouTube link, as using a shortened link will cause the tag to malfunction.
Others โ
Block | Description |
---|---|
Links | Internal links (to other articles, or to anchor points) |
Tables | Tables (like this one) |
Emojis | Emojis ๐ |
### Quotes
> "Someone said something important and it should be highlighted in the article? Please quote it and attribute it to the initial author."
>
> _(Author, date, [source](#))_
```markdown
> "Someone said something important and it should be highlighted in the article? Please quote it and attribute it to the initial author."
>
> _(Author, date, [source](#))_
Article template โ
An article template is available for a quick start: Template.
Highlighting contributors โ
For contributors to be listed, they need to be listed in the authors
property of the frontmatter configuration of the corresponding page(s).
When contributing to a page, an author must add its GitHub username to it:
---
authors: author1, author2, ...
---
Get started ๐ โ
- Fork the repository (https://github.com/The-Hacker-Recipes/The-Hacker-Recipes/fork)
- (optionnal) create a new branch in your fork, if you plan on working on different topics
- Create your content using this guide, and the template if needed
- Make sure the content builds fine with
npm install && npm run docs:dev
- Make a Pull Request (https://github.com/The-Hacker-Recipes/The-Hacker-Recipes/compare)