Example #1
0
def main():
	db = libmatomotter.q()

	param = cgi.FieldStorage()
	if param.getvalue("q"):
		r = db.get(int(param.getvalue("q")))
		if r != None:
			print u"Content-Type: text/html"
			print
			print u"id = "+str(r.get("id",None))
			print u"screen_name = "+r.get("screen_name",None)
			print u"theme = "+r.get("theme",None)
			print u"option0 = "+r.get("option0",None)
		else:
			print u"Content-Type: text/html"
			print
			print u"id notfound"
	else:
		q = {
			"id":123,
			"screen_name":"foo",
			"theme":"theme",
			"option0":"option0"
		}

		print u"Content-Type: text/html"
		print
		print db.set(q)
		print u"saved."
Example #2
0
def main():

    # 定数定義
    HOME_URI = "http://" + os.environ["HTTP_HOST"]

    # ライブラリ略称定義
    cookie = Cookie.SimpleCookie(os.environ.get("HTTP_COOKIE", ""))  # クッキーおいしいです
    session = libGAEsession.session_memcache()  # セッションDB
    dbq = libmatomotter.q()  # 質問用DB
    dba = libmatomotter.a()  # 回答用DB
    param = cgi.FieldStorage()

    # 変数定義
    http_loc = None  # httpヘッダのLocation
    bitten_cookie = False  # クッキー食べた?

    # クッキー処理
    if cookie.has_key("sessionid"):
        if session.load(cookie["sessionid"].value.decode("ascii")) == None:
            session.new()
        else:
            bitten_cookie = True  # クッキー食べてた

        # HTTPヘッダ部
    print u"Set-Cookie: sessionid=%s; expires=%s; path=/" % (
        session.getid(),
        time.strftime("%a, %d-%b-%Y %H:%M:%S GMT", time.gmtime(time.time() + 86400)),
    )
    print u"Content-Type: text/html; charset=UTF-8"

    # makoちゃんに渡すパラメータ初期化
    tmpl_file = "main.tmpl"  # 無指定の場合はmain.tmplを読みにいこう
    tmpl_args = {
        "title": "",
        "text": u"誰かに質問する→誰かについて答える→競え!!",
        "screen_name": session.get("screen_name", ""),
        "profile_image": "",
        "user_list": "",
        "question": "",
        "answer": "",
        "param_theme": "",
        "param_option0": "",
        "param_option1": "",
        "param_option2": "",
        "param_option3": "",
        "error_theme": "",
        "error_option0": "",
        "error_option1": "",
        "param_q_id": "",
        "param_q_uid": "",
        "param_q_options": [],
        "param_q_tgt": [],
        "param_post_to": "",
        "login_toggle": "",
        "param_target_url_1": "",
        "param_target_url_2": "",
        "Results_id": [],
        "Results_value": {},
    }

    # 外部モード取得
    try:
        m = param.getvalue("m", "").decode("utf-8")
    except:
        m = None  # こけたらクリアする

        # メイン処理部
    if m == "login":  # ログイン前処理
        auth = tweepy.OAuthHandler(
            conf.dict["consumer_key"], conf.dict["consumer_secret"], HOME_URI + u"/?m=callback", True
        )
        http_loc = auth.get_authorization_url()
        session.set("token_secret", auth.request_token.secret)

    elif m == "callback":  # ログイン後処理(need cookie)
        if session.get("token_secret", None):
            auth = tweepy.OAuthHandler(
                conf.dict["consumer_key"], conf.dict["consumer_secret"], HOME_URI + u"/?m=callback", True
            )
            api = tweepy.API(auth)
            try:
                auth.set_request_token(param.getvalue("oauth_token").decode("utf-8"), session.pop("token_secret"))
                auth.get_access_token(param.getvalue("oauth_verifier").decode("utf-8"))
                session.set("access_key", auth.access_token.key)
                session.set("access_secret", auth.access_token.secret)
                auth.set_access_token(session.get("access_key"), session.get("access_secret"))
                session.set("id", api.me().id)
                session.set("screen_name", api.me().screen_name)
                http_loc = HOME_URI + session.pop("return_to", "")
            except:
                http_loc = auth.get_authorization_url()
                session.set("token_secret", auth.request_token.secret)
        else:
            http_loc = HOME_URI if bitten_cookie else HOME_URI + u"/?m=cookie_error"

    elif m == "logout":
        session.clear()
        http_loc = HOME_URI

    elif m == "make":  # 質問作成ページ
        tmpl_file = "create.tmpl"
        post_flg = param.getvalue("post_flg", "").decode("utf-8")
        q = {
            "theme": param.getvalue("theme", "").decode("utf-8"),
            "option0": param.getvalue("option0", "").decode("utf-8"),
            "option1": param.getvalue("option1", "").decode("utf-8"),
            "option2": param.getvalue("option2", "").decode("utf-8"),
            "option3": param.getvalue("option3", "").decode("utf-8"),
        }
        if post_flg and q["theme"] and q["option0"] and q["option1"]:
            session.set("q", q)
            http_loc = HOME_URI + u"/?m=make_confirm"
        elif post_flg or session.get("q", None):
            if not post_flg:
                q = session.pop("q")
            if not q["theme"]:
                tmpl_args["error_theme"] = u"<br><b>タイトルを入力して下さい。</b>"
            if not q["option0"]:
                tmpl_args["error_option0"] = u"<br><b>選択肢1を入力して下さい。</b>"
            if not q["option1"]:
                tmpl_args["error_option1"] = u"<br><b>選択肢2を入力して下さい。</b>"
            tmpl_args["param_theme"] = q["theme"]
            tmpl_args["param_option0"] = q["option0"]
            tmpl_args["param_option1"] = q["option1"]
            tmpl_args["param_option2"] = q["option2"]
            tmpl_args["param_option3"] = q["option3"]
        else:
            pass

    elif m == "make_confirm":  # 質問投稿確認ページ
        tmpl_file = "answer.tmpl"
        tmpl_args["param_post_to"] = u"?m=make_post"
        if session.get("q", None):
            q = session.get("q")
            tmpl_args["text"] = q["theme"]
            tmpl_args["param_q_uid"] = session.get("id", "")
            for i in (q["option0"], q["option1"], q["option2"], q["option3"]):
                if i == "":
                    break
                tmpl_args["param_q_options"].append(i)
            tmpl_args["param_q_tgt"] = get_userlist(
                session.get("access_key", None), session.get("access_secret", None), tmpl_args["param_q_uid"]
            )
        else:
            http_loc = HOME_URI + u"/?m=make" if bitten_cookie else HOME_URI + u"/?m=cookie_error"

    elif m == "make_post":  # 質問投稿処理
        if session.get("q", None):
            if session.get("id", None):
                q = session.pop("q")
                q["id"] = session.get("id")
                q["screen_name"] = session.get("screen_name")
                http_loc = HOME_URI + u"/?m=q&id=" + str(dbq.set(q))
            else:
                session.set("return_to", u"/?m=make_post")
                http_loc = HOME_URI + u"/?m=login"
        else:
            http_loc = HOME_URI

    elif m == "q":  # 質問表示ページ
        tmpl_file = "answer.tmpl"
        qid = param.getvalue("id", "").decode("utf-8")
        uid = param.getvalue("uid", "").decode("utf-8")
        if qid:
            tmpl_args["param_post_to"] = u"?m=a&id=" + qid
            r = dbq.get(int(qid))
            tmpl_args["text"] = r.get("theme", None)
            tmpl_args["param_q_uid"] = session.get("id", "")
            for i in (r.get("option0", ""), r.get("option1", ""), r.get("option2", ""), r.get("option3", "")):
                if i == "":
                    break
                tmpl_args["param_q_options"].append(i)
            q_tgt = get_userlist(
                session.get("access_key", None), session.get("access_secret", None), tmpl_args["param_q_uid"]
            )
            tmpl_args["param_q_tgt"] = q_tgt
            session.set("q_tgt", q_tgt)

        else:  # いやqidないっておかしいから帰れ
            http_loc = HOME_URI

    elif m == "a":  # 回答処理&結果確認ページ(need cookie)
        q_tgt = session.pop("q_tgt", None)
        a = {
            "qid": param.getvalue("id", None),
            "referring_id": session.get("id", None),
            "referring_screen_name": session.get("screen_name", None),
        }
        if a["qid"] and q_tgt:
            for i in q_tgt.keys():
                a_list = []
                if param.getvalue(str(i), None):
                    a["referred_id"] = i
                    a["referred_screen_name"] = q_tgt.get(i)
                    a["choice"] = int(param.getvalue(str(i)))
                    a_list.append(a)
            if a["referring_id"]:
                for i in a_list:
                    dba.set(i)
            else:
                session.set("a", a_list)
                session.set("return_to", "/?m=a")
                http_loc = HOME_URI + u"/?m=login"

        elif session.get("a", None):
            a_list = session.pop("a")
            for i in a_list:
                dba.set(i)

        else:
            http_loc = HOME_URI if bitten_cookie else HOME_URI + u"/?m=cookie_error"

    elif m == "my":  # 結果表示ページ
        tmpl_file = "result.tmpl"
        # 仮データ
        tmpl_args["Results_id"] = [100, 200]
        tmpl_args["Results_value"] = {
            100: {
                "Question": "質問1",
                "Answer_num": 3,
                "Answer_text": ["回答1", "回答2", "回答3"],
                "Answer_Per": [10.00, 20.00, 70.00],
                "Answered_User": [[], [], get_userlist().values()],
            },
            200: {
                "Question": "質問2",
                "Answer_num": 4,
                "Answer_text": ["回答1", "回答2", "回答3", "回答4"],
                "Answer_Per": [10.00, 20.00, 30.00, 40.00],
                "Answered_User": [[], [], get_userlist().values(), []],
            },
        }

    elif m == "cookie_error":  # クッキーないよページ
        tmpl_args["text"] = u"クッキー食べてください"

    else:  # トップページ(無指定 or 無効なパラメータ)
        pass

        # makoちゃん設定部
    tmpl = mako.template.Template(
        filename="./" + tmpl_file,
        input_encoding="utf-8",
        output_encoding="utf-8",
        encoding_errors="replace",
        lookup=mako.lookup.TemplateLookup(directories=["./"]),
    )

    # makoちゃん後処理
    if tmpl_args["title"]:
        tmpl_args["title"] += u" - "
    if tmpl_args["screen_name"]:
        tmpl_args["screen_name"] = u"@" + tmpl_args["screen_name"]
    else:
        tmpl_args["screen_name"] = u"ゲストさん (未認証)"
    if session.get("id", None):
        tmpl_args["login_toggle"] = u'<a href="./?m=logout">ログアウト</a>'
    else:
        tmpl_args["login_toggle"] = u'<a href="./?m=login">ログイン</a>'

        # デバッグモーーードトグル
    if param.getvalue("debug", None):
        session.set("debug", True)
    elif param.getvalue("debug", None) == 0:
        session.set("debug", None)

    # makoさんおねがいします!(*Location指定があればそっちに飛ばす)
    if http_loc:
        if session.get("debug", None):
            print u""
            print u'<a href="' + http_loc + u'">' + http_loc + u"</a>"
        else:
            print u"Location:" + http_loc
    else:
        print u""
        print tmpl.render(**tmpl_args)

    if session.get("debug", None):
        print u"<BR>"
        for i in locals().keys():
            print i
            print u" = "
            print locals().get(i)
            print u"<BR>"

    # セッション保存
    session.save()
