Skip to content

Commit

Permalink
Merge pull request #79 from HHS/dev
Browse files Browse the repository at this point in the history
v5.0.0
  • Loading branch information
bischoffz authored Aug 19, 2024
2 parents cdb148e + 497df53 commit 28b80cf
Show file tree
Hide file tree
Showing 155 changed files with 7,436 additions and 6,217 deletions.
30 changes: 15 additions & 15 deletions .github/workflows/release_build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -59,51 +59,51 @@ jobs:
generateReleaseNotes: true
skipIfReleaseExists: true

update-gcm-taskit:
if: ${{ !contains(github.event.head_commit.message, 'update-util-to-') }}
update-gcm:
if: ${{ !endsWith(needs.release.outputs.taskit_version, '0') }}
needs: release
runs-on: ubuntu-latest
permissions:
contents: write
env:
VERSION: ${{ needs.release.outputs.taskit_version }}
steps:
- name: Checkout GCM Taskit
- name: Checkout GCM
uses: actions/checkout@v4
with:
repository: HHS/ASPR-ms-gcm-taskit
repository: HHS/ASPR-8
token: ${{ secrets.GHA_BOT }}

- name: Update Taskit version
- name: Update Util version
run : |
echo "$VERSION"
sed -i "0,/<taskit.version>.*<\/taskit.version>/s//<taskit.version>$VERSION<\/taskit.version>/g" pom.xml
sed -i "0,/<util.version>.*<\/util.version>/s//<util.version>$VERSION<\/util.version>/g" pom.xml
- name: Increment GCM Taskit Version
- name: Increment GCM Version
run: |
current_version=$(mvn help:evaluate -Dexpression=project.version -q -DforceStdout --file pom.xml)
echo GCM Taskit Version: $current_version
echo GCM Version: $current_version
parts=( ${current_version//./ } )
bv=$((parts[2] + 1))
new_version="${parts[0]}.${parts[1]}.${bv}"
echo New GCM Taskit Version: $new_version
echo New GCM Version: $new_version
sed -i "0,/<revision>.*<\/revision>/s//<revision>$new_version<\/revision>/g" pom.xml
- name: Setup Git
run: |
git config --global user.name "github-actions"
git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com"
- name: Make branch in GCM Taskit
- name: Make branch in GCM
run: |
git checkout -b update-taskit-to-$VERSION
git checkout -b update-util-to-$VERSION
git add pom.xml
git commit -m "Update taskit to $VERSION"
git push --set-upstream origin update-taskit-to-$VERSION
git commit -m "Update util to $VERSION"
git push --set-upstream origin update-util-to-$VERSION
- name: Make PR in GCM Taskit
- name: Make PR in GCM
run: |
gh pr create -R HHS/ASPR-ms-gcm-taskit -B main --fill
gh pr create -R HHS/ASPR-8 -B main --fill
gh pr merge -m --auto
env:
GH_TOKEN: ${{ secrets.GHA_BOT }}
33 changes: 19 additions & 14 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,24 +5,24 @@
[![GitHub Workflow Status (with event)][build-shield]][build-url]

# Translation And Serialization Toolkit
The Translation and Serialization Tookkil (Taskit) is a library that was created to faciliate converting from various input files into Java Objects. This is espcially useful for Simulation Models such as [GCM](https://github.com/HHS/ASPR-8).
The Translation and Serialization Toolkit (Taskit) is a library that was created to facilitate converting from various input files into Java Objects. This is especially useful for Simulation Models such as [GCM](https://github.com/HHS/ASPR-8).

Currently there is only 1 supported serialzation format, and that is protobuf. Other formats such as binary will follow in the future.
Currently there is only 1 supported serialization format, and that is protobuf. Other formats such as binary will follow in the future.

As of v3.2.0, this project is in Maven Central.

## License
Distributed under the GPLv3 License. See [LICENSE](LICENSE) for more information.

Please read the [HHS vulnerability discloure](https://www.hhs.gov/vulnerability-disclosure-policy/index.html).
Please read the [HHS vulnerability disclosure](https://www.hhs.gov/vulnerability-disclosure-policy/index.html).

## Usage
To use this project in your project, simply add the following dependency to your `dependencies` section of your pom.xml file.
```
<dependency>
<groupId>gov.hhs.aspr.ms.taskit</groupId>
<artifactId>core</artifactId>
<version>4.0.0</version>
<version>5.0.0</version>
</dependency>
```

Expand All @@ -31,29 +31,34 @@ To use the protobuf library of taskit, simply add the following dependency to yo
<dependency>
<groupId>gov.hhs.aspr.ms.taskit</groupId>
<artifactId>protobuf</artifactId>
<version>4.0.0</version>
<version>5.0.0</version>
</dependency>
```

## Overview
Currently Taskit is composed of a Core library and a Protobuf library.

### Core
[Core](core) is the base taskit engine and contains the root level functionality that drives the translation and serialization.
This library contains the base TranslationController class, the base TranslationSpec class and the base TranslationEngine class.

#### TranslationController
The TranslationController class handles the delgation of reading/writing from/to input/output files.
[Core](core) contains TranslationSpec, TaskitEngine, TaskitEngineId, TaskitEngineManager, and Translator. These classes define the root level functionality of Taskit.

#### TranslationSpec
The TranslationSpec class is an abstract class that must be impleneted to define how to convert between two Java Types, generally the input Java type and the application Java Type.
An abstract class that defines how to translate between two different Java Types. Implementers of this class must define the intricate details on the translation, while the abstract class strictly handles initialization and determining which internal translate method to call based on the given object that needs to be translated.

#### TaskitEngine
An abstract class that contains a mapping of classes to TranslationSpecs. It has the sole responsibility of translating/reading/writing. For translating, it will determine which TranslationSpec to use based on the class of the given object to translate. Implementers of this class must define how to read/write files, as that process can vary between serialization libraries.

#### TaskitEngineId
An identifier for a TaskitEngine, for use in the TaskitEngineManager.

#### TaskitEngineManager
The TaskitEngineManager can handle multiple TaskitEngines and allows the user to read/write/translate using the TaskitEngineId to determine which TaskitEngine to use. Contains the same methods as TaskitEngine, with an additional parameter for the TaskitEngineId.

#### TranslationEngine
The TranslationEngine class delgates the converting of one type to another via TranslationSpecs as well as doing the actual reading/writing as delegated by the TranslationController.
#### Translator
A Translator is simply a class that can wrap a group of TranslationSpecs that should/will often be used together. It also contains a dependency mechanism that allows for Translators to depend on other Translators, which is useful if a given TranslationSpec requires another TranslationSpec that is not provided by the encompassing Translator. Translators must follow a DAG pattern; there cannot be duplicate Translators, missing Translators nor cyclic Translator dependencies.

### Protobuf
[Protobuf](protobuf) is a version of taskit made specifically to be used with protobuf.
This library builds on the Core library described above and adds a distinct TranslationEngine and TranslationSpecs needed to fully support protobuf.
This library builds on the Core library described above and adds a distinct TaskitEngine and TranslationSpecs needed to fully support protobuf.

#### Supported types
This library supports the following proto message types:
Expand Down
1 change: 0 additions & 1 deletion core/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@
</parent>

<!-- Artifact -->
<groupId>gov.hhs.aspr.ms.taskit</groupId>
<artifactId>core</artifactId>
<packaging>jar</packaging>

Expand Down

This file was deleted.

This file was deleted.

Loading

0 comments on commit 28b80cf

Please sign in to comment.