mirror of
https://github.com/harivansh-afk/betterNAS.git
synced 2026-04-15 09:01:13 +00:00
init specification 1
This commit is contained in:
parent
678ca148d5
commit
cceabd1e91
7 changed files with 243 additions and 0 deletions
|
|
@ -0,0 +1,22 @@
|
|||
## ADDED Requirements
|
||||
|
||||
### Requirement: Dedicated control-plane service
|
||||
The system SHALL provide an aiNAS-owned control-plane service that is separate from the Nextcloud shell app and owns product domain logic.
|
||||
|
||||
#### Scenario: aiNAS adds a new control-plane rule
|
||||
- **WHEN** a new business rule for storage policy, RBAC, orchestration, or future client behavior is introduced
|
||||
- **THEN** the rule MUST be implemented in the control-plane service rather than as primary logic inside the Nextcloud app
|
||||
|
||||
### Requirement: Client-agnostic internal API
|
||||
The control-plane service SHALL expose internal APIs that can be consumed by the Nextcloud shell app and future aiNAS clients without requiring direct coupling to Nextcloud internals.
|
||||
|
||||
#### Scenario: New aiNAS client consumes control-plane behavior
|
||||
- **WHEN** aiNAS adds a web, desktop, or iOS surface outside Nextcloud
|
||||
- **THEN** that surface MUST be able to consume control-plane behavior through documented aiNAS service interfaces
|
||||
|
||||
### Requirement: Nextcloud backend adapter boundary
|
||||
The control-plane service SHALL isolate Nextcloud-specific integration at its boundary so that storage and sharing backends remain replaceable over time.
|
||||
|
||||
#### Scenario: Service calls the Nextcloud backend
|
||||
- **WHEN** the control-plane service needs to interact with file or sharing primitives provided by Nextcloud
|
||||
- **THEN** the interaction MUST pass through a dedicated adapter boundary instead of spreading Nextcloud-specific calls across unrelated domain code
|
||||
Loading…
Add table
Add a link
Reference in a new issue