com.lafargeholcim.planb.database.google.spreadsheets.GDataBase.java Source code

Java tutorial

Introduction

Here is the source code for com.lafargeholcim.planb.database.google.spreadsheets.GDataBase.java

Source

/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package com.lafargeholcim.planb.database.google.spreadsheets;

import com.google.api.client.auth.oauth2.AuthorizationCodeFlow;
import com.google.api.client.auth.oauth2.BearerToken;
import com.google.api.client.auth.oauth2.ClientParametersAuthentication;
import com.google.api.client.auth.oauth2.Credential;
import com.google.api.client.extensions.java6.auth.oauth2.AuthorizationCodeInstalledApp;
import com.google.api.client.extensions.jetty.auth.oauth2.LocalServerReceiver;
import com.google.api.client.googleapis.auth.oauth2.GoogleAuthorizationCodeFlow;
import com.google.api.client.googleapis.auth.oauth2.GoogleClientSecrets;
import com.google.api.client.googleapis.javanet.GoogleNetHttpTransport;
import com.google.api.client.http.GenericUrl;
import com.google.api.client.http.HttpResponse;
import com.google.api.client.http.HttpRequest;
import com.google.api.client.http.HttpRequestFactory;
import com.google.api.client.http.HttpRequestInitializer;
import com.google.api.client.http.HttpTransport;
import com.google.api.client.json.jackson2.JacksonFactory;
import com.google.api.client.json.JsonFactory;
import com.google.api.client.json.JsonObjectParser;
import com.google.api.client.util.store.FileDataStoreFactory;
import com.google.api.services.sheets.v4.model.*;
import com.google.api.services.sheets.v4.Sheets;
import com.google.api.services.sheets.v4.SheetsScopes;
import com.google.gson.Gson;
import com.lafargeholcim.planb.database.google.spreadsheets.json.model.Table;
import com.lafargeholcim.planb.database.google.spreadsheets.json.model.TableQueryModel;
import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.IOException;
import java.util.Arrays;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.regex.Pattern;
import java.util.regex.Matcher;
import java.net.URI;

/**
 *
 * @author AI-Saac
 */
public class GDataBase {
    /** Application name. */
    private static final String APPLICATION_NAME = "PlanB v1.0";

    /** Directory to store user credentials for this application. */
    private static final java.io.File DATA_STORE_DIR = new java.io.File(System.getProperty("user.home"),
            ".credentials/sheets.googleapis.com-java-planB");

    /** Global instance of the {@link FileDataStoreFactory}. */
    private static FileDataStoreFactory DATA_STORE_FACTORY;

    /** Global instance of the JSON factory. */
    private static final JsonFactory JSON_FACTORY = JacksonFactory.getDefaultInstance();

    /** Global instance of the HTTP transport. */
    private static HttpTransport HTTP_TRANSPORT;

    private static Credential CREDENTIAL;

    /**Google SpreadSheet ID*/
    private String spreadsheetId;

    /**General URL use to query a Google Spreadsheet*/
    private final String URL = "https://spreadsheets.google.com/tq?&tq=";

    /** Global instance of the scopes required by this quickstart.
     *
     * If modifying these scopes, delete your previously saved credentials
     * at ~/.credentials/sheets.googleapis.com-java-quickstart
     */
    private static final List<String> SCOPES = Arrays.asList(SheetsScopes.SPREADSHEETS);
    //        Arrays.asList(SheetsScopes.SPREADSHEETS); 

    /** Global instance of the scopes required by this quickstart.
     *
     * If modifying these scopes, delete your previously saved credentials
     * at ~/.credentials/sheets.googleapis.com-java-quickstart
     */
    private static HashMap<String, Worksheet> worksheets = new HashMap();

    static {
        try {
            HTTP_TRANSPORT = GoogleNetHttpTransport.newTrustedTransport();
            DATA_STORE_FACTORY = new FileDataStoreFactory(DATA_STORE_DIR);
        } catch (Throwable t) {
            t.printStackTrace();
            //System.exit(1);
        }
    }

    public GDataBase() throws IOException, Exception {
        CREDENTIAL = authorize("");
        this.spreadsheetId = "1opkeRYb5xsf_3CMpvsVVYcFx4ivbY0pchbgoeKpXIx8";
        //this.spreadsheetId = "1Xkd22LiN9unvv7GYOqsv3XwvjVMbFsi-EZASg4hxF9E";
        fetchSheetsIds();
    }

    public void setSpreadsheetId(String spreadshseetId) {
        this.spreadsheetId = spreadshseetId;
    }

