Dart client for Dmart

A Dart implementation of the Dmart that depends on dio.

APIs

  • void initDmart({bool isDioVerbose = false}) - Initializes the Dio networking instance.
  • Future<dynamic> getManifest() - Retrieves the Dmart manifest.
  • Future<dynamic> getSettings() - Retrieves the Dmart settings.
  • Future<(LoginResponse?, Error?)> login(LoginRequest loginRequest) - Authenticates a user and returns login information.
  • Future<(CreateUserResponse?, Error?)> createUser(CreateUserRequest createUserRequest) - Creates a new user.
  • Future<(ApiResponse?, Error?)> logout() - Logs the user out.
  • Future<(ProfileResponse?, Error?)> getProfile() - Retrieves the current user's profile.
  • Future<(ApiQueryResponse?, Error?)> query(QueryRequest query, {String scope = "managed"}) - Executes a query against the Dmart backend.
  • Future<(ActionResponse?, Error?)> request(ActionRequest action) - Performs an action on the Dmart system.
  • Future<(ResponseEntry?, Error?)> retrieveEntry(RetrieveEntryRequest request, {String scope = "managed"}) - Fetches a specific entry from Dmart.
  • Future<(ActionResponse?, Error?)> createSpace(ActionRequest action) - Creates a new space.
  • Future<(ApiQueryResponse?, Error?)> getSpaces() - Retrieves a list of spaces.
  • Future<dynamic> getPayload(GetPayloadRequest request) - Retrieves payload data.
  • Future<(ApiQueryResponse?, Error?)> progressTicket(ProgressTicketRequest request) - Updates a progress ticket.
  • Future<(Response?, Error?)> createAttachment({required String shortname, required String entitySubpath, required File payloadFile, required String spaceName, bool isActive = true, String resourceType = "media"}) - Uploads an attachment.
  • Future<(ActionResponse?, Error?)> submit(String spaceName, String schemaShortname, String subpath, Map<String, dynamic> record) - Submits a record (log/feedback) to Dmart.
  • String getAttachmentUrl(String resourceType, String spaceName, String subpath, String parentShortname, String shortname, String ext) - Constructs an attachment URL.

Basic Usage

  • Always initialize the Dmart instance before using it.
Dmart.initDmart();
// Or with dio verbose for debugging purposes
Dmart.initDmart(isDioVerbose: true);
  • Getting manifests and settings
// Get manifests
var (respManifests, _) = await Dmart.getManifest();
// Get settings
var (respSettings, _) = await Dmart.getSettings();
  • User creation
final CreateUserAttributes createUserAttributes = CreateUserAttributes(
    displayname: Displayname(en: 'test'),
    invitation: 'ABC',
    password: '@Jimmy123_',
    roles: ['super_admin'],
);
var (responseCreateUser, error) = await Dmart.createUser(CreateUserRequest(
    shortname: 'jimmy',
    attributes: createUserAttributes,
));
  • User login
// By using shortname and password
var (responseLogin, _) = await Dmart.login(
  LoginRequest(shortname: 'jimmy', password: '@Jimmy123_'),
);

// By using email or msisdn instead of shortname
LoginRequest.withEmail
LoginRequest.withMsisdn

// By passing directly a token
Dmart.token = 'xxx.yyy.zzz';
  • Get user profile
var (respProfile, _) = await Dmart.getProfile();
  • Get all spaces
var (respSpaces, _) = await Dmart.getSpaces();
  • Create a space
ActionRequest createSpaceActionRequest = ActionRequest(
    spaceName: 'my_space',
    requestType: RequestType.create,
    records: [
      ActionRequestRecord(
        resourceType: ResourceType.space,
        shortname: 'my_space',
        subpath: '/',
        attributes: {
          'displayname': {'en': 'Space'},
          'shortname': 'space',
        },
      ),
    ]);

var (respCreateSpace, _) = await Dmart.createSpace(createSpaceActionRequest);
  • Querying a subpath
var (respQuery, _) = await Dmart.query(
    QueryRequest(
        queryType: QueryType.subpath,
        spaceName: 'management',
        subpath: 'users',
        retrieveJsonPayload: true,
    ),
);
for (var record in respQuery?.records ?? []) {
  print(record.shortname);
}

*Retrieve entry

var (respEntry, _) = await Dmart.retrieveEntry(
  RetrieveEntryRequest(
      resourceType: ResourceType.user,
      spaceName: 'management',
      subpath: 'users',
      shortname: 'jimmy',
      retrieveJsonPayload: true,
  )
);
  • Get entry payload
var (respEntryPayload, _) = await Dmart.getPayload(GetPayloadRequest(
  resourceType: ResourceType.content,
  spaceName: 'myspace',
  subpath: 'mysubpath',
  shortname: 'myentry'
));
  • Content creation
// folder creation
ActionRequestRecord actionRequestRecord = ActionRequestRecord(
  resourceType: ResourceType.folder,
  subpath: '/',
  shortname: 'my_subpath',
  attributes: subpathAttributes,
);
ActionRequest action = ActionRequest(
  spaceName: 'my_space',
  requestType: RequestType.create,
  records: [actionRequestRecord],
);
var (respRequestFolder, err) = await Dmart.request(action);

// content creation
ActionRequestRecord actionRequestRecord = ActionRequestRecord(
    resourceType: ResourceType.content,
    subpath: 'my_subpath',
    shortname: 'my_content',
    attributes: {
        "is_active": true,
        "relationships": [],
        "payload": {
            "content_type": "json",
            "schema_shortname": null,
            "body": {
              "isAlive": true
            }
        }
    },
);
ActionRequest action = ActionRequest(
    spaceName: 'my_space',
    requestType: RequestType.create,
    records: [actionRequestRecord],
);
var (respRequestContent, err) = await Dmart.request(action);

// attachment creation
ActionRequestRecord actionRequestRecord = ActionRequestRecord(
    resourceType: ResourceType.json,
    subpath: 'my_subpath/my_content',
    shortname: 'auto',
    attributes: {
        "is_active": true,
        "payload": {
            "content_type": "json",
            "schema_shortname": null,
            "body": {
                "attachmentName": "my attachment",
                "isImportant": "very important"
            }
        }
    },
);
ActionRequest action = ActionRequest(
    spaceName: 'my_space',
    requestType: RequestType.create,
    records: [actionRequestRecord],
);
var (respRequestAttachment, err) = await Dmart.request(action);
  • Progress a ticket
var (respProgression, _) = await Dmart.progressTicket(
  ProgressTicketRequest(
    spaceName: "myspace",
    subpath: "test",
    shortname: "myticket",
    action: "rejected",
  )
);
  • Create attachment
File img = File("/path/to/myimg.jpg");
var (respAttachmentCreation, _) = await Dmart.createAttachment(
    spaceName: "myspace",
    entitySubpath: "mysubpath",
    entityShortname: "myshortname",
    attachmentShortname: "auto",
    attachmentBinary: img,
);
  • Get attachment url
String attachmentURL = await Dmart.getAttachmentUrl(
    spaceName: "myspace",
    entitySubpath: "mysubpath",
    entityShortname: "myshortname",
    attachmentShortname: "myAttachment",
);
  • Submit an entry
var (respSubmitEntry, _) = await Dmart.submit(
    "applications",
    "log",
    "logs",
    {
      "shortname": "myentry",
      "resource_type": ResourceType.content.name,
      "state": "awesome entry it is !"
    },
);
  • Logout
var (respLogout, _) = await Dmart.logout();

Libraries

dmart
Support for doing something awesome.