annotate JavaSDK/be/uclouvain/orthanc/Callbacks.java @ 43:678bbed285a1 default tip

improved import of JNI in cmake
author Sebastien Jodogne <s.jodogne@gmail.com>
date Fri, 06 Sep 2024 13:53:54 +0200
parents 10406d66d1c6
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
1 package be.uclouvain.orthanc;
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
2
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
3 /**
20
1c407ba1d311 update year to 2024
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 0
diff changeset
4 * SPDX-FileCopyrightText: 2023-2024 Sebastien Jodogne, UCLouvain, Belgium
0
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
5 * SPDX-License-Identifier: GPL-3.0-or-later
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
6 */
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
7
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
8 /**
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
9 * Java plugin for Orthanc
20
1c407ba1d311 update year to 2024
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 0
diff changeset
10 * Copyright (C) 2023-2024 Sebastien Jodogne, UCLouvain, Belgium
0
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
11 *
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
12 * This program is free software: you can redistribute it and/or
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
13 * modify it under the terms of the GNU General Public License as
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
14 * published by the Free Software Foundation, either version 3 of the
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
15 * License, or (at your option) any later version.
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
16 *
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
17 * This program is distributed in the hope that it will be useful, but
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
18 * WITHOUT ANY WARRANTY; without even the implied warranty of
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
20 * General Public License for more details.
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
21 *
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
22 * You should have received a copy of the GNU General Public License
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
23 * along with this program. If not, see http://www.gnu.org/licenses/.
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
24 **/
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
25
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
26
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
27 import java.util.Map;
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
28
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
29 /**
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
30 * Wrapper around the callbacks provided by the Orthanc SDK.
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
31 **/
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
32 public class Callbacks {
33
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
33 /**
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
34 * Callback to react to changes.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
35 **/
0
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
36 public interface OnChange {
33
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
37 /**
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
38 * Signature of a callback function that is triggered when a
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
39 * change happens to some DICOM resource.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
40 * @param changeType The type of change.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
41 * @param resourceType The type of resource affected by this change.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
42 * @param resourceId The identifier of the affected resource, if any.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
43 **/
0
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
44 public void call(ChangeType changeType,
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
45 ResourceType resourceType,
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
46 String resourceId);
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
47 }
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
48
33
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
49 /**
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
50 * Callback to serve a resource in the REST API.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
51 **/
0
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
52 public interface OnRestRequest {
33
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
53 /**
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
54 * Signature of a callback function that answers a REST request.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
55 * @param output Output containing the answer that is sent to the REST client.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
56 * @param method The HTTP method.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
57 * @param uri The URI, starting from the root of the Orthanc server.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
58 * @param regularExpressionGroups The actual values of the groups matched by the regular expression.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
59 * @param headers The HTTP headers of the request.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
60 * @param getParameters The parameters of a GET request.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
61 * @param body The body of the request (only applicable to POST and PUT methods).
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
62 **/
0
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
63 public void call(RestOutput output,
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
64 HttpMethod method,
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
65 String uri,
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
66 String[] regularExpressionGroups,
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
67 Map<String, String> headers,
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
68 Map<String, String> getParameters,
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
69 byte[] body);
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
70 }
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
71
33
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
72 /**
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
73 * Register a callback to monitor changes.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
74 * @param callback The callback to handle the change.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
75 **/
0
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
76 public static native void register(OnChange callback);
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
77
33
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
78 /**
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
79 * Register a REST callback. Note that the callback will NOT be
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
80 * invoked in mutual exclusion.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
81 * @param pathRegularExpression Regular expression for the URI. May contain groups.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
82 * @param callback The callback to handle the REST call.
10406d66d1c6 cppcheck
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 20
diff changeset
83 **/
0
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
84 public static native void register(String pathRegularExpression,
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
85 OnRestRequest callback);
3ecef5782f2c initial commit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
86 }