    /**
     * Creates an authorized Credential object.
     * @return an authorized Credential object.
     * @throws IOException
     */
    public void authorize() throws IOException {
        // Load client secrets.
        InputStream in = GDataBase.class.getResourceAsStream("/secret/client_secret12.json");
        GoogleClientSecrets clientSecrets = GoogleClientSecrets.load(JSON_FACTORY, new InputStreamReader(in));

        // Build flow and trigger user authorization request.

        GoogleAuthorizationCodeFlow flow = new GoogleAuthorizationCodeFlow.Builder(HTTP_TRANSPORT, JSON_FACTORY,
                clientSecrets, SCOPES).setDataStoreFactory(DATA_STORE_FACTORY).setAccessType("offline").build();
        Credential credential = new AuthorizationCodeInstalledApp(flow, new LocalServerReceiver())
                .authorize("user");
        System.out.println("Credentials saved to " + DATA_STORE_DIR.getAbsolutePath());
        CREDENTIAL = credential;
    }

    /**
     * Build and return an authorized Sheets API client service.
     * @return an authorized Sheets API client service
     * @throws IOException
     */
    public Sheets getSheetsService() throws IOException {
        return new Sheets.Builder(HTTP_TRANSPORT, JSON_FACTORY, CREDENTIAL).setApplicationName(APPLICATION_NAME)
                .build();
    }

    private Credential authorize(String app) throws Exception {
        // set up authorization code flow
        AuthorizationCodeFlow flow = new AuthorizationCodeFlow.Builder(
                BearerToken.authorizationHeaderAccessMethod(), HTTP_TRANSPORT, JSON_FACTORY,
                new GenericUrl("https://www.googleapis.com/oauth2/v4/token"),
                new ClientParametersAuthentication(
                        "233923573086-q1nq8r49svbhamsf55bjs1gth1cp5nk8.apps.googleusercontent.com",
                        "SPpM4KHsu8u8TbcD-bEuaX9t"),
                "233923573086-q1nq8r49svbhamsf55bjs1gth1cp5nk8.apps.googleusercontent.com",
                "https://accounts.google.com/o/oauth2/v2/auth")
                        .setScopes(Arrays.asList("https://spreadsheets.google.com/feeds"))
                        .setDataStoreFactory(DATA_STORE_FACTORY).build();
        // authorize
        LocalServerReceiver receiver = new LocalServerReceiver.Builder().setHost("127.0.0.1").setPort(8080).build();
        return new AuthorizationCodeInstalledApp(flow, receiver).authorize("user");
    }

    public Table selectQuery(String query, String table) throws IOException {
        String urlQuery = URL + query + "&key=" + spreadsheetId + "&sheet=" + table;

        GenericUrl url = new GenericUrl(URI.create(urlQuery));
        url.build();
        HttpRequestFactory requestFactory = HTTP_TRANSPORT.createRequestFactory(new HttpRequestInitializer() {
            @Override
            public void initialize(HttpRequest request) throws IOException {
                CREDENTIAL.initialize(request);
                request.setParser(new JsonObjectParser(JSON_FACTORY));
            }
        });

        try {
            HttpRequest request = requestFactory.buildGetRequest(url);
            HttpResponse response = request.execute();
            if (response.getStatusCode() == 200) {
                try {
                    return readResponse(response.getContent());
                } catch (Exception ex) {
                    return null;
                }
            }
        } catch (IOException ex) {
            return null;
        }
        return null;
    }

    public void update(List<Request> requests) {
        try {
            Sheets service = getSheetsService();
            BatchUpdateSpreadsheetRequest batchUpdateRequest = new BatchUpdateSpreadsheetRequest()
                    .setRequests(requests);
            service.spreadsheets().batchUpdate(spreadsheetId, batchUpdateRequest).execute();
        } catch (IOException ex) {

        }
    }

    public void insert(String sheetTitle, List<CellData> values) {
        try {
            Sheets service = getSheetsService();
            List<Request> requests = new ArrayList<>();
            int sheetId = getSheetId(sheetTitle);

            requests.add(new Request().setAppendCells(new AppendCellsRequest().setSheetId(sheetId)
                    .setRows(Arrays.asList(new RowData().setValues(values)))
                    .setFields("userEnteredValue,userEnteredFormat.backgroundColor")));

            BatchUpdateSpreadsheetRequest batchUpdateRequest = new BatchUpdateSpreadsheetRequest()
                    .setRequests(requests);

            service.spreadsheets().batchUpdate(spreadsheetId, batchUpdateRequest).execute();
        } catch (IOException ex) {

        }
    }

    public void delete() {

    }

