aboutsummaryrefslogtreecommitdiffstats
path: root/src/main/java/com/wipro/www/sonhms/SonController.java
blob: 89236147a364d4e3cbcbe97099c6b64056d6b22c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
/*******************************************************************************
 * ============LICENSE_START=======================================================
 * pcims
 *  ================================================================================
 *  Copyright (C) 2018 Wipro Limited.
 *  ==============================================================================
 *   Licensed under the Apache License, Version 2.0 (the "License");
 *   you may not use this file except in compliance with the License.
 *   You may obtain a copy of the License at
 *
 *        http://www.apache.org/licenses/LICENSE-2.0
 *
 *   Unless required by applicable law or agreed to in writing, software
 *   distributed under the License is distributed on an "AS IS" BASIS,
 *   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *   See the License for the specific language governing permissions and
 *   limitations under the License.
 *   ============LICENSE_END=========================================================
 ******************************************************************************/

package com.wipro.www.sonhms;


import com.wipro.www.sonhms.child.ChildThread;
import com.wipro.www.sonhms.restclient.AsyncResponseBody;

import org.slf4j.Logger;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;


@RestController
public class SonController {
    private static final Logger log = org.slf4j.LoggerFactory.getLogger(SonController.class);

    @Autowired
    SonRequestsComponent pciRequestsComponent;

    @RequestMapping(value = "/callbackUrl", method = RequestMethod.POST)
    String callBackUrl(@RequestBody AsyncResponseBody callback) {
        log.debug("received request to callback url");
        String async = callback.toString();
        log.debug("AsyncResponseBody{}", async);

        String transactionId = callback.getTransactionId();
        log.debug("transaction id {}", transactionId);

        long childThreadId = pciRequestsComponent.getChildThread(transactionId);
        log.debug("childThreadId {}", childThreadId);

        ChildThread.putResponse(childThreadId, callback);
        return "Forwarded to child thread";

    }

}