Skip to content

The PowerShell Awesome Framework is a versatile and user-friendly PowerShell module that empowers users to streamline their scripting experience with a collection of useful code snippets

License

Notifications You must be signed in to change notification settings

voytas75/PowershellFramework

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PowerShell Awesome Framework

PowerShell Awesome Framework

ko-fi

status   PowerShell Gallery Version (including pre-releases)   PowerShell Gallery   Codacy Badge

status

Overview

The PowerShell Awesome Framework is a versatile and user-friendly PowerShell module that empowers users to streamline their scripting experience with a collection of useful code snippets. This framework is designed to enhance productivity and simplify the execution of various PowerShell tasks, making it a valuable tool for both beginners and experienced PowerShell users.

Features

  1. Customizable Settings: The framework includes a JSON configuration file config.json that is automatically generated when you run the Start-PAF command for the first time. This configuration file allows users to modify settings and personalize the framework's behavior to suit their preferences and workflow. You can easily adjust the framework's options to match your unique coding needs by editing the settings in the config.json file.
  2. User-Specific Snippets: Store your custom snippets in an additional folder path, distinct from the core framework snippets. This feature allows you to maintain personalized code without affecting the core functionality.
  3. Dynamic Snippet Loading: The framework dynamically loads snippets from both the main path (specified in the configuration file) and the user-specific snippets folder. Access all available snippets from one centralized location.
  4. Organized Menu System: The framework presents snippets in a compact and organized menu, categorized based on their functionality. Quickly browse through categories and snippets to find the desired functionality effortlessly.
  5. Pagination for Large Collections: Manage a large number of snippets efficiently with built-in pagination. Navigate through multiple pages of snippets with ease, enabling access to a vast array of functionalities.
  6. Keyword-Based Search: Utilize the search functionality to filter snippets based on keywords. Perform quick searches to locate specific snippets within extensive collections.
  7. Startup Banner Option: Decide whether to display a startup banner when loading the framework. Customize the banner to display essential information or updates.
  8. Snippet Filtering: Easily refine your snippet selection through a user-friendly filtering feature, enabling precise access to the code functionalities you need. Added in 0.2.5.
  9. REMOVED: Color Output Option: Choose your preferred visual representation by enabling or disabling color output in the menu. Adapt the framework to match your terminal settings and preferences.

Aspects' ideas

Aspects' ideas

Installation and Usage

The module is available on PowerShell Gallery.

Install-Module -Name PAF

Import module

Import-Module -Module PAF

To get all commands in installed module including cmdlets, functions and aliases:

Get-Command -Module PAF

Start framework to load the menu (JSON configuration file config.json is automatically generated).

Start-PAF

Display configuration. Employ the Get-PAFConfiguration command to load your custom configuration (JSON configuration file config.json is automatically generated).

Get-PAFConfiguration

Invoke the Save-PAFConfiguration command to save configuration (JSON configuration file config.json is automatically generated).

Save-PAFConfiguration

Adding Function Snippets to PowerShell Awesome Module

To prepare a function snippet for adding it to the PowerShell Awesome Module use tempate PAF\snippets\core\TEMPLATE_Get-Example.ps1 or example PAF\snippets\core\PAF_Get-Example.ps1 and follow these steps:

  1. Create the Snippet File:

    Place the snippet file in one of the following folders:

    • $PSRootPath\snippets\core\
    • $([Environment]::GetFolderPath("MyDocuments"))\PowerShell Awesome Framework\user_snippets\ (recommended)

    Make sure the snippet file has a name with the prefix 'PAF_' followed by the function name. For example: PAF_Get-Example.ps1

  2. Add Inline Help:

    At the top of the snippet file, include inline help using PowerShell comment-based help format. The help should contain a synopsis and description of the snippet. Leave two empty lines after the help section. Here's an example:

    <#
    .SYNOPSIS
    
    Template
    
    .DESCRIPTION
    
    Template file to show how to prepare a function snippet for the PowerShell Awesome Module
    #>
  3. Specify Category and Name in Function Body:

    Inside the function body, include special tags :CATEGORY and :NAME to specify the category and name of the snippet. Can't be in inline help block! Use the following format:

    <#
    :CATEGORY
    put here the name of the category
    :NAME
    Get-Example
    #>

    Replace put here the name of the category with the actual category name, and Get-Example with the name of the function that the snippet represents.

  4. Ensure Proper Logic:

    Make sure that the snippet contains logic to execute the functionality that the user intends. Test the snippet to ensure it works correctly.

  5. Add to PowerShell Awesome Module:

    Once the snippet file is ready, add it to the user snippets folder where it belongs. For example, if the snippet is for a function called Get-Example, it would be placed in the PAF_Get-Example.ps1 file inside the $([Environment]::GetFolderPath("MyDocuments"))\PowerShell Awesome Framework\user_snippets\ folder.

By following these steps, you can contribute function snippets to the PowerShell Awesome Module effectively. Ensure that your snippets adhere to the guidelines mentioned above for consistency and compatibility with the module.

Versioning

We use SemVer for versioning.

Contributing

We welcome contributions from the community! Feel free to submit pull requests, report issues, or suggest new features to make the framework even more powerful and user-friendly.

Clone the Repository: Clone the PowerShell Awesome Framework repository to your local machine.

License

The PowerShell Awesome Framework is released under the MIT License.

Contact: If you have any questions or need assistance, please feel free to reach out to us via GitHub Issues.

Join us on the journey to make PowerShell scripting a truly awesome experience!

About

The PowerShell Awesome Framework is a versatile and user-friendly PowerShell module that empowers users to streamline their scripting experience with a collection of useful code snippets

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published