    private void fetchSheetsIds() throws IOException {
        String sheetsIdURL = "https://sheets.googleapis.com/v4/spreadsheets/" + spreadsheetId
                + "?&fields=sheets.properties";
        Sheets service = getSheetsService();
        Spreadsheet spreadsheet = service.spreadsheets().get(sheetsIdURL).setSpreadsheetId(spreadsheetId).execute();
        List<Sheet> sheets = spreadsheet.getSheets();
        for (Sheet sheet : sheets) {
            String title = sheet.getProperties().getTitle();
            Worksheet worksheet;
            switch (title) {
            case "access":
                worksheet = Worksheet.ACCESS;
                worksheet.setSheetId(sheet.getProperties().getSheetId());
                worksheets.put("access", worksheet);
                break;
            case "action":
                worksheet = Worksheet.ACTION;
                worksheet.setSheetId(sheet.getProperties().getSheetId());
                worksheets.put("action", worksheet);
                break;
            case "actionplan":
                worksheet = Worksheet.ACTIONPLAN;
                worksheet.setSheetId(sheet.getProperties().getSheetId());
                worksheets.put("actionplan", worksheet);
                break;
            case "adtparticipants_meeting":
                worksheet = Worksheet.ADTPARTICIPANTS_MEETING;
                worksheet.setSheetId(sheet.getProperties().getSheetId());
                worksheets.put("adtparticipants_meeting", worksheet);
                break;
            case "apsummary":
                worksheet = Worksheet.APSUMMARY;
                worksheet.setSheetId(sheet.getProperties().getSheetId());
                worksheets.put("apsummary", worksheet);
                break;
            case "collaborator":
                worksheet = Worksheet.COLLABORATOR;
                worksheet.setSheetId(sheet.getProperties().getSheetId());
                worksheets.put("collaborator", worksheet);
                break;
            case "facility":
                worksheet = Worksheet.FACILITY;
                worksheet.setSheetId(sheet.getProperties().getSheetId());
                worksheets.put("facility", worksheet);
                break;
            case "facility_collaborator":
                worksheet = Worksheet.FACILITY_COLLABORATOR;
                worksheet.setSheetId(sheet.getProperties().getSheetId());
                worksheets.put("facility_collaborator", worksheet);
                break;
            case "followup_action":
                worksheet = Worksheet.FOLLOWUP_ACTION;
                worksheet.setSheetId(sheet.getProperties().getSheetId());
                worksheets.put("followup_action", worksheet);
                break;
            case "meeting":
                worksheet = Worksheet.MEETING;
                worksheet.setSheetId(sheet.getProperties().getSheetId());
                worksheets.put("meeting", worksheet);
                break;
            case "user":
                worksheet = Worksheet.USER;
                worksheet.setSheetId(sheet.getProperties().getSheetId());
                worksheets.put("user", worksheet);
                break;
            case "workteam":
                worksheet = Worksheet.WORKTEAM;
                worksheet.setSheetId(sheet.getProperties().getSheetId());
                worksheets.put("workteam", worksheet);
                break;
            case "workteam_collaborator":
                worksheet = Worksheet.WORKTEAM_COLLABORATOR;
                worksheet.setSheetId(sheet.getProperties().getSheetId());
                worksheets.put("workteam_collaborator", worksheet);
                break;
            }
        }
    }

    private Table readResponse(InputStream response) throws IOException {
        Pattern pattern = Pattern.compile(".\\((.*?)\\);");
        Matcher matcher = pattern.matcher(convertStreamToString(response));
        matcher.find();
        String jsonElement = matcher.group(1);
        if (!jsonElement.contains("\"status\":\"error\"")) {
            Gson gsonFactory = new Gson();
            TableQueryModel tableModel = gsonFactory.fromJson(jsonElement, TableQueryModel.class);
            return tableModel.getTable();
        }
        return null;
    }

    protected static String convertStreamToString(InputStream input) {
        BufferedReader reader = new BufferedReader(new InputStreamReader(input));
        StringBuilder result = new StringBuilder();

        String line = null;
        try {
            while ((line = reader.readLine()) != null)
                result.append(line);
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            try {
                input.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        return result.toString();
    }

    private int getSheetId(String sheetTitle) {
        return worksheets.get(sheetTitle).getSheetId();
    }

    public Request getRequest(String sheetTitle, List<CellData> values, int rowIndex, int columnIndex) {

        int sheetId = getSheetId(sheetTitle);
        return new Request().setUpdateCells(new UpdateCellsRequest()
                .setStart(
                        new GridCoordinate().setSheetId(sheetId).setRowIndex(rowIndex).setColumnIndex(columnIndex))
                .setRows(Arrays.asList(new RowData().setValues(values)))
                .setFields("userEnteredValue,userEnteredFormat.backgroundColor"));
    }

}