ariesagent

package module
v0.0.0-...-f3e3514 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 17, 2023 License: Apache-2.0 Imports: 7 Imported by: 0

README

Agent SDK Mobile

Mobile bindings for the Agent SDK library.

Note: these bindings are experimental and are subject to frequent changes.

1. Requirements

2. Build

Export (or set) the following variables

  • ANDROID_HOME - the location of the installed Android SDK
  • ANDROID_NDK_HOME - the location of the installed Android NDK
2.1 Make All
$ make all
2.2 Make Bindings
a. All bindings
$ make bindings
b. Android bindings
$ make bindings-android
c. iOS bindings

Please note that this can only be run on macOS.

$ make bindings-ios

3. Usage

3.1. Android
a. Importing the generated binding as a module in Android Studio
  • In the menu of your Android Studio project, go to File>Project Structure.
  • A modal will be displayed and on the left click on Modules.
  • In the section title Modules click on the +.
  • Another modal will be displayed, scroll down and select Import .JAR/.AAR Package and press Next.
  • In the File name field, enter the path to the agent-sdk.aar file and click Finish.
  • Select Apply if applicable and then OK.
  • Reopen the Project Structure modal and on the left click on Dependencies.
  • Click on app. In the section titled Declared Dependencies, click on the +.
  • Click on Module Dependency and select agent-sdk.aar.
  • Click OK and select Apply if applicable and then OK.
b. Code sample

This is an example of how the imported module can be used:

Java

import org.trustbloc.agent.sdk.api.AriesController;
import org.trustbloc.agent.sdk.api.IntroduceController;
import org.trustbloc.agent.sdk.ariesagent.Ariesagent;
import org.trustbloc.agent.sdk.models.RequestEnvelope;
import org.trustbloc.agent.sdk.models.ResponseEnvelope;
import org.trustbloc.agent.sdk.config.Options;

import java.nio.charset.StandardCharsets;
/*
...
*/
        // create options
        Options opts = new Options();
        opts.setAgentURL("http://example.com");
        opts.setUseLocalAgent(false);

        ResponseEnvelope res = new ResponseEnvelope();
        try {
            // create an aries agent instance
            AriesController a = Ariesagent.new_(opts);

            // create a controller
            IntroduceController i = a.getIntroduceController();

            // perform an operation
            byte[] data = "{}".getBytes(StandardCharsets.UTF_8);
            res = i.actions(new RequestEnvelope(data));
        } catch (Exception e) {
            e.printStackTrace();
        }

        String actionsResponse = new String(res.getPayload(), StandardCharsets.UTF_8);
        System.out.println(actionsResponse);

Kotlin

import org.trustbloc.agent.sdk.ariesagent.Ariesagent
import org.trustbloc.agent.sdk.config.Options
import org.trustbloc.agent.sdk.models.RequestEnvelope
import org.trustbloc.agent.sdk.models.ResponseEnvelope
import java.nio.charset.StandardCharsets
/*
...
*/
        // create options
        val opts = Options()
        opts.agentURL = "http://example.com"
        opts.useLocalAgent = false
        var res = ResponseEnvelope()
        try {
            // create an aries agent instance
            val a = Ariesagent.new_(opts)

            // create a controller
            val i = a.introduceController

            // perform an operation
            val data = "{}".toByteArray(StandardCharsets.UTF_8)
            res = i.actions(RequestEnvelope(data))
        } catch (e: Exception) {
            e.printStackTrace()
        }
        val actionsResponse = String(res.payload, StandardCharsets.UTF_8)
        println(actionsResponse)

To subscribe to events on an Aries agent, implement the Handler interface and use as follows:

Java


import java.nio.charset.StandardCharsets;

import org.trustbloc.agent.sdk.api.Handler;

class MyHandler implements Handler {

    @Override
    public void handle(String topic, byte[] message) {
        System.out.println("received notification topic: ", topic);
        System.out.println("received notification message: ", new String(message, StandardCharsets.UTF_8));
    }
}

