24. Django 1.8 Server Build - CentOS 7 hosted on VPS - Facebook open graph API timeline fan page custom tab 3 (Django side - urls.py, settings.py, and views.py)
data:image/s3,"s3://crabby-images/ae068/ae068f24f8ac07d133810992338236c1e2dfdf81" alt="django.png"
We'll continue from 23. Django 1.8 Server Build - CentOS 7 hosted on VPS - Facebook Open Graph API Timeline Fan Page Custom Tab 2 (SSL certificate setup).
In that chapter, we got the following error:
data:image/s3,"s3://crabby-images/1b650/1b6507dd2cbd3ebdbb0369a858fc841438473274" alt="PageNotFoundDjango.png"
So, in that chapter, we need to work on Django side to fix the error.
Here is the files we've created so far:
data:image/s3,"s3://crabby-images/4be80/4be8076b57aae38cd1ba539640a2e45eb09b01f4" alt="tree1.png"
data:image/s3,"s3://crabby-images/0dcba/0dcbac5a0e65f829b3f6805e7218ec299ba82994" alt="tree2.png"
Let's create a new app for our Facebook Tab Page, custom-facebool-tab:
[sfvue@sf djangotest]$ python manage.py startapp custom_facebook_tab [sfvue@sf djangotest]$ ls car custom_facebook_tab djangotest driver manage.py pages [sfvue@sf djangotest]$
Here is our settings.py:
INSTALLED_APPS = ( ... 'custom_facebook_tab', ... )
Then, go into the app, and we don't need any models since we're not going to make any database entries. But we need to server the page, so let's edit views.py:
from django.shortcuts import render_to_response from django.template import RequestContext from django.views.decorators.csrf import csrf_exempt @csrf_exempt def SfvueCars(request): return render_to_response('sfvueCars.html')
Our urls.py:
from django.conf.urls import include, url from django.contrib import admin from django.conf import settings urlpatterns = [ url(r'^admin/', include(admin.site.urls)), url(r'^tinymce/', include('tinymce.urls')), url(r'^$', 'pages.views.MainHomePage'), url(r'^cars/$', 'car.views.CarsAll'), url(r'^cars/(?P<carslug>.*)/$', 'car.views.SpecificCar'), url(r'^makes/(?P<makeslug>.*)/$', 'car.views.SpecificMake'), url(r'^media/(?P<path>.*)$', 'django.views.static.serve', { 'document_root': settings.MEDIA_ROOT, }), url(r'^register/$', 'driver.views.DriverRegistration'), url(r'^login/$', 'driver.views.LoginRequest'), url(r'^logout/$', 'driver.views.LogoutRequest'), url(r'^resetpassword/passwordsent/$', 'django.contrib.auth.views.password_reset_done'), url(r'^resetpassword/$', 'django.contrib.auth.views.password_reset', {'post_reset_redirect' : 'django.contrib.auth.views.password_reset_done'}, name="password_reset"), url(r'^reset/(?P<uidb64>[0-9A-Za-z]+)/(?P<token>.+)/$', 'django.contrib.auth.views.password_reset_confirm', name='password_reset_confirm'), url(r'^reset/done/$', 'django.contrib.auth.views.password_reset_complete', name='password_reset_complete'), url(r'^profile/$', 'driver.views.Profile'), url('', include('social.apps.django_app.urls', namespace='social')), url(r'^custom_facebook_tab/sfvueCars/$', 'custom_facebook_tab.views.SfvueCars'), ]
Here is our sfvueCars.html:
<html> <head> </head> <body> <p>TESTING FACEBOOK sfvueCars TAB</p> </body> </html>
With the new app, we get the following page:
data:image/s3,"s3://crabby-images/9263f/9263f14c5d35e5eee9f5e0a162a646cf338e5c5c" alt="sfvueCars.png"
So, we get for tab page with this url:
http://www.facebook.com/dialog/pagetab?app_id=1625098564374792&next;=https://djangotest.sfvue.com/custom_facebook_tab/sfvueCarsdata:image/s3,"s3://crabby-images/d585c/d585c5413b3794296820619a1fdd35b53f4456f5" alt="AddPageTab.png"
Click Okay:
data:image/s3,"s3://crabby-images/7b13e/7b13ec799db36432581117bcf4e84a120ef72a3b" alt="FacebookTab2.png"
it looks fine from Django side, but we got Refused to display in a frame because it set 'X-Frame-Options' to 'SAMEORIGIN' from Facebook as shown below (Chrome console).
data:image/s3,"s3://crabby-images/0ce11/0ce112e4c971d1125d715fd7585e9e6fd7dd6d8d" alt="SAMEORIGIN.png"
So, the Django cannot be displayed in iframe of Tab page .
Django uses Clickjacking protection with django.middleware.clickjacking.XFrameOptionsMiddleware. To allow the site to be embedded in an iframe just erase that middleware from settings.py.
MIDDLEWARE_CLASSES = ( 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', #'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.auth.middleware.SessionAuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', #'django.middleware.clickjacking.XFrameOptionsMiddleware', 'django.middleware.security.SecurityMiddleware', )
But we still have an error in our urls.py:
data:image/s3,"s3://crabby-images/7ad99/7ad998ffca4f6971d3eb6698dee1e82c4100cfc9" alt="Slash-url-error.png"
So, we let's fix it, urls.py, from :
... url(r'^custom_facebook_tab/sfvueCars/$', 'custom_facebook_tab.views.SfvueCars'), ]
Just drop the slash(/):
... url(r'^custom_facebook_tab/sfvueCars$', 'custom_facebook_tab.views.SfvueCars'), ]
data:image/s3,"s3://crabby-images/ec56e/ec56e0c18e798a3cc4a695b9615f6414e0f024c7" alt="Facebook-App-Button.png"
Finally, we have a functional page inside of Facebook that run through Django views/template: a Facebook Tab page!
data:image/s3,"s3://crabby-images/2dc48/2dc4808eaac78033e24f86057d28e01df2517e7f" alt="Working-Tab.png"
Ph.D. / Golden Gate Ave, San Francisco / Seoul National Univ / Carnegie Mellon / UC Berkeley / DevOps / Deep Learning / Visualization