├── .github
├── ISSUE_TEMPLATE.md
└── PULL_REQUEST_TEMPLATE.md
├── .gitignore
├── .mvn
└── wrapper
│ ├── MavenWrapperDownloader.java
│ └── maven-wrapper.properties
├── CODE_OF_CONDUCT.md
├── LICENSE
├── README.md
├── contributing.adoc
├── install.gif
├── java.gif
├── key.png
├── mvnw
├── mvnw.cmd
├── pom.xml
└── src
├── main
├── java
│ └── com
│ │ └── modzy
│ │ └── sdk
│ │ ├── JobClient.java
│ │ ├── ModelClient.java
│ │ ├── ModzyClient.java
│ │ ├── ResultClient.java
│ │ ├── TagClient.java
│ │ ├── dto
│ │ ├── EmbeddedData.java
│ │ ├── JobHistoryResponseWrapper.java
│ │ ├── JobHistorySearchParams.java
│ │ ├── JobHistorySearchStatus.java
│ │ ├── ModelSearchParams.java
│ │ ├── Pagination.java
│ │ ├── S3FileRef.java
│ │ └── TagWrapper.java
│ │ ├── exception
│ │ └── ApiException.java
│ │ ├── filter
│ │ └── LoggingFilter.java
│ │ ├── model
│ │ ├── ContainerImage.java
│ │ ├── Feature.java
│ │ ├── Image.java
│ │ ├── Job.java
│ │ ├── JobInput.java
│ │ ├── JobInputEmbedded.java
│ │ ├── JobInputJDBC.java
│ │ ├── JobInputS3.java
│ │ ├── JobInputStream.java
│ │ ├── JobInputText.java
│ │ ├── JobOutput.java
│ │ ├── JobOutputJSON.java
│ │ ├── JobStatus.java
│ │ ├── Model.java
│ │ ├── ModelInput.java
│ │ ├── ModelOutput.java
│ │ ├── ModelTimeout.java
│ │ ├── ModelVersion.java
│ │ ├── Requirement.java
│ │ ├── Statistic.java
│ │ ├── Tag.java
│ │ └── Team.java
│ │ ├── samples
│ │ ├── JobAwsInputSample.java
│ │ ├── JobEmbeddedInputSample.java
│ │ ├── JobFileInputSample.java
│ │ ├── JobTextInputSample.java
│ │ └── ModelSamples.java
│ │ └── util
│ │ ├── DataSize.java
│ │ ├── EmbeddedSerializer.java
│ │ ├── FileUtils.java
│ │ └── LoggerFactory.java
└── resources
│ ├── logging.properties
│ └── samples
│ ├── config.json
│ └── image.png
└── test
├── java
└── com
│ └── modzy
│ └── sdk
│ ├── TestJobClient.java
│ ├── TestModelClient.java
│ ├── TestModzyClient.java
│ ├── TestResultClient.java
│ └── TestTagClient.java
└── resources
├── images
└── example_1.jpg
└── logging.properties
/.github/ISSUE_TEMPLATE.md:
--------------------------------------------------------------------------------
1 | ## Checklist
2 |
3 | Please review first that the issue is fully related with this SDK by checking the relevant checkboxes (`[x]`).
4 |
5 | - [ ] I have a Modzy API Key active and have the entitlements to perform the desired action.
6 | - [ ] I review that have access to Modzy API host.
7 | - [ ] I think that is a error specific to the SDK.
8 | - [ ] I review the documentation and existing issues in order to not duplicate existing ones.
9 | - [ ] I am willing to follow-up on comments in a timely manner.
10 |
11 | ### Info
12 |
13 | * Modzy SDK version:
14 | * Java version:
15 | * Operating System:
16 |
17 | ### Description
18 |
19 |
20 |
21 | ### Steps to reproduce
22 |
23 |
24 |
25 | ```
26 | Paste the command(s) you ran and the output.
27 | ```
28 |
29 | **Expected results:**
30 |
31 | **Actual results:**
32 |
33 | ### Traceback
34 |
35 |
36 | Logs
37 |
42 |
43 | ```
44 | Paste the logs that you consider useful for diagnostic.
45 | ```
46 |
47 |
--------------------------------------------------------------------------------
/.github/PULL_REQUEST_TEMPLATE.md:
--------------------------------------------------------------------------------
1 | ## Description
2 |
3 |
4 |
5 | ## Related issues
6 |
7 |
8 |
9 | ## Tests
10 |
11 |
12 |
13 | ## Checklist
14 |
15 | - [ ] I read the Contributing guide.
16 | - [ ] I update the documentation and if the case the README.md file.
17 | - [ ] I am willing to follow-up on review comments in a timely manner.
18 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | .metadata
2 | bin/
3 | tmp/
4 | *.tmp
5 | *.bak
6 | *.swp
7 | *~.nib
8 | local.properties
9 | .settings/
10 | .idea/
11 | modzy-sdk.iml
12 | .loadpath
13 | .recommenders
14 | .env
15 | docs
16 | # External tool builders
17 | .externalToolBuilders/
18 |
19 | # Locally stored "Eclipse launch configurations"
20 | *.launch
21 |
22 | # PyDev specific (Python IDE for Eclipse)
23 | *.pydevproject
24 |
25 | # CDT-specific (C/C++ Development Tooling)
26 | .cproject
27 |
28 | # CDT- autotools
29 | .autotools
30 |
31 | # Java annotation processor (APT)
32 | .factorypath
33 |
34 | # PDT-specific (PHP Development Tools)
35 | .buildpath
36 |
37 | # sbteclipse plugin
38 | .target
39 |
40 | # Tern plugin
41 | .tern-project
42 |
43 | # TeXlipse plugin
44 | .texlipse
45 |
46 | # STS (Spring Tool Suite)
47 | .springBeans
48 |
49 | # Code Recommenders
50 | .recommenders/
51 |
52 | # Annotation Processing
53 | .apt_generated/
54 |
55 | # Scala IDE specific (Scala & Java development for Eclipse)
56 | .cache-main
57 | .scala_dependencies
58 | .worksheet
59 |
60 | ### Eclipse Patch ###
61 | # Eclipse Core
62 | .project
63 |
64 | # JDT-specific (Eclipse Java Development Tools)
65 | .classpath
66 |
67 | # Annotation Processing
68 | .apt_generated
69 |
70 | .sts4-cache/
71 |
72 | ### Git ###
73 | # Created by git for backups. To disable backups in Git:
74 | # $ git config --global mergetool.keepBackup false
75 | *.orig
76 |
77 | # Created by git when using merge tools for conflicts
78 | *.BACKUP.*
79 | *.BASE.*
80 | *.LOCAL.*
81 | *.REMOTE.*
82 | *_BACKUP_*.txt
83 | *_BASE_*.txt
84 | *_LOCAL_*.txt
85 | *_REMOTE_*.txt
86 |
87 | ### Java ###
88 | # Compiled class file
89 | *.class
90 |
91 | # Log file
92 | *.log
93 |
94 | # BlueJ files
95 | *.ctxt
96 |
97 | # Mobile Tools for Java (J2ME)
98 | .mtj.tmp/
99 |
100 | # Package Files #
101 | *.jar
102 | *.war
103 | *.nar
104 | *.ear
105 | *.zip
106 | *.tar.gz
107 | *.rar
108 |
109 | # virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml
110 | hs_err_pid*
111 |
112 | ### Maven ###
113 | target/
114 | pom.xml.tag
115 | pom.xml.releaseBackup
116 | pom.xml.versionsBackup
117 | pom.xml.next
118 | release.properties
119 | dependency-reduced-pom.xml
120 | buildNumber.properties
121 | .mvn/timing.properties
122 | .mvn/wrapper/maven-wrapper.jar
123 | .flattened-pom.xml
124 |
125 | ### Windows ###
126 | # Windows thumbnail cache files
127 | Thumbs.db
128 | Thumbs.db:encryptable
129 | ehthumbs.db
130 | ehthumbs_vista.db
131 |
132 | # Dump file
133 | *.stackdump
134 |
135 | # Folder config file
136 | [Dd]esktop.ini
137 |
138 | # Recycle Bin used on file shares
139 | $RECYCLE.BIN/
140 |
141 | # Windows Installer files
142 | *.cab
143 | *.msi
144 | *.msix
145 | *.msm
146 | *.msp
147 |
148 | # Windows shortcuts
149 | *.lnk
150 |
--------------------------------------------------------------------------------
/.mvn/wrapper/MavenWrapperDownloader.java:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright 2007-present the original author or authors.
3 | *
4 | * Licensed under the Apache License, Version 2.0 (the "License");
5 | * you may not use this file except in compliance with the License.
6 | * You may obtain a copy of the License at
7 | *
8 | * http://www.apache.org/licenses/LICENSE-2.0
9 | *
10 | * Unless required by applicable law or agreed to in writing, software
11 | * distributed under the License is distributed on an "AS IS" BASIS,
12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 | * See the License for the specific language governing permissions and
14 | * limitations under the License.
15 | */
16 | import java.net.*;
17 | import java.io.*;
18 | import java.nio.channels.*;
19 | import java.util.Properties;
20 |
21 | public class MavenWrapperDownloader {
22 |
23 | private static final String WRAPPER_VERSION = "0.5.6";
24 | /**
25 | * Default URL to download the maven-wrapper.jar from, if no 'downloadUrl' is provided.
26 | */
27 | private static final String DEFAULT_DOWNLOAD_URL = "https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/"
28 | + WRAPPER_VERSION + "/maven-wrapper-" + WRAPPER_VERSION + ".jar";
29 |
30 | /**
31 | * Path to the maven-wrapper.properties file, which might contain a downloadUrl property to
32 | * use instead of the default one.
33 | */
34 | private static final String MAVEN_WRAPPER_PROPERTIES_PATH =
35 | ".mvn/wrapper/maven-wrapper.properties";
36 |
37 | /**
38 | * Path where the maven-wrapper.jar will be saved to.
39 | */
40 | private static final String MAVEN_WRAPPER_JAR_PATH =
41 | ".mvn/wrapper/maven-wrapper.jar";
42 |
43 | /**
44 | * Name of the property which should be used to override the default download url for the wrapper.
45 | */
46 | private static final String PROPERTY_NAME_WRAPPER_URL = "wrapperUrl";
47 |
48 | public static void main(String args[]) {
49 | System.out.println("- Downloader started");
50 | File baseDirectory = new File(args[0]);
51 | System.out.println("- Using base directory: " + baseDirectory.getAbsolutePath());
52 |
53 | // If the maven-wrapper.properties exists, read it and check if it contains a custom
54 | // wrapperUrl parameter.
55 | File mavenWrapperPropertyFile = new File(baseDirectory, MAVEN_WRAPPER_PROPERTIES_PATH);
56 | String url = DEFAULT_DOWNLOAD_URL;
57 | if(mavenWrapperPropertyFile.exists()) {
58 | FileInputStream mavenWrapperPropertyFileInputStream = null;
59 | try {
60 | mavenWrapperPropertyFileInputStream = new FileInputStream(mavenWrapperPropertyFile);
61 | Properties mavenWrapperProperties = new Properties();
62 | mavenWrapperProperties.load(mavenWrapperPropertyFileInputStream);
63 | url = mavenWrapperProperties.getProperty(PROPERTY_NAME_WRAPPER_URL, url);
64 | } catch (IOException e) {
65 | System.out.println("- ERROR loading '" + MAVEN_WRAPPER_PROPERTIES_PATH + "'");
66 | } finally {
67 | try {
68 | if(mavenWrapperPropertyFileInputStream != null) {
69 | mavenWrapperPropertyFileInputStream.close();
70 | }
71 | } catch (IOException e) {
72 | // Ignore ...
73 | }
74 | }
75 | }
76 | System.out.println("- Downloading from: " + url);
77 |
78 | File outputFile = new File(baseDirectory.getAbsolutePath(), MAVEN_WRAPPER_JAR_PATH);
79 | if(!outputFile.getParentFile().exists()) {
80 | if(!outputFile.getParentFile().mkdirs()) {
81 | System.out.println(
82 | "- ERROR creating output directory '" + outputFile.getParentFile().getAbsolutePath() + "'");
83 | }
84 | }
85 | System.out.println("- Downloading to: " + outputFile.getAbsolutePath());
86 | try {
87 | downloadFileFromURL(url, outputFile);
88 | System.out.println("Done");
89 | System.exit(0);
90 | } catch (Throwable e) {
91 | System.out.println("- Error downloading");
92 | e.printStackTrace();
93 | System.exit(1);
94 | }
95 | }
96 |
97 | private static void downloadFileFromURL(String urlString, File destination) throws Exception {
98 | if (System.getenv("MVNW_USERNAME") != null && System.getenv("MVNW_PASSWORD") != null) {
99 | String username = System.getenv("MVNW_USERNAME");
100 | char[] password = System.getenv("MVNW_PASSWORD").toCharArray();
101 | Authenticator.setDefault(new Authenticator() {
102 | @Override
103 | protected PasswordAuthentication getPasswordAuthentication() {
104 | return new PasswordAuthentication(username, password);
105 | }
106 | });
107 | }
108 | URL website = new URL(urlString);
109 | ReadableByteChannel rbc;
110 | rbc = Channels.newChannel(website.openStream());
111 | FileOutputStream fos = new FileOutputStream(destination);
112 | fos.getChannel().transferFrom(rbc, 0, Long.MAX_VALUE);
113 | fos.close();
114 | rbc.close();
115 | }
116 |
117 | }
118 |
--------------------------------------------------------------------------------
/.mvn/wrapper/maven-wrapper.properties:
--------------------------------------------------------------------------------
1 | distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.6.3/apache-maven-3.6.3-bin.zip
2 | wrapperUrl=https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar
3 |
--------------------------------------------------------------------------------
/CODE_OF_CONDUCT.md:
--------------------------------------------------------------------------------
1 |
2 | # Contributor Covenant Code of Conduct
3 |
4 | ## Our Pledge
5 |
6 | We as members, contributors, and leaders pledge to make participation in our
7 | community a harassment-free experience for everyone, regardless of age, body
8 | size, visible or invisible disability, ethnicity, sex characteristics, gender
9 | identity and expression, level of experience, education, socio-economic status,
10 | nationality, personal appearance, race, religion, or sexual identity
11 | and orientation.
12 |
13 | We pledge to act and interact in ways that contribute to an open, welcoming,
14 | diverse, inclusive, and healthy community.
15 |
16 | ## Our Standards
17 |
18 | Examples of behavior that contributes to a positive environment for our
19 | community include:
20 |
21 | * Demonstrating empathy and kindness toward other people
22 | * Being respectful of differing opinions, viewpoints, and experiences
23 | * Giving and gracefully accepting constructive feedback
24 | * Accepting responsibility and apologizing to those affected by our mistakes,
25 | and learning from the experience
26 | * Focusing on what is best not just for us as individuals, but for the
27 | overall community
28 |
29 | Examples of unacceptable behavior include:
30 |
31 | * The use of sexualized language or imagery, and sexual attention or
32 | advances of any kind
33 | * Trolling, insulting or derogatory comments, and personal or political attacks
34 | * Public or private harassment
35 | * Publishing others' private information, such as a physical or email
36 | address, without their explicit permission
37 | * Other conduct which could reasonably be considered inappropriate in a
38 | professional setting
39 |
40 | ## Enforcement Responsibilities
41 |
42 | Community leaders are responsible for clarifying and enforcing our standards of
43 | acceptable behavior and will take appropriate and fair corrective action in
44 | response to any behavior that they deem inappropriate, threatening, offensive,
45 | or harmful.
46 |
47 | Community leaders have the right and responsibility to remove, edit, or reject
48 | comments, commits, code, wiki edits, issues, and other contributions that are
49 | not aligned to this Code of Conduct, and will communicate reasons for moderation
50 | decisions when appropriate.
51 |
52 | ## Scope
53 |
54 | This Code of Conduct applies within all community spaces, and also applies when
55 | an individual is officially representing the community in public spaces.
56 | Examples of representing our community include using an official e-mail address,
57 | posting via an official social media account, or acting as an appointed
58 | representative at an online or offline event.
59 |
60 | ## Enforcement
61 |
62 | Instances of abusive, harassing, or otherwise unacceptable behavior may be
63 | reported to the community leaders responsible for enforcement at
64 | [INSERT CONTACT METHOD].
65 | All complaints will be reviewed and investigated promptly and fairly.
66 |
67 | All community leaders are obligated to respect the privacy and security of the
68 | reporter of any incident.
69 |
70 | ## Enforcement Guidelines
71 |
72 | Community leaders will follow these Community Impact Guidelines in determining
73 | the consequences for any action they deem in violation of this Code of Conduct:
74 |
75 | ### 1. Correction
76 |
77 | **Community Impact**: Use of inappropriate language or other behavior deemed
78 | unprofessional or unwelcome in the community.
79 |
80 | **Consequence**: A private, written warning from community leaders, providing
81 | clarity around the nature of the violation and an explanation of why the
82 | behavior was inappropriate. A public apology may be requested.
83 |
84 | ### 2. Warning
85 |
86 | **Community Impact**: A violation through a single incident or series
87 | of actions.
88 |
89 | **Consequence**: A warning with consequences for continued behavior. No
90 | interaction with the people involved, including unsolicited interaction with
91 | those enforcing the Code of Conduct, for a specified period of time. This
92 | includes avoiding interactions in community spaces as well as external channels
93 | like social media. Violating these terms may lead to a temporary or
94 | permanent ban.
95 |
96 | ### 3. Temporary Ban
97 |
98 | **Community Impact**: A serious violation of community standards, including
99 | sustained inappropriate behavior.
100 |
101 | **Consequence**: A temporary ban from any sort of interaction or public
102 | communication with the community for a specified period of time. No public or
103 | private interaction with the people involved, including unsolicited interaction
104 | with those enforcing the Code of Conduct, is allowed during this period.
105 | Violating these terms may lead to a permanent ban.
106 |
107 | ### 4. Permanent Ban
108 |
109 | **Community Impact**: Demonstrating a pattern of violation of community
110 | standards, including sustained inappropriate behavior, harassment of an
111 | individual, or aggression toward or disparagement of classes of individuals.
112 |
113 | **Consequence**: A permanent ban from any sort of public interaction within
114 | the community.
115 |
116 | ## Attribution
117 |
118 | This Code of Conduct is adapted from the [Contributor Covenant][homepage],
119 | version 2.0, available at
120 | https://www.contributor-covenant.org/version/2/0/code_of_conduct.html.
121 |
122 | Community Impact Guidelines were inspired by [Mozilla's code of conduct
123 | enforcement ladder](https://github.com/mozilla/diversity).
124 |
125 | [homepage]: https://www.contributor-covenant.org
126 |
127 | For answers to common questions about this code of conduct, see the FAQ at
128 | https://www.contributor-covenant.org/faq. Translations are available at
129 | https://www.contributor-covenant.org/translations.
130 |
131 |
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | Apache License
2 | Version 2.0, January 2004
3 | http://www.apache.org/licenses/
4 |
5 | TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
6 |
7 | 1. Definitions.
8 |
9 | "License" shall mean the terms and conditions for use, reproduction,
10 | and distribution as defined by Sections 1 through 9 of this document.
11 |
12 | "Licensor" shall mean the copyright owner or entity authorized by
13 | the copyright owner that is granting the License.
14 |
15 | "Legal Entity" shall mean the union of the acting entity and all
16 | other entities that control, are controlled by, or are under common
17 | control with that entity. For the purposes of this definition,
18 | "control" means (i) the power, direct or indirect, to cause the
19 | direction or management of such entity, whether by contract or
20 | otherwise, or (ii) ownership of fifty percent (50%) or more of the
21 | outstanding shares, or (iii) beneficial ownership of such entity.
22 |
23 | "You" (or "Your") shall mean an individual or Legal Entity
24 | exercising permissions granted by this License.
25 |
26 | "Source" form shall mean the preferred form for making modifications,
27 | including but not limited to software source code, documentation
28 | source, and configuration files.
29 |
30 | "Object" form shall mean any form resulting from mechanical
31 | transformation or translation of a Source form, including but
32 | not limited to compiled object code, generated documentation,
33 | and conversions to other media types.
34 |
35 | "Work" shall mean the work of authorship, whether in Source or
36 | Object form, made available under the License, as indicated by a
37 | copyright notice that is included in or attached to the work
38 | (an example is provided in the Appendix below).
39 |
40 | "Derivative Works" shall mean any work, whether in Source or Object
41 | form, that is based on (or derived from) the Work and for which the
42 | editorial revisions, annotations, elaborations, or other modifications
43 | represent, as a whole, an original work of authorship. For the purposes
44 | of this License, Derivative Works shall not include works that remain
45 | separable from, or merely link (or bind by name) to the interfaces of,
46 | the Work and Derivative Works thereof.
47 |
48 | "Contribution" shall mean any work of authorship, including
49 | the original version of the Work and any modifications or additions
50 | to that Work or Derivative Works thereof, that is intentionally
51 | submitted to Licensor for inclusion in the Work by the copyright owner
52 | or by an individual or Legal Entity authorized to submit on behalf of
53 | the copyright owner. For the purposes of this definition, "submitted"
54 | means any form of electronic, verbal, or written communication sent
55 | to the Licensor or its representatives, including but not limited to
56 | communication on electronic mailing lists, source code control systems,
57 | and issue tracking systems that are managed by, or on behalf of, the
58 | Licensor for the purpose of discussing and improving the Work, but
59 | excluding communication that is conspicuously marked or otherwise
60 | designated in writing by the copyright owner as "Not a Contribution."
61 |
62 | "Contributor" shall mean Licensor and any individual or Legal Entity
63 | on behalf of whom a Contribution has been received by Licensor and
64 | subsequently incorporated within the Work.
65 |
66 | 2. Grant of Copyright License. Subject to the terms and conditions of
67 | this License, each Contributor hereby grants to You a perpetual,
68 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable
69 | copyright license to reproduce, prepare Derivative Works of,
70 | publicly display, publicly perform, sublicense, and distribute the
71 | Work and such Derivative Works in Source or Object form.
72 |
73 | 3. Grant of Patent License. Subject to the terms and conditions of
74 | this License, each Contributor hereby grants to You a perpetual,
75 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable
76 | (except as stated in this section) patent license to make, have made,
77 | use, offer to sell, sell, import, and otherwise transfer the Work,
78 | where such license applies only to those patent claims licensable
79 | by such Contributor that are necessarily infringed by their
80 | Contribution(s) alone or by combination of their Contribution(s)
81 | with the Work to which such Contribution(s) was submitted. If You
82 | institute patent litigation against any entity (including a
83 | cross-claim or counterclaim in a lawsuit) alleging that the Work
84 | or a Contribution incorporated within the Work constitutes direct
85 | or contributory patent infringement, then any patent licenses
86 | granted to You under this License for that Work shall terminate
87 | as of the date such litigation is filed.
88 |
89 | 4. Redistribution. You may reproduce and distribute copies of the
90 | Work or Derivative Works thereof in any medium, with or without
91 | modifications, and in Source or Object form, provided that You
92 | meet the following conditions:
93 |
94 | (a) You must give any other recipients of the Work or
95 | Derivative Works a copy of this License; and
96 |
97 | (b) You must cause any modified files to carry prominent notices
98 | stating that You changed the files; and
99 |
100 | (c) You must retain, in the Source form of any Derivative Works
101 | that You distribute, all copyright, patent, trademark, and
102 | attribution notices from the Source form of the Work,
103 | excluding those notices that do not pertain to any part of
104 | the Derivative Works; and
105 |
106 | (d) If the Work includes a "NOTICE" text file as part of its
107 | distribution, then any Derivative Works that You distribute must
108 | include a readable copy of the attribution notices contained
109 | within such NOTICE file, excluding those notices that do not
110 | pertain to any part of the Derivative Works, in at least one
111 | of the following places: within a NOTICE text file distributed
112 | as part of the Derivative Works; within the Source form or
113 | documentation, if provided along with the Derivative Works; or,
114 | within a display generated by the Derivative Works, if and
115 | wherever such third-party notices normally appear. The contents
116 | of the NOTICE file are for informational purposes only and
117 | do not modify the License. You may add Your own attribution
118 | notices within Derivative Works that You distribute, alongside
119 | or as an addendum to the NOTICE text from the Work, provided
120 | that such additional attribution notices cannot be construed
121 | as modifying the License.
122 |
123 | You may add Your own copyright statement to Your modifications and
124 | may provide additional or different license terms and conditions
125 | for use, reproduction, or distribution of Your modifications, or
126 | for any such Derivative Works as a whole, provided Your use,
127 | reproduction, and distribution of the Work otherwise complies with
128 | the conditions stated in this License.
129 |
130 | 5. Submission of Contributions. Unless You explicitly state otherwise,
131 | any Contribution intentionally submitted for inclusion in the Work
132 | by You to the Licensor shall be under the terms and conditions of
133 | this License, without any additional terms or conditions.
134 | Notwithstanding the above, nothing herein shall supersede or modify
135 | the terms of any separate license agreement you may have executed
136 | with Licensor regarding such Contributions.
137 |
138 | 6. Trademarks. This License does not grant permission to use the trade
139 | names, trademarks, service marks, or product names of the Licensor,
140 | except as required for reasonable and customary use in describing the
141 | origin of the Work and reproducing the content of the NOTICE file.
142 |
143 | 7. Disclaimer of Warranty. Unless required by applicable law or
144 | agreed to in writing, Licensor provides the Work (and each
145 | Contributor provides its Contributions) on an "AS IS" BASIS,
146 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
147 | implied, including, without limitation, any warranties or conditions
148 | of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
149 | PARTICULAR PURPOSE. You are solely responsible for determining the
150 | appropriateness of using or redistributing the Work and assume any
151 | risks associated with Your exercise of permissions under this License.
152 |
153 | 8. Limitation of Liability. In no event and under no legal theory,
154 | whether in tort (including negligence), contract, or otherwise,
155 | unless required by applicable law (such as deliberate and grossly
156 | negligent acts) or agreed to in writing, shall any Contributor be
157 | liable to You for damages, including any direct, indirect, special,
158 | incidental, or consequential damages of any character arising as a
159 | result of this License or out of the use or inability to use the
160 | Work (including but not limited to damages for loss of goodwill,
161 | work stoppage, computer failure or malfunction, or any and all
162 | other commercial damages or losses), even if such Contributor
163 | has been advised of the possibility of such damages.
164 |
165 | 9. Accepting Warranty or Additional Liability. While redistributing
166 | the Work or Derivative Works thereof, You may choose to offer,
167 | and charge a fee for, acceptance of support, warranty, indemnity,
168 | or other liability obligations and/or rights consistent with this
169 | License. However, in accepting such obligations, You may act only
170 | on Your own behalf and on Your sole responsibility, not on behalf
171 | of any other Contributor, and only if You agree to indemnify,
172 | defend, and hold each Contributor harmless for any liability
173 | incurred by, or claims asserted against, such Contributor by reason
174 | of your accepting any such warranty or additional liability.
175 |
176 | END OF TERMS AND CONDITIONS
177 |
178 | APPENDIX: How to apply the Apache License to your work.
179 |
180 | To apply the Apache License to your work, attach the following
181 | boilerplate notice, with the fields enclosed by brackets "[]"
182 | replaced with your own identifying information. (Don't include
183 | the brackets!) The text should be enclosed in the appropriate
184 | comment syntax for the file format. We also recommend that a
185 | file or class name and description of purpose be included on the
186 | same "printed page" as the copyright notice for easier
187 | identification within third-party archives.
188 |
189 | Copyright [yyyy] [name of copyright owner]
190 |
191 | Licensed under the Apache License, Version 2.0 (the "License");
192 | you may not use this file except in compliance with the License.
193 | You may obtain a copy of the License at
194 |
195 | http://www.apache.org/licenses/LICENSE-2.0
196 |
197 | Unless required by applicable law or agreed to in writing, software
198 | distributed under the License is distributed on an "AS IS" BASIS,
199 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
200 | See the License for the specific language governing permissions and
201 | limitations under the License.
202 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # Modzy Java SDK
2 |
3 | 
4 |
5 |
6 |
7 | **Modzy's Java SDK queries models, submits inference jobs, and returns results directly to your editor.**
8 |
9 |
10 | 
11 | 
12 | 
13 |
14 |
15 | [The job lifecycle](https://docs.modzy.com/reference/the-job-lifecycle) | [API Keys](https://docs.modzy.com/reference/api-keys-1) | [Samples](https://github.com/modzy/sdk-java/tree/main/samples) | [Documentation](https://docs.modzy.com/docs)
16 |
17 |
18 |
19 | ## Installation
20 |
21 | [](https://asciinema.org/a/CMMbns4Pp4TpTkZdXgMFiguDs)
22 |
23 | Clone the repository:
24 |
25 | - `$ git clone https://github.com/modzy/sdk-java.git`
26 |
27 | Use [maven](https://maven.apache.org/) to install the SDK.
28 |
29 | - `$ ./mvnw install -DskipTests=true`
30 |
31 | Add the dependency in your `pom.xml` file:
32 |
33 | ```xml
34 |
35 | com.modzy
36 | modzy-sdk
37 | 0.0.1
38 |
39 | ```
40 |
41 |
42 | ### Get your API key
43 |
44 |
45 |
46 | API keys are security credentials required to perform API requests to Modzy. Our API keys are composed of an ID that is split by a dot into two parts: a public and private part.
47 |
48 | The *public* part is the API keys' visible part only used to identify the key and by itself, it’s unable to perform API requests.
49 |
50 | The *private* part is the public part's complement and it’s required to perform API requests. Since it’s not stored on Modzy’s servers, it cannot be recovered. Make sure to save it securely. If lost, you can [replace the API key](https://docs.modzy.com/reference/update-a-keys-body).
51 |
52 |
53 | Find your API key in your user profile. To get your full API key click on "Get key":
54 |
55 |
56 |
57 |
58 |
59 | ## Initialize
60 |
61 | Once you have a `model` and `version` identified, get authenticated with your API key.
62 |
63 | ```java
64 | ModzyClient modzyClient = new ModzyClient("http://url.to.modzy/api", "API Key");
65 | ```
66 |
67 | ## Basic usage
68 |
69 | 
70 |
71 | ### Browse models
72 |
73 | Modzy’s Marketplace includes pre-trained and re-trainable AI models from industry-leading machine learning companies, accelerating the process from data to value.
74 |
75 | The Model service drives the Marketplace and can be integrated with other applications, scripts, and systems. It provides routes to list, search, and filter model and model-version details.
76 |
77 | [List models](https://docs.modzy.com/reference/list-models):
78 |
79 | ```java
80 | List models = modzyClient.getAllModels();
81 | for( Model model : models ){
82 | System.out.println("Model: "+model);
83 | }
84 | ```
85 |
86 | Tags help categorize and filter models. They make model browsing easier.
87 |
88 | [List tags](https://docs.modzy.com/reference/list-tags):
89 |
90 | ```java
91 | List tags = modzyClient.getTagClient().getAllTags();
92 | for( Tag tag : tags ){
93 | System.out.println("Tag: "+tag);
94 | }
95 | ```
96 |
97 | [List models by tag](https://docs.modzy.com/reference/list-models-by-tag):
98 |
99 | ```java
100 | TagWrapper tagsModels = modzyClient.getTagsAndModels("language_and_text");
101 | for( Model model : tagsModels.getModels() ){
102 | System.out.println("Model: "+model);
103 | }
104 | ```
105 |
106 | ### Get a model's details
107 |
108 | Models accept specific *input file [MIME](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/MIME_types) types*. Some models may require multiple input file types to run data accordingly. In this sample, we use a model that requires `text/plain`.
109 |
110 | Models require inputs to have a specific *input name* declared in the job request. This name can be found in the model’s details. In this sample, we use a model that requires `input.txt`.
111 |
112 | Additionally, users can set their own input names. When multiple input items are processed in a job, these names are helpful to identify and get each input’s results. In this sample, we use a model that requires `input-1` and `input-2`.
113 |
114 | [Get a model's details](https://docs.modzy.com/reference/list-model-details):
115 |
116 | ```java
117 | Model saModel = modzyClient.getModel("ed542963de");
118 | System.out.println("Model: "+saModel);
119 | ```
120 |
121 | Model specific sample requests are available in the version details and in the Model Details page.
122 |
123 | [Get version details](https://docs.modzy.com/reference/get-version-details):
124 |
125 | ```java
126 | ModelVersion modelVersion = modzyClient.getModelVersion("ed542963de", "0.0.27");
127 | // then you'll get all the details about the specific model version
128 | System.out.println(String.format("ModelVersion details properties: %s", getNotNullProperties(modelVersion)));
129 | // Probably the more interesting are the ones related with the inputs and outputs of the model
130 | System.out.println(" inputs:");
131 | for( ModelInput input : modelVersion.getInputs() ){
132 | System.out.println(
133 | String.format(" key %s, type %s, description: %s", input.getName(), input.getAcceptedMediaTypes(), input.getDescription())
134 | );
135 | }
136 | System.out.println(" outputs:");
137 | for( ModelOutput output : modelVersion.getOutputs() ){
138 | System.out.println(
139 | String.format(" key %s, type %s, description: %s", output.getName(), output.getMediaType(), output.getDescription())
140 | );
141 | }
142 | ```
143 |
144 | ### Submit a job and get results
145 |
146 | A *job* is the process that sends data to a model, sets the model to run the data, and returns results.
147 |
148 | Modzy supports several *input types* such as `text`, `embedded` for Base64 strings, `aws-s3` and `aws-s3-folder` for inputs hosted in buckets, and `jdbc` for inputs stored in databases. In this sample, we use `text`.
149 |
150 | [Here](https://github.com/modzy/sdk-java/blob/readmeUpdates/samples.adoc) are samples to submit jobs with `embedded`, `aws-s3`, `aws-s3-folder`, and `jdbc` input types.
151 |
152 | [Submit a job with the model, version, and input items](https://docs.modzy.com/reference/create-a-job-1):
153 |
154 | ```java
155 | Job job = modzyClient.submitJobText("ed542963de", "0.0.27", "Modzy is great!");
156 | ```
157 |
158 | [Hold until the inference is complete and results become available](https://docs.modzy.com/reference/get-job-details):
159 |
160 | ```java
161 | Job job = modzyClient.blockUntilComplete(job, 20000);
162 | ```
163 |
164 | [Get the results](https://docs.modzy.com/reference/get-results):
165 |
166 | Results are available per input item and can be identified with the name provided for each input item upon job request. You can also add an input name to the route and limit the results to any given input item.
167 |
168 | Jobs requested for multiple input items may have partial results available prior to job completion.
169 |
170 | ```java
171 | JobOutput jobResult = modzyClient.getResult(job);
172 | Map> results = jobResult.getResults();
173 | ```
174 |
175 | ### Fetch errors
176 |
177 | Errors may arise for different reasons. Fetch errors to know what is their cause and how to fix them.
178 |
179 | Error | Description
180 | ---------- | ---------
181 | `ApiException` | Wrapper for different exceptions, check the message and the stacktrace.
182 |
183 |
184 | Submitting jobs:
185 |
186 | ```javascript
187 | try{
188 | Map retValue = this.modzyClient.submitJobTextBlockUntilComplete("ed542963de", "Modzy is great!");
189 | }
190 | catch(ApiException ae){
191 | System.out.println("The job submission fails with message "+ae.getMessage());
192 | as.printStackTrace();
193 | }
194 | ```
195 |
196 | ## Features
197 |
198 | Modzy supports [batch processing](https://docs.modzy.com/reference/batch-processing), [explainability](https://docs.modzy.com/reference/explainability), and [model drift detection](https://docs.modzy.com/reference/model-drift-1).
199 |
200 | ## APIs
201 |
202 | Here is a list of Modzy APIs. To see all the APIs, check our [Documentation](https://docs.modzy.com/reference/introduction).
203 |
204 |
205 | | Feature | Code |Api route
206 | | --- | --- | ---
207 | |Get all models|modzyClient.getAllModels()|[api/models](https://docs.modzy.com/reference/get-all-models)|
208 | |List models|modzyClient.getModels()|[api/models](https://docs.modzy.com/reference/list-models)|
209 | |Get model details|modzyClient.getModel()|[api/models/:model-id](https://docs.modzy.com/reference/list-model-details)|
210 | |List models by name|modzyClient.getModelByName()|[api/models](https://docs.modzy.com/reference/list-models)|
211 | |List models by tags|modzyClient.getTagsAndModels()|[api/models/tags/:tag-id](https://docs.modzy.com/reference/list-models-by-tag) |
212 | |Get related models|modzyClient.getRelatedModels()|[api/models/:model-id/related-models](https://docs.modzy.com/reference/get-related-models)|
213 | |Get a model's versions|modzyClient.getModelVersions()|[api/models/:model-id/versions](https://docs.modzy.com/reference/list-versions)|
214 | |Get version details|modzyClient.getModelVersions()|[api/models/:model-id/versions/:version-id](https://docs.modzy.com/reference/get-version-details)|
215 | |List tags|modzyClient.getAllTags()|[api/models/tags](https://docs.modzy.com/reference/list-tags)|
216 | |Submit a Job (Text)|modzyClient.submitJobText()|[api/jobs](https://docs.modzy.com/reference/create-a-job-1)|
217 | |Submit a Job (Embedded)|modzyClient.submitJobEmbedded()|[api/jobs](https://docs.modzy.com/reference/create-a-job-1)|
218 | |Submit a Job (AWS S3)|modzyClient.submitJobAWSS3()|[api/jobs](https://docs.modzy.com/reference/create-a-job-1)|
219 | |Submit a Job (JDBC)|modzyClient.submitJobJDBC()|[api/jobs](https://docs.modzy.com/reference/create-a-job-1)|
220 | |Cancel a job|modzyClient.cancelJob()|[api/jobs/:job-id](https://docs.modzy.com/reference/cancel-a-job) |
221 | |Hold until inference is complete|modzyClient.blockUntilComplete()|[api/jobs/:job-id](https://docs.modzy.com/reference/get-job-details) |
222 | |Get job details|modzyClient.getJob()|[api/jobs/:job-id](https://docs.modzy.com/reference/get-job-details) |
223 | |Get results|modzyClient.getResults()|[api/results/:job-id](https://docs.modzy.com/reference/get-results) |
224 | |List the job history|modzyClient.getJobHistory()|[api/jobs/history](https://docs.modzy.com/reference/list-the-job-history) |
225 |
226 | ## Samples
227 |
228 | Check out our [samples](https://github.com/modzy/sdk-java/tree/main/java/com/modzy/sdk/samples) for details on specific use cases.
229 |
230 | To run samples:
231 |
232 | Set the base url and api key in each sample file:
233 |
234 | ```javascript
235 | // TODO: set the base url of modzy api and you api key
236 | ModzyClient modzyClient = new ModzyClient("https://http://modzy.url", "modzy-api.key");
237 | ```
238 |
239 | Or follow the instructions [here](https://github.com/modzy/sdk-java/tree/main/contributing.adoc#set-environment-variables-in-bash) to learn more.
240 |
241 | And then, you can:
242 |
243 | ```bash
244 | $ ./mvnw exec:java -Dexec.mainClass="com.modzy.sdk.samples.ModelSamples"
245 | ```
246 | ## Contributing
247 |
248 | We are happy to receive contributions from all of our users. Check out our [contributing file](https://github.com/modzy/sdk-java/tree/main/contributing.adoc) to learn more.
249 |
250 | ## Code of conduct
251 |
252 |
253 | [](https://github.com/modzy/sdk-java/tree/main//CODE_OF_CONDUCT.md)
254 |
--------------------------------------------------------------------------------
/contributing.adoc:
--------------------------------------------------------------------------------
1 | :doctype: article
2 | :icons: font
3 | :source-highlighter: highlightjs
4 | :docname: Java SDK
5 |
6 |
7 |
8 |
9 |
10 | ++++
11 |
12 |
13 |
14 |
Contributing to Modzy's Java SDK
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |

24 |
25 |

26 |
27 |

28 |
29 |
30 |
31 |
32 |

33 |
34 |
35 |
36 |
37 |
38 |
39 |
44 |
45 |
46 |
47 |
48 |
49 |
50 | ++++
51 |
52 | Contributions are welcome and they are greatly appreciated! Every little bit helps, and credit will always be given.
53 |
54 | Below you'll find our contributing requirements, a step-by-step guideline, and our features roadmap.
55 |
56 |
57 | == Requirements
58 |
59 | - Search previous link:https://github.com/modzy/sdk-java/issues[issues] before making new ones to avoid duplicates.
60 | - If you are reporting a bug, please include:
61 | . Your operating system name and version.
62 | . Any details about your local setup that might be helpful in troubleshooting.
63 | . Detailed steps to reproduce the bug.
64 | - If you are proposing a feature:
65 | . Explain in detail how it would work.
66 | . Keep the scope as narrow as possible, to make it easier to implement.
67 | . Remember that this is a volunteer-driven project, and that contributions are welcome.
68 | - File an issue to let us know what you're working on.
69 | - Fork the repo, develop and test your code changes, and add supporting documentation.
70 | - Use descriptive comments throughout your code.
71 | - Add test cases and comment them.
72 | //- Check your spelling and grammar.
73 | - Use descriptive commit messages that clearly explain the changes. Reference the original issue in the pull request.
74 | - Make an individual pull request for each issue.
75 |
76 |
77 |
78 | == Guidelines
79 |
80 |
81 | === 1. Fork the repo and set it for local development
82 |
83 | Clone the repository:
84 |
85 | - `$ git clone https://github.com/modzy/sdk-java.git`
86 |
87 | Install dependencies:
88 |
89 | - `$ mvn compile -DskipTests=true`
90 |
91 | Create a branch for your awesome new feature:
92 |
93 | - `$ git checkout -b my-new-awesome-feature`
94 |
95 |
96 | === 2. Develop your changes
97 |
98 | Fix that bug or build your feature.
99 |
100 | === 3. Run unit tests
101 |
102 | Configure the environment variables to easily run all the tests with a single configuration point.
103 |
104 | You can:
105 |
106 | ==== Set environment variables in bash
107 |
108 | ===== Windows
109 |
110 | [source,bash]
111 | ----
112 | set MODZY_BASE_URL=http://modzy.com/api
113 | set MODZY_API_KEY=my_key.modzy
114 | ----
115 |
116 | ===== Unix
117 |
118 | [source,bash]
119 | ----
120 | export MODZY_BASE_URL=http://modzy.com/api
121 | export MODZY_API_KEY=my_key.modzy
122 | ----
123 |
124 | ==== Use `.env` file
125 |
126 | Create a `.env` file in the root folder with your API key:
127 |
128 | [source,java]
129 | ----
130 | MODZY_BASE_URL=http://modzy.com/api
131 | MODZY_API_KEY=my_key.modzy
132 |
133 | ----
134 |
135 | Run tests:
136 |
137 | - `$ mvn test`
138 |
139 | Or specify the test that you want to run:
140 |
141 | - `$ mvn -Dtest=TestModelClient test`
142 |
143 | === 4. Document your changes
144 |
145 | Add supporting documentation for your code.
146 |
147 | //what else would be useful for Raúl?
148 |
149 | === 5. Send a pull request
150 |
151 | Add and commit your changes:
152 |
153 | - `git add .`
154 |
155 | - `$ git commit "A descriptive message"`
156 |
157 | Push your branch to GitHub:
158 |
159 | - `$ git push origin my-new-awesome-feature`
160 |
161 |
162 | //== Code of conduct
163 |
164 |
165 |
166 | == Roadmap
167 |
168 | - Wider API coverage (custom models, accounting, audit, etc).
169 | - [Maybe] Add retry logic for possibly transient issues.
170 | - Fetch model list errors.
171 |
172 |
173 |
174 |
175 | == Support
176 |
177 | Use GitHub to report bugs and send feature requests. +
178 | Reach out to https://www.modzy.com/support/ for support requests.
179 |
--------------------------------------------------------------------------------
/install.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/modzy/sdk-java/42f188a12e286cd470db9178a33c3ee2e9243def/install.gif
--------------------------------------------------------------------------------
/java.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/modzy/sdk-java/42f188a12e286cd470db9178a33c3ee2e9243def/java.gif
--------------------------------------------------------------------------------
/key.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/modzy/sdk-java/42f188a12e286cd470db9178a33c3ee2e9243def/key.png
--------------------------------------------------------------------------------
/mvnw:
--------------------------------------------------------------------------------
1 | #!/bin/sh
2 | # ----------------------------------------------------------------------------
3 | # Licensed to the Apache Software Foundation (ASF) under one
4 | # or more contributor license agreements. See the NOTICE file
5 | # distributed with this work for additional information
6 | # regarding copyright ownership. The ASF licenses this file
7 | # to you under the Apache License, Version 2.0 (the
8 | # "License"); you may not use this file except in compliance
9 | # with the License. You may obtain a copy of the License at
10 | #
11 | # http://www.apache.org/licenses/LICENSE-2.0
12 | #
13 | # Unless required by applicable law or agreed to in writing,
14 | # software distributed under the License is distributed on an
15 | # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16 | # KIND, either express or implied. See the License for the
17 | # specific language governing permissions and limitations
18 | # under the License.
19 | # ----------------------------------------------------------------------------
20 |
21 | # ----------------------------------------------------------------------------
22 | # Maven Start Up Batch script
23 | #
24 | # Required ENV vars:
25 | # ------------------
26 | # JAVA_HOME - location of a JDK home dir
27 | #
28 | # Optional ENV vars
29 | # -----------------
30 | # M2_HOME - location of maven2's installed home dir
31 | # MAVEN_OPTS - parameters passed to the Java VM when running Maven
32 | # e.g. to debug Maven itself, use
33 | # set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
34 | # MAVEN_SKIP_RC - flag to disable loading of mavenrc files
35 | # ----------------------------------------------------------------------------
36 |
37 | if [ -z "$MAVEN_SKIP_RC" ] ; then
38 |
39 | if [ -f /etc/mavenrc ] ; then
40 | . /etc/mavenrc
41 | fi
42 |
43 | if [ -f "$HOME/.mavenrc" ] ; then
44 | . "$HOME/.mavenrc"
45 | fi
46 |
47 | fi
48 |
49 | # OS specific support. $var _must_ be set to either true or false.
50 | cygwin=false;
51 | darwin=false;
52 | mingw=false
53 | case "`uname`" in
54 | CYGWIN*) cygwin=true ;;
55 | MINGW*) mingw=true;;
56 | Darwin*) darwin=true
57 | # Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home
58 | # See https://developer.apple.com/library/mac/qa/qa1170/_index.html
59 | if [ -z "$JAVA_HOME" ]; then
60 | if [ -x "/usr/libexec/java_home" ]; then
61 | export JAVA_HOME="`/usr/libexec/java_home`"
62 | else
63 | export JAVA_HOME="/Library/Java/Home"
64 | fi
65 | fi
66 | ;;
67 | esac
68 |
69 | if [ -z "$JAVA_HOME" ] ; then
70 | if [ -r /etc/gentoo-release ] ; then
71 | JAVA_HOME=`java-config --jre-home`
72 | fi
73 | fi
74 |
75 | if [ -z "$M2_HOME" ] ; then
76 | ## resolve links - $0 may be a link to maven's home
77 | PRG="$0"
78 |
79 | # need this for relative symlinks
80 | while [ -h "$PRG" ] ; do
81 | ls=`ls -ld "$PRG"`
82 | link=`expr "$ls" : '.*-> \(.*\)$'`
83 | if expr "$link" : '/.*' > /dev/null; then
84 | PRG="$link"
85 | else
86 | PRG="`dirname "$PRG"`/$link"
87 | fi
88 | done
89 |
90 | saveddir=`pwd`
91 |
92 | M2_HOME=`dirname "$PRG"`/..
93 |
94 | # make it fully qualified
95 | M2_HOME=`cd "$M2_HOME" && pwd`
96 |
97 | cd "$saveddir"
98 | # echo Using m2 at $M2_HOME
99 | fi
100 |
101 | # For Cygwin, ensure paths are in UNIX format before anything is touched
102 | if $cygwin ; then
103 | [ -n "$M2_HOME" ] &&
104 | M2_HOME=`cygpath --unix "$M2_HOME"`
105 | [ -n "$JAVA_HOME" ] &&
106 | JAVA_HOME=`cygpath --unix "$JAVA_HOME"`
107 | [ -n "$CLASSPATH" ] &&
108 | CLASSPATH=`cygpath --path --unix "$CLASSPATH"`
109 | fi
110 |
111 | # For Mingw, ensure paths are in UNIX format before anything is touched
112 | if $mingw ; then
113 | [ -n "$M2_HOME" ] &&
114 | M2_HOME="`(cd "$M2_HOME"; pwd)`"
115 | [ -n "$JAVA_HOME" ] &&
116 | JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`"
117 | fi
118 |
119 | if [ -z "$JAVA_HOME" ]; then
120 | javaExecutable="`which javac`"
121 | if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then
122 | # readlink(1) is not available as standard on Solaris 10.
123 | readLink=`which readlink`
124 | if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then
125 | if $darwin ; then
126 | javaHome="`dirname \"$javaExecutable\"`"
127 | javaExecutable="`cd \"$javaHome\" && pwd -P`/javac"
128 | else
129 | javaExecutable="`readlink -f \"$javaExecutable\"`"
130 | fi
131 | javaHome="`dirname \"$javaExecutable\"`"
132 | javaHome=`expr "$javaHome" : '\(.*\)/bin'`
133 | JAVA_HOME="$javaHome"
134 | export JAVA_HOME
135 | fi
136 | fi
137 | fi
138 |
139 | if [ -z "$JAVACMD" ] ; then
140 | if [ -n "$JAVA_HOME" ] ; then
141 | if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
142 | # IBM's JDK on AIX uses strange locations for the executables
143 | JAVACMD="$JAVA_HOME/jre/sh/java"
144 | else
145 | JAVACMD="$JAVA_HOME/bin/java"
146 | fi
147 | else
148 | JAVACMD="`which java`"
149 | fi
150 | fi
151 |
152 | if [ ! -x "$JAVACMD" ] ; then
153 | echo "Error: JAVA_HOME is not defined correctly." >&2
154 | echo " We cannot execute $JAVACMD" >&2
155 | exit 1
156 | fi
157 |
158 | if [ -z "$JAVA_HOME" ] ; then
159 | echo "Warning: JAVA_HOME environment variable is not set."
160 | fi
161 |
162 | CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher
163 |
164 | # traverses directory structure from process work directory to filesystem root
165 | # first directory with .mvn subdirectory is considered project base directory
166 | find_maven_basedir() {
167 |
168 | if [ -z "$1" ]
169 | then
170 | echo "Path not specified to find_maven_basedir"
171 | return 1
172 | fi
173 |
174 | basedir="$1"
175 | wdir="$1"
176 | while [ "$wdir" != '/' ] ; do
177 | if [ -d "$wdir"/.mvn ] ; then
178 | basedir=$wdir
179 | break
180 | fi
181 | # workaround for JBEAP-8937 (on Solaris 10/Sparc)
182 | if [ -d "${wdir}" ]; then
183 | wdir=`cd "$wdir/.."; pwd`
184 | fi
185 | # end of workaround
186 | done
187 | echo "${basedir}"
188 | }
189 |
190 | # concatenates all lines of a file
191 | concat_lines() {
192 | if [ -f "$1" ]; then
193 | echo "$(tr -s '\n' ' ' < "$1")"
194 | fi
195 | }
196 |
197 | BASE_DIR=`find_maven_basedir "$(pwd)"`
198 | if [ -z "$BASE_DIR" ]; then
199 | exit 1;
200 | fi
201 |
202 | ##########################################################################################
203 | # Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
204 | # This allows using the maven wrapper in projects that prohibit checking in binary data.
205 | ##########################################################################################
206 | if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then
207 | if [ "$MVNW_VERBOSE" = true ]; then
208 | echo "Found .mvn/wrapper/maven-wrapper.jar"
209 | fi
210 | else
211 | if [ "$MVNW_VERBOSE" = true ]; then
212 | echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..."
213 | fi
214 | if [ -n "$MVNW_REPOURL" ]; then
215 | jarUrl="$MVNW_REPOURL/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
216 | else
217 | jarUrl="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
218 | fi
219 | while IFS="=" read key value; do
220 | case "$key" in (wrapperUrl) jarUrl="$value"; break ;;
221 | esac
222 | done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties"
223 | if [ "$MVNW_VERBOSE" = true ]; then
224 | echo "Downloading from: $jarUrl"
225 | fi
226 | wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar"
227 | if $cygwin; then
228 | wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"`
229 | fi
230 |
231 | if command -v wget > /dev/null; then
232 | if [ "$MVNW_VERBOSE" = true ]; then
233 | echo "Found wget ... using wget"
234 | fi
235 | if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
236 | wget "$jarUrl" -O "$wrapperJarPath"
237 | else
238 | wget --http-user=$MVNW_USERNAME --http-password=$MVNW_PASSWORD "$jarUrl" -O "$wrapperJarPath"
239 | fi
240 | elif command -v curl > /dev/null; then
241 | if [ "$MVNW_VERBOSE" = true ]; then
242 | echo "Found curl ... using curl"
243 | fi
244 | if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
245 | curl -o "$wrapperJarPath" "$jarUrl" -f
246 | else
247 | curl --user $MVNW_USERNAME:$MVNW_PASSWORD -o "$wrapperJarPath" "$jarUrl" -f
248 | fi
249 |
250 | else
251 | if [ "$MVNW_VERBOSE" = true ]; then
252 | echo "Falling back to using Java to download"
253 | fi
254 | javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java"
255 | # For Cygwin, switch paths to Windows format before running javac
256 | if $cygwin; then
257 | javaClass=`cygpath --path --windows "$javaClass"`
258 | fi
259 | if [ -e "$javaClass" ]; then
260 | if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
261 | if [ "$MVNW_VERBOSE" = true ]; then
262 | echo " - Compiling MavenWrapperDownloader.java ..."
263 | fi
264 | # Compiling the Java class
265 | ("$JAVA_HOME/bin/javac" "$javaClass")
266 | fi
267 | if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
268 | # Running the downloader
269 | if [ "$MVNW_VERBOSE" = true ]; then
270 | echo " - Running MavenWrapperDownloader.java ..."
271 | fi
272 | ("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR")
273 | fi
274 | fi
275 | fi
276 | fi
277 | ##########################################################################################
278 | # End of extension
279 | ##########################################################################################
280 |
281 | export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"}
282 | if [ "$MVNW_VERBOSE" = true ]; then
283 | echo $MAVEN_PROJECTBASEDIR
284 | fi
285 | MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS"
286 |
287 | # For Cygwin, switch paths to Windows format before running java
288 | if $cygwin; then
289 | [ -n "$M2_HOME" ] &&
290 | M2_HOME=`cygpath --path --windows "$M2_HOME"`
291 | [ -n "$JAVA_HOME" ] &&
292 | JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"`
293 | [ -n "$CLASSPATH" ] &&
294 | CLASSPATH=`cygpath --path --windows "$CLASSPATH"`
295 | [ -n "$MAVEN_PROJECTBASEDIR" ] &&
296 | MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"`
297 | fi
298 |
299 | # Provide a "standardized" way to retrieve the CLI args that will
300 | # work with both Windows and non-Windows executions.
301 | MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@"
302 | export MAVEN_CMD_LINE_ARGS
303 |
304 | WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
305 |
306 | exec "$JAVACMD" \
307 | $MAVEN_OPTS \
308 | -classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \
309 | "-Dmaven.home=${M2_HOME}" "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \
310 | ${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@"
311 |
--------------------------------------------------------------------------------
/mvnw.cmd:
--------------------------------------------------------------------------------
1 | @REM ----------------------------------------------------------------------------
2 | @REM Licensed to the Apache Software Foundation (ASF) under one
3 | @REM or more contributor license agreements. See the NOTICE file
4 | @REM distributed with this work for additional information
5 | @REM regarding copyright ownership. The ASF licenses this file
6 | @REM to you under the Apache License, Version 2.0 (the
7 | @REM "License"); you may not use this file except in compliance
8 | @REM with the License. You may obtain a copy of the License at
9 | @REM
10 | @REM http://www.apache.org/licenses/LICENSE-2.0
11 | @REM
12 | @REM Unless required by applicable law or agreed to in writing,
13 | @REM software distributed under the License is distributed on an
14 | @REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15 | @REM KIND, either express or implied. See the License for the
16 | @REM specific language governing permissions and limitations
17 | @REM under the License.
18 | @REM ----------------------------------------------------------------------------
19 |
20 | @REM ----------------------------------------------------------------------------
21 | @REM Maven Start Up Batch script
22 | @REM
23 | @REM Required ENV vars:
24 | @REM JAVA_HOME - location of a JDK home dir
25 | @REM
26 | @REM Optional ENV vars
27 | @REM M2_HOME - location of maven2's installed home dir
28 | @REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands
29 | @REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending
30 | @REM MAVEN_OPTS - parameters passed to the Java VM when running Maven
31 | @REM e.g. to debug Maven itself, use
32 | @REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
33 | @REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files
34 | @REM ----------------------------------------------------------------------------
35 |
36 | @REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on'
37 | @echo off
38 | @REM set title of command window
39 | title %0
40 | @REM enable echoing by setting MAVEN_BATCH_ECHO to 'on'
41 | @if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO%
42 |
43 | @REM set %HOME% to equivalent of $HOME
44 | if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%")
45 |
46 | @REM Execute a user defined script before this one
47 | if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre
48 | @REM check for pre script, once with legacy .bat ending and once with .cmd ending
49 | if exist "%HOME%\mavenrc_pre.bat" call "%HOME%\mavenrc_pre.bat"
50 | if exist "%HOME%\mavenrc_pre.cmd" call "%HOME%\mavenrc_pre.cmd"
51 | :skipRcPre
52 |
53 | @setlocal
54 |
55 | set ERROR_CODE=0
56 |
57 | @REM To isolate internal variables from possible post scripts, we use another setlocal
58 | @setlocal
59 |
60 | @REM ==== START VALIDATION ====
61 | if not "%JAVA_HOME%" == "" goto OkJHome
62 |
63 | echo.
64 | echo Error: JAVA_HOME not found in your environment. >&2
65 | echo Please set the JAVA_HOME variable in your environment to match the >&2
66 | echo location of your Java installation. >&2
67 | echo.
68 | goto error
69 |
70 | :OkJHome
71 | if exist "%JAVA_HOME%\bin\java.exe" goto init
72 |
73 | echo.
74 | echo Error: JAVA_HOME is set to an invalid directory. >&2
75 | echo JAVA_HOME = "%JAVA_HOME%" >&2
76 | echo Please set the JAVA_HOME variable in your environment to match the >&2
77 | echo location of your Java installation. >&2
78 | echo.
79 | goto error
80 |
81 | @REM ==== END VALIDATION ====
82 |
83 | :init
84 |
85 | @REM Find the project base dir, i.e. the directory that contains the folder ".mvn".
86 | @REM Fallback to current working directory if not found.
87 |
88 | set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR%
89 | IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir
90 |
91 | set EXEC_DIR=%CD%
92 | set WDIR=%EXEC_DIR%
93 | :findBaseDir
94 | IF EXIST "%WDIR%"\.mvn goto baseDirFound
95 | cd ..
96 | IF "%WDIR%"=="%CD%" goto baseDirNotFound
97 | set WDIR=%CD%
98 | goto findBaseDir
99 |
100 | :baseDirFound
101 | set MAVEN_PROJECTBASEDIR=%WDIR%
102 | cd "%EXEC_DIR%"
103 | goto endDetectBaseDir
104 |
105 | :baseDirNotFound
106 | set MAVEN_PROJECTBASEDIR=%EXEC_DIR%
107 | cd "%EXEC_DIR%"
108 |
109 | :endDetectBaseDir
110 |
111 | IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig
112 |
113 | @setlocal EnableExtensions EnableDelayedExpansion
114 | for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a
115 | @endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS%
116 |
117 | :endReadAdditionalConfig
118 |
119 | SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe"
120 | set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar"
121 | set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
122 |
123 | set DOWNLOAD_URL="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
124 |
125 | FOR /F "tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO (
126 | IF "%%A"=="wrapperUrl" SET DOWNLOAD_URL=%%B
127 | )
128 |
129 | @REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
130 | @REM This allows using the maven wrapper in projects that prohibit checking in binary data.
131 | if exist %WRAPPER_JAR% (
132 | if "%MVNW_VERBOSE%" == "true" (
133 | echo Found %WRAPPER_JAR%
134 | )
135 | ) else (
136 | if not "%MVNW_REPOURL%" == "" (
137 | SET DOWNLOAD_URL="%MVNW_REPOURL%/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
138 | )
139 | if "%MVNW_VERBOSE%" == "true" (
140 | echo Couldn't find %WRAPPER_JAR%, downloading it ...
141 | echo Downloading from: %DOWNLOAD_URL%
142 | )
143 |
144 | powershell -Command "&{"^
145 | "$webclient = new-object System.Net.WebClient;"^
146 | "if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^
147 | "$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^
148 | "}"^
149 | "[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%DOWNLOAD_URL%', '%WRAPPER_JAR%')"^
150 | "}"
151 | if "%MVNW_VERBOSE%" == "true" (
152 | echo Finished downloading %WRAPPER_JAR%
153 | )
154 | )
155 | @REM End of extension
156 |
157 | @REM Provide a "standardized" way to retrieve the CLI args that will
158 | @REM work with both Windows and non-Windows executions.
159 | set MAVEN_CMD_LINE_ARGS=%*
160 |
161 | %MAVEN_JAVA_EXE% %JVM_CONFIG_MAVEN_PROPS% %MAVEN_OPTS% %MAVEN_DEBUG_OPTS% -classpath %WRAPPER_JAR% "-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" %WRAPPER_LAUNCHER% %MAVEN_CONFIG% %*
162 | if ERRORLEVEL 1 goto error
163 | goto end
164 |
165 | :error
166 | set ERROR_CODE=1
167 |
168 | :end
169 | @endlocal & set ERROR_CODE=%ERROR_CODE%
170 |
171 | if not "%MAVEN_SKIP_RC%" == "" goto skipRcPost
172 | @REM check for post script, once with legacy .bat ending and once with .cmd ending
173 | if exist "%HOME%\mavenrc_post.bat" call "%HOME%\mavenrc_post.bat"
174 | if exist "%HOME%\mavenrc_post.cmd" call "%HOME%\mavenrc_post.cmd"
175 | :skipRcPost
176 |
177 | @REM pause the script if MAVEN_BATCH_PAUSE is set to 'on'
178 | if "%MAVEN_BATCH_PAUSE%" == "on" pause
179 |
180 | if "%MAVEN_TERMINATE_CMD%" == "on" exit %ERROR_CODE%
181 |
182 | exit /B %ERROR_CODE%
183 |
--------------------------------------------------------------------------------
/pom.xml:
--------------------------------------------------------------------------------
1 |
4 | 4.0.0
5 | com.modzy
6 | modzy-sdk
7 | jar
8 |
9 | 0.0.1
10 | Modzy Java SDK
11 | Java API client for Modzy
12 | https://github.boozallencsn.com/AI/modzy-java.git
13 |
14 |
15 | 1.8
16 | 1.8
17 | UTF-8
18 |
19 |
20 |
21 |
22 | org.glassfish.jersey.core
23 | jersey-client
24 | 2.25.1
25 |
26 |
27 | org.glassfish.jersey.media
28 | jersey-media-json-jackson
29 | 2.31
30 |
31 |
32 | org.glassfish.jersey.media
33 | jersey-media-multipart
34 | 2.30.1
35 |
36 |
37 | javax.xml.bind
38 | jaxb-api
39 | 2.3.1
40 |
41 |
42 | commons-io
43 | commons-io
44 | 2.6
45 |
46 |
47 | io.github.cdimascio
48 | java-dotenv
49 | 5.1.4
50 |
51 |
52 | junit
53 | junit
54 | 4.13-beta-1
55 | test
56 |
57 |
58 | org.projectlombok
59 | lombok
60 | RELEASE
61 | compile
62 |
63 |
64 |
65 |
66 |
67 |
68 | org.codehaus.mojo
69 | cobertura-maven-plugin
70 | 2.7
71 |
72 |
73 | html
74 | xml
75 |
76 |
77 |
78 |
79 |
80 | org.apache.maven.plugins
81 | maven-javadoc-plugin
82 | 3.0.0
83 |
84 |
85 | attach-javadocs
86 |
87 | jar
88 |
89 |
90 | none
91 | false
92 |
93 |
94 |
95 |
96 |
97 | org.apache.maven.plugins
98 | maven-surefire-plugin
99 | 2.21.0
100 |
101 |
102 |
103 |
104 |
--------------------------------------------------------------------------------
/src/main/java/com/modzy/sdk/JobClient.java:
--------------------------------------------------------------------------------
1 | package com.modzy.sdk;
2 |
3 | import java.io.BufferedInputStream;
4 | import java.io.ByteArrayInputStream;
5 | import java.io.IOException;
6 | import java.io.InputStream;
7 | import java.util.List;
8 | import java.util.Map;
9 | import java.util.logging.Level;
10 | import java.util.logging.Logger;
11 |
12 | import javax.ws.rs.ProcessingException;
13 | import javax.ws.rs.WebApplicationException;
14 | import javax.ws.rs.client.Entity;
15 | import javax.ws.rs.client.Invocation.Builder;
16 | import javax.ws.rs.client.ResponseProcessingException;
17 | import javax.ws.rs.client.WebTarget;
18 | import javax.ws.rs.core.GenericType;
19 | import javax.ws.rs.core.MediaType;
20 | import javax.ws.rs.core.Response;
21 |
22 |
23 | import com.fasterxml.jackson.core.type.TypeReference;
24 | import com.fasterxml.jackson.databind.ObjectMapper;
25 | import com.modzy.sdk.dto.JobHistorySearchParams;
26 | import com.modzy.sdk.exception.ApiException;
27 | import com.modzy.sdk.model.Job;
28 | import com.modzy.sdk.model.JobInput;
29 | import com.modzy.sdk.model.JobInputStream;
30 | import com.modzy.sdk.model.JobStatus;
31 | import com.modzy.sdk.model.Model;
32 | import com.modzy.sdk.model.ModelVersion;
33 | import com.modzy.sdk.util.DataSize;
34 | import org.glassfish.jersey.media.multipart.MultiPart;
35 | import com.modzy.sdk.util.LoggerFactory;
36 | import org.glassfish.jersey.media.multipart.MultiPartFeature;
37 | import org.glassfish.jersey.media.multipart.file.StreamDataBodyPart;
38 |
39 | /**
40 | *
41 | * Client of the Job API Services
42 | *
43 | */
44 | public class JobClient {
45 |
46 | private static final String REST_PATH = "jobs";
47 |
48 | private WebTarget restTarget;
49 |
50 | private String apiKey;
51 |
52 | private Logger logger;
53 |
54 | public JobClient(WebTarget baseTarget, String apiKey) {
55 | super();
56 | this.logger = LoggerFactory.getLogger(this);
57 | this.restTarget = baseTarget.path(JobClient.REST_PATH);
58 | this.apiKey = apiKey;
59 | }
60 |
61 | /**
62 | * Wrapper of the GenericType necesary for process the response of the API
63 | *
64 | * @return A GenericType object for parse a list of Job instances
65 | */
66 | private GenericType> getListType(){
67 | return new GenericType>() {};
68 | }
69 |
70 | /**
71 | *
72 | * Call the Modzy API Service and query on the history of jobs
73 | *
74 | * @param searchParams search parameters see {@link JobHistorySearchParams class}
75 | * @return List of Jobs according to the search params
76 | * @throws ApiException if there is something wrong with the service or the call
77 | */
78 | public List getJobHistory(JobHistorySearchParams searchParams) throws ApiException{
79 | WebTarget webTarget = this.restTarget.path("history");
80 | ObjectMapper objMapper = new ObjectMapper();
81 | Map map = objMapper.convertValue(searchParams, new TypeReference