Skip to content

Commit ce0482a

Browse files
Add UriUtils class for URI/Path translation
Currently, we have the metaschema-cli only support local file paths for arguments for content inputs and outputs. This loader will support the use of MetaschemaLoader.load() with URIs and unify local file path and URL access (primarily https://, http://) with the same command line tooling for similar remote and local access. Co-Authored-By: David Waltermire <[email protected]>
1 parent 9babb01 commit ce0482a

File tree

2 files changed

+145
-0
lines changed

2 files changed

+145
-0
lines changed
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,60 @@
1+
/*
2+
* Portions of this software was developed by employees of the National Institute
3+
* of Standards and Technology (NIST), an agency of the Federal Government and is
4+
* being made available as a public service. Pursuant to title 17 United States
5+
* Code Section 105, works of NIST employees are not subject to copyright
6+
* protection in the United States. This software may be subject to foreign
7+
* copyright. Permission in the United States and in foreign countries, to the
8+
* extent that NIST may hold copyright, to use, copy, modify, create derivative
9+
* works, and distribute this software and its documentation without fee is hereby
10+
* granted on a non-exclusive basis, provided that this notice and disclaimer
11+
* of warranty appears in all copies.
12+
*
13+
* THE SOFTWARE IS PROVIDED 'AS IS' WITHOUT ANY WARRANTY OF ANY KIND, EITHER
14+
* EXPRESSED, IMPLIED, OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, ANY WARRANTY
15+
* THAT THE SOFTWARE WILL CONFORM TO SPECIFICATIONS, ANY IMPLIED WARRANTIES OF
16+
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND FREEDOM FROM
17+
* INFRINGEMENT, AND ANY WARRANTY THAT THE DOCUMENTATION WILL CONFORM TO THE
18+
* SOFTWARE, OR ANY WARRANTY THAT THE SOFTWARE WILL BE ERROR FREE. IN NO EVENT
19+
* SHALL NIST BE LIABLE FOR ANY DAMAGES, INCLUDING, BUT NOT LIMITED TO, DIRECT,
20+
* INDIRECT, SPECIAL OR CONSEQUENTIAL DAMAGES, ARISING OUT OF, RESULTING FROM,
21+
* OR IN ANY WAY CONNECTED WITH THIS SOFTWARE, WHETHER OR NOT BASED UPON WARRANTY,
22+
* CONTRACT, TORT, OR OTHERWISE, WHETHER OR NOT INJURY WAS SUSTAINED BY PERSONS OR
23+
* PROPERTY OR OTHERWISE, AND WHETHER OR NOT LOSS WAS SUSTAINED FROM, OR AROSE OUT
24+
* OF THE RESULTS OF, OR USE OF, THE SOFTWARE OR SERVICES PROVIDED HEREUNDER.
25+
*/
26+
27+
package gov.nist.secauto.metaschema.core.util;
28+
29+
import java.net.URI;
30+
import java.net.URISyntaxException;
31+
import java.nio.file.InvalidPathException;
32+
import java.nio.file.Path;
33+
import java.nio.file.Paths;
34+
35+
import edu.umd.cs.findbugs.annotations.NonNull;
36+
37+
public final class UriUtils {
38+
39+
private UriUtils() {
40+
// disable construction
41+
}
42+
43+
public static URI toUri(@NonNull String location, @NonNull URI baseUri) throws URISyntaxException {
44+
URI asUri;
45+
try {
46+
asUri = new URI(location);
47+
} catch (URISyntaxException ex) {
48+
// the location is not a valid URI
49+
try {
50+
// try to parse the location as a local file path
51+
Path path = Paths.get(location);
52+
asUri = path.toUri();
53+
} catch (InvalidPathException ex2) {
54+
// not a local file path, so rethrow the original URI expection
55+
throw ex;
56+
}
57+
}
58+
return baseUri.resolve(asUri.normalize());
59+
}
60+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,85 @@
1+
/*
2+
* Portions of this software was developed by employees of the National Institute
3+
* of Standards and Technology (NIST), an agency of the Federal Government and is
4+
* being made available as a public service. Pursuant to title 17 United States
5+
* Code Section 105, works of NIST employees are not subject to copyright
6+
* protection in the United States. This software may be subject to foreign
7+
* copyright. Permission in the United States and in foreign countries, to the
8+
* extent that NIST may hold copyright, to use, copy, modify, create derivative
9+
* works, and distribute this software and its documentation without fee is hereby
10+
* granted on a non-exclusive basis, provided that this notice and disclaimer
11+
* of warranty appears in all copies.
12+
*
13+
* THE SOFTWARE IS PROVIDED 'AS IS' WITHOUT ANY WARRANTY OF ANY KIND, EITHER
14+
* EXPRESSED, IMPLIED, OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, ANY WARRANTY
15+
* THAT THE SOFTWARE WILL CONFORM TO SPECIFICATIONS, ANY IMPLIED WARRANTIES OF
16+
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND FREEDOM FROM
17+
* INFRINGEMENT, AND ANY WARRANTY THAT THE DOCUMENTATION WILL CONFORM TO THE
18+
* SOFTWARE, OR ANY WARRANTY THAT THE SOFTWARE WILL BE ERROR FREE. IN NO EVENT
19+
* SHALL NIST BE LIABLE FOR ANY DAMAGES, INCLUDING, BUT NOT LIMITED TO, DIRECT,
20+
* INDIRECT, SPECIAL OR CONSEQUENTIAL DAMAGES, ARISING OUT OF, RESULTING FROM,
21+
* OR IN ANY WAY CONNECTED WITH THIS SOFTWARE, WHETHER OR NOT BASED UPON WARRANTY,
22+
* CONTRACT, TORT, OR OTHERWISE, WHETHER OR NOT INJURY WAS SUSTAINED BY PERSONS OR
23+
* PROPERTY OR OTHERWISE, AND WHETHER OR NOT LOSS WAS SUSTAINED FROM, OR AROSE OUT
24+
* OF THE RESULTS OF, OR USE OF, THE SOFTWARE OR SERVICES PROVIDED HEREUNDER.
25+
*/
26+
27+
package gov.nist.secauto.metaschema.core.util;
28+
29+
import static org.junit.jupiter.api.Assertions.assertEquals;
30+
31+
import org.junit.jupiter.params.ParameterizedTest;
32+
import org.junit.jupiter.params.provider.Arguments;
33+
import org.junit.jupiter.params.provider.MethodSource;
34+
35+
import java.net.URI;
36+
import java.nio.file.Path;
37+
import java.nio.file.Paths;
38+
import java.util.LinkedList;
39+
import java.util.List;
40+
import java.util.stream.Stream;
41+
42+
import edu.umd.cs.findbugs.annotations.NonNull;
43+
44+
class UriUtilsTest {
45+
private static final boolean VALID = true;
46+
private static final boolean INVALID = false;
47+
48+
private static Stream<Arguments> provideValuesTestToUri() {
49+
List<Arguments> values = new LinkedList<>() {
50+
{
51+
add(Arguments.of("http://example.org/valid", VALID));
52+
add(Arguments.of("https://example.org/valid", VALID));
53+
add(Arguments.of("http://example.org/valid", VALID));
54+
add(Arguments.of("ftp://example.org/valid", VALID));
55+
add(Arguments.of("ssh://example.org/valid", VALID));
56+
add(Arguments.of("example.org/good", VALID));
57+
add(Arguments.of("bad.txt", VALID));
58+
add(Arguments.of("relative\\windows\\path\\resource.txt", VALID));
59+
add(Arguments.of("C:\\absolute\\valid.txt", VALID));
60+
add(Arguments.of("local/relative/path/is/invalid.txt", VALID));
61+
add(Arguments.of("/absolute/local/path/is/invalid.txt", VALID));
62+
add(Arguments.of("1;", VALID));
63+
add(Arguments.of(":", INVALID));
64+
add(Arguments.of(">", INVALID));
65+
add(Arguments.of("<", INVALID));
66+
}
67+
};
68+
return values.stream();
69+
}
70+
71+
@ParameterizedTest
72+
@MethodSource("provideValuesTestToUri")
73+
void testToUri(@NonNull String location, boolean expectedResult) {
74+
boolean valid = false;
75+
Path cwd = Paths.get("");
76+
try {
77+
URI uri = UriUtils.toUri(location, cwd.toAbsolutePath().toUri());
78+
valid = true;
79+
System.out.println(String.format("%s -> %s", location, uri.toASCIIString()));
80+
} catch (Exception ex) {
81+
ex.printStackTrace();
82+
}
83+
assertEquals(valid, expectedResult);
84+
}
85+
}

0 commit comments

Comments
 (0)