Example #3
0
def main():

	cookie = Cookie.SimpleCookie(os.environ.get("HTTP_COOKIE","")) # クッキーおいしいです
	session = libGAEsession.session_memcache() # セッションDB
	dbq = libmatomotter.q() # 質問用DB
	dba = libmatomotter.a() # 回答用DB


	param = cgi.FieldStorage()

	HOME_URI = conf.dict['HOME_URI']
	auth = tweepy.OAuthHandler(conf.dict['consumer_key'], conf.dict['consumer_secret'], HOME_URI+"?m=callback", True) # tweepy(TwitterAPI)にConsumer keyくわせる
	api = tweepy.API(auth)

	if cookie.has_key("sessionid"): # クッキー埋め込み
		if session.load(cookie["sessionid"].value.decode("ascii")) == None:
			session.new()

	try: # モード取得
		m = param.getvalue("m","").decode("utf-8")
	except: # こけたらクリアする
		m = None

	# HTTP共通ヘッダ部
	print u"Set-Cookie: sessionid=%s; expires=%s; path=/" % (session.getid(),time.strftime("%a, %d-%b-%Y %H:%M:%S GMT",time.gmtime(time.time() + 86400)))
	print u"Content-Type: text/html; charset=UTF-8"


	if m == "login": # 認証前処理

		if session.get("access_key",None) == None:
			url = auth.get_authorization_url()
			session.set("token_secret", auth.request_token.secret)
			session.save()
			print u"Location:"+url
		else:
			auth.set_access_token(session.get("access_key"),session.get("access_secret"))

			try:
				url = HOME_URI
				auth.get_username()
				session.set("id",api.me().id)
				session.set("screen_name",api.me().screen_name)
			except:
				url = auth.get_authorization_url()
				session.set("token_secret", auth.request_token.secret)
			finally:
				print u"Location:"+url

			session.save()


	elif m == "callback": # 認証後処理

		oauth_token = param.getvalue("oauth_token","").decode("utf-8")
		oauth_verifier = param.getvalue("oauth_verifier","").decode("utf-8")

		try:
			auth.set_request_token(oauth_token,session.get("token_secret"))
			auth.get_access_token(oauth_verifier)
			session.set("access_key",auth.access_token.key)
			session.set("access_secret",auth.access_token.secret)
			auth.set_access_token(session.get("access_key"),session.get("access_secret"))
			session.set("id",api.me().id)
			session.set("screen_name",api.me().screen_name)
			url = HOME_URI+session.pop("int_cb","")
		except:
			url = HOME_URI+"?m=login"
		finally:
			print u"Location:"+url

		session.save()


	elif m == "logout": # ログアウト処理

		session.clear()
		session.save()
		print u"Location:"+HOME_URI


	elif m == "make": #質問作成ペーーーーージ
		if param.getvalue("post_flg","0").decode("utf-8"):
			try: # access_keyとaccess_secretが使えるかどうか確認
				auth.set_access_token(session.get("access_key"),session.get("access_secret"))
				username = auth.get_username()
				if not session.get("q_temp",None) == None:
					q = session.get("q_temp")
					session.set("q_temp",None)
					q["id"] = session.get("id")
					q["screen_name"] = session.get("screen_name")
				else:
					q = {
						"theme":param.getvalue("theme","").decode("utf-8"),
						"option0":param.getvalue("option0","").decode("utf-8"),
						"option1":param.getvalue("option1","").decode("utf-8"),
						"option2":param.getvalue("option2","").decode("utf-8"),
						"option3":param.getvalue("option3","").decode("utf-8"),
						"id":session.get("id"),
						"screen_name":session.get("screen_name")
					}
				url = HOME_URI+u"?m=q&id="+str(dbq.set(q))
			except: # 使えなかった場合
				q = {
					"theme":param.getvalue("theme","").decode("utf-8"),
					"option0":param.getvalue("option0","").decode("utf-8"),
					"option1":param.getvalue("option1","").decode("utf-8"),
					"option2":param.getvalue("option2","").decode("utf-8"),
					"option3":param.getvalue("option3","").decode("utf-8")
				}
				session.set("q_temp",q)
				session.set("int_cb","?m=make&post_flg=1")
				url = HOME_URI+u"?m=login"
			finally:
				print u"Location:"+url

			print u""
			session.save()

		else:

			print u""
			try: # access_keyとaccess_secretが使えるかどうか確認
				auth.set_access_token(session.get("access_key"),session.get("access_secret"))
				username = auth.get_username()
				user_status = u'Logged in as @' + username + "(" + str(session.get("id")).encode("utf-8") + ") "
				login = True # 使えたらログインフラグ立つ
			except: # 使えなかった場合
				user_status = u'<a href="?m=login">Login</a>'
				login = False # ログインフラグへし折る
			finally:
				print user_status
				print u'<a href="?m=logout">Logout</a><br>'

			print u'<form method="POST" action="'+HOME_URI+u'?m=make">'
			print u'<input type="hidden" name="post_flg" value="True">'
			print u'<input type="text" name="theme" value=""><br>'
			print u'<input type="text" name="option0" value="">'
			print u'<input type="text" name="option1" value="">'
			print u'<input type="text" name="option2" value="">'
			print u'<input type="text" name="option3" value=""><br>'
			print u'<input type="submit" value="Post">'
			print u'</form>'

	elif m == "q": # 回答ペーーーーーージ
		print u""
		try: # access_keyとaccess_secretが使えるかどうか確認
			auth.set_access_token(session.get("access_key"),session.get("access_secret"))
			username = auth.get_username()
			user_status = u'Logged in as @' + username + "(" + str(session.get("id")).encode("utf-8") + ") "
			login = True # 使えたらログインフラグ立つ
		except: # 使えなかった場合
			user_status = u'<a href="?m=login">Login</a>'
			login = False # ログインフラグへし折る
		finally:
			print user_status
			print u'<a href="?m=logout">Logout</a><br>'

		print u'質問に答えるのれす^q^<br>'
		r = dbq.get(int(param.getvalue("id")))
		print u"しつもん: "+r.get("theme",None)+u"<br>"
		print u'こたえ1: <a href="?m=a&id='+param.getvalue("id")+u'&o=0">'+r.get("option0",None)+u'</a>'
		print u'こたえ2: <a href="?m=a&id='+param.getvalue("id")+u'&o=1">'+r.get("option1",None)+u'</a>'
		print u'こたえ3: <a href="?m=a&id='+param.getvalue("id")+u'&o=2">'+r.get("option2",None)+u'</a>'
		print u'こたえ4: <a href="?m=a&id='+param.getvalue("id")+u'&o=3">'+r.get("option3",None)+u'</a>'

	elif m == "a": # 答えた時の処理^p^

		if param.getvalue("post_flg","0").decode("utf-8"):
			

		elif param.getvalue("id","").decode("utf-8") == "" or  param.getvalue("o","").decode("utf-8") == "" or param.getvalue("uid","").decode("utf-8") == "":
			print u"Location:"+HOME_URI

		else:
			try: # access_keyとaccess_secretが使えるかどうか確認
				auth.set_access_token(session.get("access_key"),session.get("access_secret"))
				username = auth.get_username()
				if not session.get("a_temp",None) == None:
					a = session.get("a_temp")
					session.set("a_temp",None)
					a["referring_id"] = session.get("id")
					a["referring_screen_name"] = session.get("screen_name")
				else:
					a = {
						"qid":param.getvalue("id").decode("utf-8"),
						"referred_id":param.getvalue("uid").decode("utf-8"),
						"referred_screen_name":(api.get_user(param.getvalue("uid").decode("utf-8"))).screen_name,
						"choice":param.getvalue("o").decode("utf-8"),
						"referring_id":session.get("id"),
						"referring_screen_name":session.get("screen_name")
					}
				url = HOME_URI+u"?m=q&id="+str(dba.set(a))
			except: # 使えなかった場合
				a = {
					"qid":param.getvalue("id").decode("utf-8"),
					"referred_id":param.getvalue("uid").decode("utf-8"),
					"referred_screen_name":(api.get_user(param.getvalue("uid").decode("utf-8"))).screen_name,
					"choice":param.getvalue("o").decode("utf-8"),
				}
				session.set("a_temp",a)
				session.set("int_cb","?m=a&post_flg=1")
				url = HOME_URI+u"?m=login"
			finally:
				print u"Location:"+url

			print u""
			session.save()

	else: # トップペーーーージ

		print u""

		try: # access_keyとaccess_secretが使えるかどうか確認
			auth.set_access_token(session.get("access_key"),session.get("access_secret"))
			username = auth.get_username()
			user_status = u'Logged in as @' + username + "(" + str(session.get("id")).encode("utf-8") + ") "
			login = True # 使えたらログインフラグ立つ
		except: # 使えなかった場合
			user_status = u'<a href="?m=login">Login</a>'
			login = False # ログインフラグへし折る
		finally:
			print user_status
			print u'<a href="?m=logout">Logout</a><br>'
			print u'<a href="?m=make">Make Question</a><br>'