undercarriage grpc

null

License

License

Categories

Categories

gRPC Net Networking
GroupId

GroupId

org.joeyb.undercarriage
ArtifactId

ArtifactId

grpc
Last Version

Last Version

1.3.3
Release Date

Release Date

Type

Type

jar
Description

Description

undercarriage grpc
null
Project URL

Project URL

https://github.com/joeyb/undercarriage
Source Code Management

Source Code Management

https://github.com/joeyb/undercarriage

Download grpc

How to add to project

<!-- https://jarcasting.com/artifacts/org.joeyb.undercarriage/grpc/ -->
<dependency>
    <groupId>org.joeyb.undercarriage</groupId>
    <artifactId>grpc</artifactId>
    <version>1.3.3</version>
</dependency>
// https://jarcasting.com/artifacts/org.joeyb.undercarriage/grpc/
implementation 'org.joeyb.undercarriage:grpc:1.3.3'
// https://jarcasting.com/artifacts/org.joeyb.undercarriage/grpc/
implementation ("org.joeyb.undercarriage:grpc:1.3.3")
'org.joeyb.undercarriage:grpc:jar:1.3.3'
<dependency org="org.joeyb.undercarriage" name="grpc" rev="1.3.3">
  <artifact name="grpc" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.joeyb.undercarriage', module='grpc', version='1.3.3')
)
libraryDependencies += "org.joeyb.undercarriage" % "grpc" % "1.3.3"
[org.joeyb.undercarriage/grpc "1.3.3"]

Dependencies

compile (5)

Group / Artifact Type Version
io.grpc : grpc-stub jar 1.1.1
io.grpc : grpc-netty jar 1.1.1
org.joeyb.undercarriage : core jar 1.3.3
io.grpc : grpc-protobuf jar 1.1.1
javax.inject : javax.inject jar 1

provided (1)

Group / Artifact Type Version
org.immutables : value jar 2.4.2

test (3)

Group / Artifact Type Version
org.mockito : mockito-core jar 2.7.1
junit : junit jar 4.12
org.assertj : assertj-core jar 3.6.2

Project Modules

There are no modules declared in this project.

undercarriage

Build Status codecov Maven Central

undercarriage is a general-purpose Java application framework. The project's main design goals are:

  • Testability - Aim for near 100% branch coverage with fast and accurate tests.
  • Extensibility - Where possible, provide extension points for swapping out interface implementations and hooking into the application's lifecycle. This is mainly accomplished via Dependency Injection and the plugin infrastructure.
  • Documentation - All public and protected APIs should be thoroughly documented. Each library should have higher-level usage docs and each application type should have end-to-end tutorial-style docs.
  • Modern Tooling - Take advantage of the latest features provided by Java 8 and modern libraries. Prefer modern best practices with newer libraries over legacy code to support older (but maybe more popular) libraries.
  • DI Framework Agnostic - The core code should never be tied to a particular dependency injection framework. It uses the JSR-330 annotations where needed. The framework is designed so that it will play nicely with a compile-time DI framework like Dagger 2.

There is a cost to being DI framework agnostic. JSR-330 does not currently standardize dependency configuration, so we don't currently provide a way for base application types or plugins to automatically register the dependencies that they provide. This means that you'll need to manually setup the full DI configuration for your particular framework. The documentation for each base application type and each plugin will define their required dependencies.

The core library provides the foundational framework for building an application.

To see some real examples, check out the examples directory.

Libraries

Library Package
config-yaml "org.joeyb.undercarriage:config-yaml:$undercarriageVersion"
core "org.joeyb.undercarriage:core:$undercarriageVersion"
grpc "org.joeyb.undercarriage:grpc:$undercarriageVersion"
jersey "org.joeyb.undercarriage:jersey:$undercarriageVersion"
spark "org.joeyb.undercarriage:spark:$undercarriageVersion"

Versions

Version
1.3.3
1.3.2
1.3.1
1.3.0
1.1.1
1.1.0
1.0.0