[ROOT] / doc / DocFrag / ARCAPI.BaseController

KeyValue
AssemblyARCAPI
DocFragTypeClass
NameBaseController
NamespaceARCAPI
TypeBaseController

ClassAttribute

KeyValue
AssemblyNameARCAPI
BaseTypesPConcurrent
ClassNamespaceARCAPI
ClassTypeBaseController
CorrespondingEnumTypeBaseControllerP
InterfacesIP; -IEnumerable<IKIP>-; -IEnumerable-
SubTypesAddController; EditController; GQController; RQController

Contains basic functionality for serving API methods.

Regarding ExposingApplicationState:
The specific controller instances serving requests are usually stored in a global DataStorage like 'app/{nodeId}/Controller/{TypeOfController}/{ControllerId}...'.
(in other words, ControllerStorage actually points to a branch inside Storage.)

Examples of API requests and how they are resolved to a Controller by CatchAll:
API request URL: https://yourserver.com/RQ/dt/Customer/42
Controller instance (in this case of type RQController) to be found in controllerStorage["RQController"]
Method APIMethod is called on this instance.

The following controller classes are included within ARCAPI:

RQController:
Executes a REST like query request against the given DataStorage.
Example: https://yourserver.com/RQ/dt/Customer/42

AddController:
Parses and stores a PropertyStreamLine.
Example: https://yourserver.com/Add/dt/Customer/42/FirstName = John

GQController:
Offers GraphQL queries.
Not implemented as of Feb 2022.

EditController:
Offers a simple HTML editing environment of the raw PropertyStream from the given key.
Example: https://yourserver.com/Edit/dt/Customer/42

Note how these controllers are sufficient for a basic CRUD API (Create, Read, Update, Delete).
(Delete is done by using the metakey Invalid.)

Often no additional ApplicationSpecificCode is needed.

ARCEvent offers additional controllers of which the most important are -RSController- and -ESController- for operating against the RegStream and EventStream respectively.

See BuildControllerStorage for how ApplicationSpecificCode controllers are integrated.

This system has the following advantages:
(Note: The concepts described below has shown little practical value as of Feb 2022).

1) The API-routing syntax is by default exposed to the outside because the ControllerStorage is normally inserted into the global DataStorage.
Therefore the standard query mechanism in AgoRapide can be used to get this information by querying like
'RQ/log/[nodeId]/Controller'

2) The API itself is discoverable even without querying like above, without much special code.
This is because an invalid API request is actually analyzed by the same mechanism answering standard queries.
When the error message is returned it actually contains data about the correct syntax.

3) The API is configurable both through the API itself and also over the PropertyStream.
For instance like 'Add/log/[nodeId]/Controller/RQ/~std/LogLevel = Warning' which would change the log level for the standard instance ('std') of RQController to 'Warning'.

4) Different instances of the same controller type can exist and be configured individually.
For instance if some specific query needs additional logging down to debug level, a dedicated controller can be created for this and configured individually, like
'Add/log/[nodeId]/Controller/RQController/~dbg/LogLevel = Debug'
(Note: Such a debug controller is created by default by BuildControllerStorage).

NOTE: Such specific controller instances can be used like 'RQ~dbg/...' instead of 'RQ/~dbg/...'. NOTE: This make inserted links more correct, for instance when RQController links to EditController
NOTE: The reason for the somewhat special ~ prefix for the controller instance key is to avoid ambiguities NOTE: which are inherent because the complete hierarchical level has not been deemed necessary to specify explicitly.

Some limitations of this approach are:
1) Actual API method name is limited to the name of the controller type (without the 'Controller' part).
That is, a controller called CustomerController can only serve queries starting with 'Customer'.

Note however that in your ApplicationSpecificCode you can implement any additional controllers with routing structure totally independent of this standard generic AgoRapide mechanism.
In other words, you can keep the AgoRapide mechanism for its standardised approach to data manipulation and add additional traditional controllers and methods as needed.

Note how the BaseController classes (like this class) do not inherit any special Microsoft.AspNetCore.Mvc class. They are totally stand-alone with regard to Microsoft.AspNetCore.Mvc.

Edit


Generated 2025-01-13 21:46:22.667 UTC