org.graceframework:grace-core

2023.3.0-M1last stable release 2 months ago
Complexity Score
High
Open Issues
2
Dependent Projects
9

License

  • Apache-2.0
    • Yesattribution
    • Permissivelinking
    • Permissivedistribution
    • Permissivemodification
    • Yespatent grant
    • Yesprivate use
    • Permissivesublicensing
    • Notrademark grant

Readme

Grace Framework

Grace is a fork of Grails 5 that started development in early 2022, it’s a powerful and open-source One-Person web framework used to build enterprise-grade Spring Boot applications with the powerful Groovy programming language. The core framework is very extensible and there are numerous Plugins available that provide easy integration of add-on features.

Getting Started

You need a Java Development Kit (JDK) installed, but it is not necessary to install Groovy because it’s bundled with the Grace distribution.

To install Grace, visit https://github.com/graceframework/grace-framework/releases and download the version you would like to use. Set a GRACE_HOME environment variable to point to the root of the extracted download and add GRACE_HOME/bin to your executable PATH. Then in a shell, type the following:

    grace create-app com.example.blog
    cd blog
    grace run-app

To build Grace, clone this GitHub repository and execute the install Gradle target:

    git clone https://github.com/graceframework/grace-framework.git
    cd grace-framework
    ./gradlew pTML zipDist

If you encounter out of memory errors when trying to run the install target, try adjusting Gradle build settings. For example:

    export GRADLE_OPTS="-Xmx2G -Xms2G -XX:NewSize=512m -XX:MaxNewSize=512m"

For installation instructions see INSTALL.txt.

Plugins

Grace is first and foremost a web application framework, but it is also a platform. Grace provide Plugin API to expose a number of extension points that let you extend anything from the command line interface to the runtime configuration engine.

Grace Framework repository contains core plugins and most commonly used plugins, which are provided by default when creating a project.

  • Grace Asset Pipeline Plugin is a plugin used for managing and processing static assets in Grace applications.
  • Grace Async and Events provides asynchronous, parallel programming, Events APIs, which integrate Grace with various asynchronous libraries and frameworks such as GPars and RxJava.
  • Grace Cache provides powerful and easy to use caching functionality to Grace applications and plugins.
  • Grace Database Migration helps you manage database changes uses the Liquibase library.
  • Grace Scaffolding is a plugin to generate scaffolded controllers and views for your Grace application.
  • Grace Fields is a plugin allows you to customize the rendering of input fields for properties of domain objects, command beans and POGOs based on their type, name, etc.
  • Grace Geb provides the Geb dependencies and a create-functional-test command for generating Geb tests.
  • Grace Views includes JSON views powered by Groovy’s JsonBuilder, also provides the basis for implementation other view types.

Grace Plugins repository contains several plugins to develop applications more easier and productive.

  • Grace Admin is a powerful and flexible, extensible administration framework and management console for Grace, which use Grace Dynamic Modules.
  • Grace Htmx is a plugin provide helpers to easy use HTMX.
  • Grace Hotwire is a plugin for using Hotwire Stimulus and Turbo.
  • Grace Unpoly is a plugin for using Unpoly.
  • Grace View Components is a plugin for creating reusable, testable and encapsulated view components.

Profiles

Grace profile is a simple directory that contains a profile.yml file and directories containing the “commands”, “skeleton” and “templates” defined by the profile.

Grace provides several profiles in the Grace Profiles repository,

  • base - a profile for other profiles to extend from
  • plugin - a profie to create a plugin
  • profile - a profie to create a custom profile
  • rest-api - a profie for REST API applications
  • starter - A profile for getting start to create anything you like
  • web-plugin - a profile for Web plugin that contains web resources css js images
  • web - default profile to creae a web app

Guides

Grace Guides repository contains several guides that show how to use Grace.

  • Spring Boot Application with Plugins is a how-to guide that shows you how to use Grace Plugins in your Spring Boot application.
  • Spring Boot Application with GSP is a how-to guide that shows you how to use GSP as view templates in your Spring Boot application.
  • Spring Boot Application with GORM is a how-to guide that shows you how to use GORM as data persistence layer in your Spring Boot application.
  • Build Admin Console with Grace Admin Plugin is a how-to guide that shows you how to use Grace Admin plugin to build flexible, extensible management console in your application.

License

Grace framework is Open Source software released under the Apache License, Version 2.0.

Dependencies

Loading dependencies...

CVE IssuesActive
0
Scorecards Score
No Data
Test Coverage
No Data
Follows Semver
Yes
Github Stars
18
Dependenciestotal
10
DependenciesOutdated
4
DependenciesDeprecated
0
Threat Modelling
No
Repo Audits
No

Learn how to distribute org.graceframework:grace-core in your own private Maven registry

mvn install org.graceframework:grace-core
Processing...
Done

58 Releases