Skip to content

(DRAFT) Feature (mix task): Add a REST API generator to scaffold the code by Domain, Resources and Actions on the REST API layer #7

@Exadra37

Description

@Exadra37

Mix Task to generate the REST API folder structure organized by Domain, Resource and Actions

Github Sponsor: https://github.com/sponsors/Exadra37

Important

→ To define which features from the README Roadmap will be free, only for sponsors, or only available in the PRO version.

Why?

To enable developers to write Clean Code in a Clean Software Architecture that respects the Single Responsibility Principle.

The traditional approach in software development tends to group all actions for a resource under the same module, which violates the Single Responsibility Principle because the module has more than one reason to change, as many as the number of actions on the resource.

What?

What to expect from this task is that when the developer executes the mix scribe.gen.restapi ... command in the terminal, the result is a folder structure where a module is created for each action of a REST API resource in a domain at lib/my_app_restapi/. This respects the Single Responsibility Principle because each module only has one reason to change: the logic for the single action it is responsible for.

This generator will also invoke mix scribe.gen.domain (issue #4) to generate the Domain, Resource and Actions for the core business logic.

When?

The developer should use this generator whenever they need to create a new feature that will be consumed via REST API endpoints.

Acceptance Criteria

Let's base the acceptance criteria's on a developer tasked with building an Online Shop.

TODO: Define the acceptance criteria's

Metadata

Metadata

Assignees

Labels

draftFor issues that are being defined, thus not ready to work on

Type

No type

Projects

No projects

Milestone

No milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions