Wordpress plugins that enables you to create web form, that stores information in Firebase RealTime Database after user login thru FirebaseUI. It will then trigger Firebase Functions, to submit information to AWS Elastic Search thru AWS API Gateway and AWS Lambda.
- Create realtime contest with WordPress plugin, Google Firebase[realtime database, Firebase functions, firebase storage], AWS [IAM, API Gateway, LAMBDA, Elastic Search]
- To use this plugin you will have to open account on Google to use Google products and on AWS to use Amazon services as mentioned above.
- Also you will have to install Firebase CLI to deploy Firebase Function on Firebase.
- On Google firebase side will need to have premium account as to call third party API's it is must.
- For Firebase Functions can refer to: https://firebase.google.com/docs/functions/get-started
- Please change or initiate firebase application by configuring below mentioned parameters in \firebase-forms\lib\init_firebase.php
$apikey = "XXXXXXXXXXXXXXXXXXXXXXXXXXX"; $authdomain = "XXX-XX-XXXXX.firebaseapp.com"; $dburl = "https://XXX-XX-XXXXX.firebaseio.com"; $projecturl = "XXX-XX-XXXXX"; $bucket = "XXX-XX-XXXXX.appspot.com"; $senderid = "XXXXXXXXXXXX";
- DEFAULT_TOKEN: You can get it from firebase console > project > project settings > Service accounts > Database secrets
- FIREBASE_ES_API: This constant will hold URL of aws API which will post data to ES server with aws LAMDA function
- FIREBASE_AWS_API_SECRET: This constant will hold secret key to authenticate call with aws API
- Refer to https://firebase.google.com/docs/web/setup for more information about setup application on google firebase.
- You can use PHP Firebase API to connect Firebase database in PHP using API suggested by Firebase https://firebase.google.com/docs/database/rest/start
- We have used PHP API developed by Tamas Kalman
- Go to https://github.com/ktamas77/firebase-php/, install or download below three files
- firebaseInterface.php
- firebaseLib.php
- firebaseStub.php
- Copy them in /firebase-forms/lib folder
- We are using this API to approve and reject contest entries from admin side.
- To deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software please go through Licence section of API first.
- Google Firebase: Realtime Database, Firebase Functions, Firebase Storage
- AWS: IAM role, API Gateway, LAMBDA, Elastic Search
- After activating plugin add below code in page content, you can modify it if you want:
<div style="width: 100%;">
<div style="width: 30%; float: left; margin-right: 10px;">[bootstrap_sidebar_navigation]</div>
<div class="container" style="width: 60%; float: left;">[firebase_form_shortcode]</div>
<div style="clear: both;"></div>
</div>
[bootstrap_sidebar_navigation]
: Shortcode for sidebar navigation
[firebase_form_shortcode]
: Shortcode for contest forms
[firebase_contest_shortcode contest="-LHITRFgQimv9k6UzbYn"]
: Shortcode to show participated users, where contest is ID of contest which you can get from admin
- We have created another plugin "bootstrap-sidebar-navigation" to show sidebar with links to diffrent pages of site
- To add or modify existing navigation you need to do changes in /view/navigation.php
- Note: We used javascript function to call another page which is boot_loadPage() eq. javascript:boot_loadPage(3, 2) - where 3 is page id and 2 header id which we have added in firebase forms plugin
- Also need to keep ID of "" element in specific format: "nav_lnk{pageid}{headerid}" eq: Fathers Day Contest
- If you want to add new form or page you have to add two files 1. form-{id}.php eq. form-2.php in folder /view/ 2. form-{id}.js eq. form-2.js in folder /js/ 3. Similar to form you can add new header with file name headerlinks-{id}.php, eq. headerlinks-2.php 4. For your referance we have added few forms which you can refer to add new
- On admin side, we have added page using which you can add new contest and see all participated users.
- For added sample contests we have considered
- If you want to customize Select Tag dropdown using select2 lib to implement multiple select drop down you need to follow two points below with some changes in form.js and form html
- Go to https://github.com/select2/select2/blob/master/LICENSE.md, find and download select2.min.js file then paste it in WordPress-Plugins/firebase-forms/js folder
- Go to https://github.com/select2/select2/blob/master/LICENSE.md, find and download select2.min.css file then paste it in WordPress-Plugins/firebase-forms/css folder
- Add contest from admin, once you add contest you will get contest id which you need to configure in js file of form
- When user submit form data will get stored to firebase node.
- Once data write on firebase node firebase function will get trigger which will post same data to API gateway which will post it to Elastic Search
- After post data to Elastic search firebase function will copy data to main node and delete it from temporary node
- On frontend side, shortcode [firebase_contest_shortcode contest="-LHITRFgQimv9k6UzbYn"] will fetch all participant data from elastic search and show on site
- Note. If you want to change fields need to make changes in form javascript file, Firebase function code and LAMBDA function code
Node: - wp_fb_admin : Add admin users - wp_fb_contests : This node will include contest data like createdate and name - wp_fb_images : This node will include image info like description, status, createdate and URL - wp_fb_tokens : This node will include user device token which will be used as user login token - wp_fb_users : This node will include user related data like address, name and createdate
The MIT License (MIT)
Copyright (c) 2018 Christian Lai Yit Ming
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.