-
Notifications
You must be signed in to change notification settings - Fork 4.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
bridge: add register string accessor functionality plus expose on And…
…roid (#1188) Description: this PR adds the ability to register string accessors from the platform to the engine. This allows the core layer to access strings from the platform at runtime. Two highlights: Eventually this mechanism should be made generic to be able to access and set arbitrary types from the platform. This is very type-specific as a POC. #1192 This PR only wires up Android's platform layer all the way. A subsequent PR will do the same for iOS. Risk Level: low - new API Testing: using the example app. Signed-off-by: Jose Nino <jnino@lyft.com> Signed-off-by: JP Simard <jp@jpsim.com>
- Loading branch information
Showing
20 changed files
with
187 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
package io.envoyproxy.envoymobile.helloenvoykotlin | ||
|
||
import io.envoyproxy.envoymobile.engine.types.EnvoyStringAccessor | ||
import java.nio.ByteBuffer | ||
|
||
class DemoStringAccessor : EnvoyStringAccessor { | ||
override fun getString(): ByteBuffer { | ||
return ByteBuffer.wrap("PlatformString".toByteArray(Charsets.UTF_8)) | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
#pragma once | ||
|
||
#include "library/common/types/c_types.h" | ||
|
||
// NOLINT(namespace-envoy) | ||
|
||
#ifdef __cplusplus | ||
extern "C" { // function pointers | ||
#endif | ||
|
||
typedef envoy_data (*envoy_get_string_f)(void* context); | ||
|
||
#ifdef __cplusplus | ||
} // function pointers | ||
#endif | ||
|
||
/** | ||
* Datatype used to access strings from the platform layer. This accessor is read-only. | ||
*/ | ||
// TODO: https://github.com/envoyproxy/envoy-mobile/issues/1192 generalize to access arbitrary | ||
// types. | ||
typedef struct { | ||
envoy_get_string_f get_string; | ||
void* context; | ||
} envoy_string_accessor; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
18 changes: 18 additions & 0 deletions
18
mobile/library/java/src/io/envoyproxy/envoymobile/engine/JvmStringAccessorContext.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
package io.envoyproxy.envoymobile.engine; | ||
|
||
import java.nio.ByteBuffer; | ||
|
||
import io.envoyproxy.envoymobile.engine.types.EnvoyStringAccessor; | ||
|
||
class JvmStringAccessorContext { | ||
private final EnvoyStringAccessor accessor; | ||
|
||
public JvmStringAccessorContext(EnvoyStringAccessor accessor) { this.accessor = accessor; } | ||
|
||
/** | ||
* Invokes getString callback. | ||
* | ||
* @return ByteBuffer, the string retrieved from the platform. | ||
*/ | ||
public ByteBuffer getString() { return accessor.getString(); } | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
11 changes: 11 additions & 0 deletions
11
mobile/library/java/src/io/envoyproxy/envoymobile/engine/types/EnvoyStringAccessor.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
package io.envoyproxy.envoymobile.engine.types; | ||
|
||
import java.nio.ByteBuffer; | ||
|
||
public interface EnvoyStringAccessor { | ||
|
||
/** | ||
* Called to retrieve a string from the Application | ||
*/ | ||
ByteBuffer getString(); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.