class AriesService {
    AriesController ariesAgent;

    public void newAgentWithHandler(String url, String websocketURL, bool useLocalAgent) {
        Options opts = new Options();
        opts.setAgentURL(url);
        opts.setWebsocketURL(websocketURL);
        opts.setUseLocalAgent(useLocalAgent);

        try {
            ariesAgent = Ariesagent.new_(opts);

            // register handler
            Handler handler = new MyHandler();
            String registrationID = ariesAgent.registerHandler(handler, "didexchange_states");
            System.out.println("handler registration id: ", registrationID);

        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

Kotlin


import org.trustbloc.agent.sdk.api.AriesController
import org.trustbloc.agent.sdk.api.Handler
import org.trustbloc.agent.sdk.ariesagent.Ariesagent
import org.trustbloc.agent.sdk.config.Options
import java.nio.charset.StandardCharsets

class MyHandler : Handler {
    override fun handle(topic: String, message: ByteArray) {
        println("received notification topic: $topic")
        println("received notification message: " + String(message, StandardCharsets.UTF_8))
    }
}

class AriesService {
    var ariesAgent: AriesController? = null
    fun newAgentWithHandler(url: String?, websocketURL: String?, useLocalAgent: Boolean) {
        val opts = Options()
        opts.agentURL = url
        opts.websocketURL = websocketURL
        opts.useLocalAgent = useLocalAgent
        try {
            ariesAgent = Ariesagent.new_(opts)

            // register handler
            val handler: Handler = MyHandler()
            val registrationID = ariesAgent.registerHandler(handler, "didexchange_states")
            println("handler registration id: $registrationID")
        } catch (e: Exception) {
            e.printStackTrace()
        }
    }
}

3.2. iOS
a. Importing the generated binding as a framework in Xcode
  • In the menu of your Xcode project, go to File>Add Files to "your project name"....
  • In the displayed modal, navigate to the path of your AgentSDK.framework file and click Add.
b. Code sample

This is an example of how the imported framework can be used:

Objective-C

#import <AriesAgent/Ariesagent.h>
/*
...
*/
    NSError *error = nil;

    // create options
    ConfigOptions *opts = ConfigNew();
    // [opts setAgentURL:@"http://example.com"];
    [opts setUseLocalAgent:true];
    
    // create an aries agent instance
    ApiAriesController *ac = (ApiAriesController*) AriesagentNew(opts, &error);
    if(error) {
        NSLog(@"error creating an aries agent: %@", error);
    }
    
    // create a controller
    ApiVerifiableController *ic = (ApiVerifiableController*) [ac getVerifiableController:&error];
    if(error) {
        NSLog(@"error creating an verifiable controller instance: %@", error);
    }

    // perform an operation
    NSData *data = [@"" dataUsingEncoding:NSUTF8StringEncoding];
    ModelsRequestEnvelope *req = ModelsNewRequestEnvelope(data);
    ModelsResponseEnvelope *resp = [ic getCredentials:req];
    if(resp.error) {
        NSLog(@"error getting credentials: %@", resp.error.message);
    } else {
        NSString *credResp = [[NSString alloc] initWithData:resp.payload encoding:NSUTF8StringEncoding];
        NSLog(@"credentials response: %@", credResp);
    }

Swift

import AriesAgent

/*
...
*/
var error: Error? = nil

// create options
let opts = ConfigNew()
// [opts setAgentURL:@"http://example.com"];
opts?.useLocalAgent = true

// create an aries agent instance
let ac = AriesagentNew(opts, &error) as? ApiAriesController
if let error = error {
    print("error creating an aries agent: \(error)")
}

// create a controller
let ic = ac?.getVerifiableController(&error) as? ApiVerifiableController
if let error = error {
    print("error creating an verifiable controller instance: \(error)")
}

// perform an operation
let data = "".data(using: .utf8)
let req = ModelsNewRequestEnvelope(data)
let resp = ic.getCredentials(req)
if resp?.error != nil {
    if let message = resp?.error.message {
        print("error getting credentials: \(message)")
    }
} else {
    var credResp: String? = nil
    if let payload = resp?.payload {
        credResp = String(data: payload, encoding: .utf8)
    }
    print("credentials response: \(credResp ?? "")")
}

To subscribe to events on an Aries agent, implement the Handler interface and use as follows:

Objective-C


#import <AriesAgent/Ariesagent.h>

@interface MyHandler: NSObject<ApiHandler>{

}
@end

@implementation MyHandler
    
NSString *lastTopic, *lastMessage;

- (BOOL) handle: (NSString *)topic message:(NSData *)message
          error:(NSError * _Nullable __autoreleasing *)error {
    
    lastTopic = topic;
    lastMessage = [[NSString alloc] initWithData:message encoding:NSUTF8StringEncoding];
        
    return true;
}

@end

@interface AriesService()

@property NSString *urlToUse;
@property NSString *wsURLToUse;
@property BOOL useLocalAgent;
@property ApiAriesController* ariesAgent;

@end

@implementation AriesService

- (void) newAgentWithHandler {
    ConfigOptions *opts = ConfigNew();
    [opts setAgentURL:_urlToUse];
    [opts setUseLocalAgent:_useLocalAgent];
    [opts setWebsocketURL:_wsURLToUse];
    
    NSError *error = nil;
    
    _ariesAgent = (ApiAriesController*) AriesagentNew(opts, &error);
    if(error) {
        NSLog(@"error creating an aries agent: %@", error);
    }
    
    // register handler
    MyHandler *handler = [[MyHandler alloc] init];
    NSString *regID = [_ariesAgent registerHandler:handler topics:@"didexchange_states"];
    NSLog(@"handler registration id: %@", regID);
}

@end

Swift


import AriesAgent

var lastTopic: String?
    var lastMessage: String?

class MyHandler: NSObject, ApiHandler {
    func handle(
        _ topic: String?,
        message: Data?
    ) throws {

        lastTopic = topic
        if let message = message {
            lastMessage = String(data: message, encoding: .utf8)
        }

        return true
    }
}

class AriesService {
    private var urlToUse: String?
    private var wsURLToUse: String?
    private var useLocalAgent = false
    private var ariesAgent: ApiAriesController?

    func newAgentWithHandler() {
        let opts = ConfigNew()
        opts?.agentURL = urlToUse
        opts?.useLocalAgent = useLocalAgent
        opts?.websocketURL = wsURLToUse

        var error: Error? = nil

        ariesAgent = AriesagentNew(opts, &error) as? ApiAriesController
        if let error = error {
            print("error creating an aries agent: \(error)")
        }

        // register handler
        let handler = MyHandler()
        let regID = ariesAgent?.register(handler, topics: "didexchange_states")
        print("handler registration id: \(regID ?? "")")
    }
}

3.3. Demo apps

For examples of mobile apps built with the aries-agent-mobile bindings, see https://github.com/trustbloc/aries-examples.

4. Test

$ make unit-test

5. Release

TODO

6. Contribute

See the guidelines from the parent project.

Documentation

Overview

Package ariesagent represents aries agent.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func New

func New(opts *config.Options) (api.AriesController, error)

New initializes and returns an implementation of the AriesController.

Types

This section is empty.

Directories

Path Synopsis
pkg
api
Package api describes agents api.
Package api describes agents api.
wrappers/command
Package command provides commands for mobile usage.
Package command provides commands for mobile usage.
wrappers/config
Package config describes configuration options.
Package config describes configuration options.
wrappers/logger
Package logger is not expected to be used by the mobile app.
Package logger is not expected to be used by the mobile app.
wrappers/models
Package models describes models.
Package models describes models.
wrappers/notifier
Package notifier is not expected to be used by the mobile app.
Package notifier is not expected to be used by the mobile app.
wrappers/rest
Package rest represents REST API.
Package rest represents REST API.
wrappers/storage
Package storage is not expected to be used by the mobile app.
Package storage is not expected to be used by the mobile app.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL