This is the master data management tool that made it possible to do from the creation of the data to the reflection only in Chrome by using Chrome Extension and Spreadsheet.
The most common way to manage master data is to create data in Excel or Spreadsheet, and reflect it to GitHub or database.
Of these, SSBird minimizes the cost of managing master data by taking care of the process of creating data and pushing it to GitHub, except for parts that are dependent on each project's development environment, such as reflecting database.
It also has features for merging sheets and creating Pull Request in consideration of parallel work by multiple people and data checking in CI. As an operational flow, we assume that when a csv is pushed to GitHub, it is imported into the database on CI/CD.
- Download the version of SSBird-vX.X.X.Server.zipyou want to use from the Releases and unzip it
- Right-click on the location on Google Drive where you want to save the script and select More > Google Apps Script
- Open the code editor, overwrite it with the code in SSBird/gas/apply.gsand save it
- (optional) In line 8 of the apply.gs, enter your password likeconst password = "Enter a random password here";(it will be required as Apply Password when the Chrome extension is installed)
- From the status bar above, go to Resources > Advanced Google services...and turn on "Google Sheets API"
- From the status bar above, select Publish > Deploy as Web app...and change the permissions under "Who has access to the app" so that SSBird members can access it, then press "Deploy"
- You will be asked to approve it after the update, so follow the instructions to approve it
- Edit SSBird/examples/extension-config.json with reference to this (use the URL that appears after the completion of step 5 of this procedure for applyUrl)
- Right-click on the configuration file in a location on Google Drive that your team members can access and upload the extension-config.jsonthat you edited inUpload files
- Right-click on the uploaded extension-config.json, selectGet shareable link, and note theXXXXXXXpart ofhttps://drive.google.com/file/d/XXXXXXX/view?usp=sharingas the ID (it will be required as Config File Id when the Chrome extension is installed)
- Download the version of SSBird-vX.X.X.Client.zipyou want to use from the Releases and unzip it
- If you are a Mac user, right-click on SSBird/extension/installer/mac/install.command, hold down the command key and select "Open", which will bring up a dialog, then select "Open"
- If you are a Windows user, double-click on SSBird/extension/installer/windows/install.bat
- Please log in with your administrator-designated GitHub account
- Please refer to this page and check the "repo" box in step 7 of the reference, and then issue the GitHub access token
- Go to chrome://extensions, turn on developer mode in the upper right corner, and selectSSBird/extension/appunder "LOAD UNPACKED"
- Please log in with your administrator-designated Google account
- When you go to Spreadsheet screen or the folder where Spreadsheet is located in Google Drive, you will be able to press the SSBird icon in the upper right corner of Chrome
- You will be asked for information, so enter it (use the GitHub Access Token you got in step 4 of this procedure)
- Config File Id and Apply Password should be told to you by your administrator (if omitted, Apply Password is not necessary)
| light | dark | 
|---|---|
| Parameter | Description | 
|---|---|
| Apply Spreadsheets | Spreadsheets that are subject to Apply. Automatic selection on Spreadsheet and multiple selections on Google Drive. | 
| Target Sheet | The sheet to be pushed to. If it doesn't exist, it will be created automatically. The name of the branch to be pushed is the same as the name of the sheet. | 
| Merge Sheets | The sheet to merge Target Sheet. Multiple sheets can be selected, in which case, the sheets are merged in the order of input. | 
| Commit Message | Commit message. | 
| Parent Branch | The name of the branch to use as a parent if the branch with Target Sheet name does not exist and is newly created. | 
| Create Pull Request | When it is on, the sheet specified in Target Sheet is not updated and Pull Request is created instead. | 
- Create the sheet and data that you want to reflect in Spreadsheet
- Press the SSBird icon at the top right
- Select the sheet you want to reflect in the "Target Sheet"
- press "Apply"
- if "Success π" comes up, it's a success!
- In Spreadsheet, create a sheet to overwrite the data separately from the sheet you want to reflect (please write a column in the sheet for overwriting)
- Please write only the data you want to overwrite in the sheet you want to overwrite
- Select the sheet you want to reflect in the "Target Sheet"
- Select the sheet describing the data to be overwritten in "Merge Sheets" (multiple selections are possible, and the data will be overwritten in the order of selection)
- press "Apply"
- if "Success π" comes up, it's a success!
- Go to the Google Drive folder screen that contains Spreadsheet you want to reflect
- In the 'Apply Spreadsheets' section, select Spreadsheet you want to reflect
- As for "Target Sheet" and "Merge Sheets", it is the same as How to merge and reflect sheets, and is applied to all selected Spreadsheets
- press "Apply"
- if "Success π" comes up, it's a success!
- turn on the "Create Pull Request"
- As for "Target Sheet" and "Merge Sheets", it is the same as How to merge and reflect sheets
- press "Apply"
- if "Success π" comes up, it's a success! (In Pull Request, "Target Sheet" is base branch, "Merge Sheets" is head)
- If the Spreadsheet name is example, it will be example.csv on GitHub
- If the target sheet name is develop, the csv will be pushed to the develop branch
- Data columns should be written with no spaces on the left and top (A1,B1,C1...)
- Cells with blank A columns or 1 rows will be ignored in both merging sheets and converting csv, so please use this when making notes (if you're making notes in D2, leave A2 or D1 blank)
- Cells in column A (A1,A2,A3...) is the same, it is assumed to be the same data and overwritten, if not, it is added to the bottom as new data
- If the data is overwritten, it is not a problem even if the order of the data columns other than column A is different between the target sheet and the sheet describing the data to be overwritten because the data is overwritten based on the data column
- If the sheet containing the data to be overwritten has a new data column that is not in the target sheet, new data column will be added
{ // URLs that can be obtained after publishing a web application in apply.gs "applyUrl": "https://script.google.com/XXXXXXX/exec", // URL of the GitHub repository to push // Please give the user who issues the access token more than Write permission "repositoryUrl": "https://github.com/XXXXXXX/XXXXXXX", // The path from this ID folder to Spreadsheet will be the path on GitHub // The ID of the folder is the URL in the state of opening the folder with a browser, and // https://drive.google.com/drive/u/0/folders/XXXXXXX // XXXXXXX part is applicable "rootFolderId": "XXXXXXX" }