亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? lj_journal.py

?? pyLJclient是一個跨平臺的livejournal客戶端
?? PY
字號:
# pyLJclient - a python based live journal client with a wxPython gui
# Copyright (C) 2002 Sameer Chowdhury
# refer to "about this software.txt" for info on licensing

from lj import lj_procs, friend, posted_event, friend_groups
from lj.lj_exceptions import *
from lj.moods import Moods, Mood
import string, re, time

# OO layer that sits on top of lj_procs.  Not really optimized, so all 
# re expressions compiled on the fly for now.

class LJ_Journal:
    def __init__(self, username='', password='', name='', hpassword=''):
        self.username = username
	if hpassword:
	    self.hpassword=hpassword
	    self.password = ''
	elif password:
	    self.password = password
	    self.hpassword=''
        self.name = name
	self.journal_access_list = []
	self.pic_url_association = {}
	self.ljfastserver = 0
	self.moods = Moods()
        if self.username and (self.hpassword or self.password):
            self.login()


    def getUser(self):
	return self.username

    # logs in to the online journal
    # sets the ljfastserver for subsequent responses, if it is found
    # sets the journal_access_list, a list of journals that can be posted to
    # updates the child object moods with the current moods
    def login(self):
	if self.hpassword:
	    raw = lj_procs.login(self.username, hpassword = self.hpassword, 
			    mood_index=self.moods.getmoodcount())
	else:
	    raw = lj_procs.login(self.username, self.password, mood_index=self.moods.getmoodcount())
        login_response = self._process_login_string(raw)
        if login_response['success'] != 'OK':
            raise UnknownUser("Invalid username or password")
        self.name = login_response['name']
	try:
	    self.ljfastserver = login_response['fastserver']
	except:
	    self.ljfastserver = 0
	self._populate_access_journals(login_response)
	if login_response.has_key('mood_count') and (int(login_response['mood_count']) > 0):
	    self._extract_moods(login_response)
	if login_response.has_key('pickw_count') and (int(login_response['pickw_count']) > 0):
	    self._populate_pics_with_urls(login_response)
	self._extract_friend_groups(login_response)

    def getmoods(self):
	return self.moods

    def get_pic_url_association(self):
	return self.pic_url_association

    # returns a list of Friend objects    
    def get_friends(self):
	if self.hpassword:
	    raw_result = lj_procs.friendof(self.username, hpassword=self.hpassword)
	else:
	    raw_result = lj_procs.friendof(self.username, self.password) 
        friends_list = self._process_friends_list(raw_result)
        return friends_list

    def getWriteJournals(self):
	return self.journal_access_list

    def add_mood_args(self, mood):
	return {'prop_current_mood':mood}

    def add_mood_pic(self, mood_pic):
	return {'prop_picture_keyword': mood_pic}

    def add_mood_id(self, mood_id):
	return {'prop_current_moodid':mood_id}

    def add_current_music(self, music):
	return {'prop_current_music':music}

    # returns an Event object
    def post_event(self, new_event):
	evt = new_event.getBodyText()
	subject = new_event.getSubjectText()
	security_mask = new_event.get_security_group().get_mask()
	if security_mask:
	    security='usemask'
	else:
	    security = new_event.get_security_group().get_name()
	journal = new_event.getPostJournal()
	time_stamp = new_event.getTimeStamp()
	year = time_stamp.getYear()
	mon = time_stamp.getMonth()
	day = time_stamp.getDay()
	hour = time_stamp.getHour()
	min = time_stamp.getMinute()
	mood = new_event.getMood()
	mood_id = new_event.getMoodID()
	mood_pic = new_event.getMoodPic()
	current_music = new_event.getMusic()
	print "security name: %s"%security
	print "security mask: %s"%security_mask
	prop_items = {}
	if mood:
	    prop_items.update(self.add_mood_args(mood))
	if mood_pic:
	    prop_items.update(self.add_mood_pic(mood_pic))
	if mood_id:
	    prop_items.update(self.add_mood_id(mood_id))
	if current_music:
	    prop_items.update(self.add_current_music(current_music))
	if self.hpassword:
	    raw_result = lj_procs.postevent(self.username, hpassword=self.hpassword, event = evt, 
		subject=subject, security=security, allowmask=security_mask, journal=journal,
		year=year, mon=mon, day=day, hour=hour, min=min, fastserver=self.ljfastserver,
		prop_items=prop_items)
	else:
	    raw_result = lj_procs.postevent(self.username, self.password, event = evt, 
		subject = subject, security = security, allowmask = security_mask, journal = journal, 
		year=year, mon=mon, day=day, hour=hour, min=min, fastserver=self.ljfastserver, 
		prop_items = prop_items)
	# print "lj user post_event result:\n%s"%raw_result
	self._process_event_string(raw_result)
        return 1

    def get_events_by_day(self, day, month=time.localtime()[1],
                          year=time.localtime()[0]):
        raw = lj_procs.getevents(self.username, self.password, 'day',
                                 year,month,day)
        return self._process_event(raw)

    def friendof(self):
        raw = lj_procs.friendof(self.username, self.password)
        friends_list = self._process_friends_list(raw)
        return friends_list

    # not properly implemented, just returns the raw result
    # no processing performed on string returned
    # this is because i don't see it used anywhere
    def getfriendgroups(self):
        raw = lj_procs.getfriendgroups(self.username, self.password)
        return raw
    
    def delete_event(self, itemid):
	if self.hpassword:
	    raw = lj_procs.editevent(self.username, hpassword = self.hpassword, itemid= itemid, event='')
	else: 
	    raw = lj_procs.editevent(self.username, self.password, itemid= itemid, event='')
        response_dict = self._dictify_return_string(raw)
        self._perform_basic_error_checking(response_dict)
        return 1

    def edit_event(self, itemid, evt, subject=''):
	if self.hpassword:
	    raw = lj_procs.editevent(self.username, hpassword= self.hpassword, itemid=itemid,
		event=evt, subject=subject)
	else:
	    raw = lj_procs.editevent(self.username, self.password, itemid=itemid, event=evt,
		subject=subject)
        response_dict = self._dictify_return_string(raw)
        self._perform_basic_error_checking(response_dict)
        return 1
    
    def checkfriends(self):
	if self.hpassword:
	    raw = lj_procs.checkfriends(self.username, hpassword = self.hpassword)
	else:
	    raw = lj_procs.checkfriends(self.username, self.password)
        response_dict = self._dictify_return_string(raw)
        self._perform_basic_error_checking(response_dict)
        if response_dict['new'] == '1':
            return 1
        else:
            return 0
    
    def get_friend_groups(self):
	return self.groups

    #------------ functions for internal use------------------------------------------ 
    
    def _extract_friend_groups(self, login_response):
	print "--------- extracting friend groups --------"
	temp_group_list = friend_groups.Groups()
	temp_group_list.initialize_defaults()
	for key, val in login_response.items():
	    pat = "^frgrp_(?P<id>[\d]+)_name$"
	    result = re.search(pat, key)
	    if result:
		group_name = val
		group_number = result.group('id')
		group_sort_order = login_response['frgrp_'+result.group('id')+'_sortorder']
		new_group = friend_groups.User_Defined_Group(group_name, group_number, group_sort_order)
		temp_group_list.add_group(new_group) 
	print "temp group list ----->"
	print temp_group_list
	self.groups = temp_group_list


    def _extract_moods(self, login_response):
	print "--------------- In extract_moods ---------------"
	temp_moods_list = []
	for key, val in login_response.items():
	    pat = "^mood_(?P<id>[\d]+)_id$"
	    result = re.search(pat, key)
	    if result:
		mood_id = val
		mood_val = login_response['mood_'+result.group('id')+'_name']
		temp_moods_list.append(Mood(mood_id, mood_val))
		# print mood_id, '------', mood_val
	self.moods.update(temp_moods_list)	
    
    def _populate_pics_with_urls(self, login_response):
	print "---------------- Now building association of pic names with urls --------------------"
	temp_pic_association = {}
	for key, val in login_response.items():
	    pat = "^pickw_(?P<id>[\d]+)$"
	    result = re.search(pat, key)
	    if result:
		print "pic keyword name: (%s) found"%val
		pick_name = val
		pick_url = login_response['pickwurl_'+result.group('id')]
		print "associate url (%s) found"%pick_url
		temp_pic_association[pick_name] = pick_url
	print temp_pic_association
	self.pic_url_association.update(temp_pic_association)

    #helper string processing function for get_friends function
    def _process_friends_list(self, start_string):
        basic_tokens = start_string.split('\n')
        friends_list = []
        #------------state machine below----------------------
        #after friend_name has been found the machine goes into the state of
        #waiting for the friend_user_name to come along.  Once a friend_user
        #name has been found the machine is set to start state again, which
        #is to look for friend_name.  I wish i could just include a link
        #from here to a jpg or better yet, interactive image of this state
        #machine alas my ide is not so advanced yet.
        friend_name_found = 0
        for token in basic_tokens:
            if friend_name_found == 1:
                    if re.compile("^friendof_[\d]+_user$").search(token):
                        friend_user = basic_tokens[basic_tokens.index(token)+1]
                        a_friend = friend.Friend(friend_name, friend_user)
                        friends_list.append(a_friend)
                        friend_name_found = 0
            else:
                if re.compile("^friendof_[\d]+_name$").search(token):
                    friend_name = basic_tokens[basic_tokens.index(token)+1]
                    friend_name_found = 1
        return friends_list                
    
    # helper string processing function for post_event function 
    def _process_event_string(self, raw):
        response_dict = self._dictify_return_string(raw)
        self._perform_basic_error_checking(response_dict)
        #return event.Event(response_dict['itemid'])

    def _perform_basic_error_checking(self, response_dict):
        if response_dict['success'] == 'FAIL':
            raise "EVENT UNSUCCESSFUL, %s"%response_dict['errmsg']
        
    def _process_event(self, raw_event):
        tokens = string.split(raw_event,'\n')
        evt, evt_time, itemid, security, subject = '', '', '', '', ''
        events = []
        # start feeding the state machine with tokens
        # i is the current position of the input tape
        i = 0
        while (i < len(tokens)):
            # search for event start marker
            if re.compile("^events_[\d]+_event$").search(tokens[i]):
                # jump to state 2, keep feeding data into event string
                # as long as eventtime marker has not been found
                i = i + 1
                while(1):
                    if re.compile("^events_[\d]+_eventtime$").search(tokens[i]):
                        break
                    evt = evt + tokens[i]
                    i = i + 1
                # move marker to the evt_time value
                i = i + 1
                # now marker is on time, read it into the time variable
                evt_time = tokens[i]
                # skip over itemid label and move directly to its value
                i= i + 2
                # store itemid variable
                itemid = tokens[i]
                # advance marker to next token
                i = i + 1
                # now detect if there is an optional security item
                if re.compile("^events_[\d]+_security$").search(tokens[i]):
                    i = i + 1
                    security = tokens[i]
                    i = i + 1
                # now detect if there is a subject
                # if there is, advance marker and read its value into variable
                if re.compile("^events_[\d]+_subject$").search(tokens[i]):
                    i = i + 1
                    subject = tokens[i]
                event_obj = posted_event.Event(itemid, evt, evt_time,
                                        subject, security)
                events.append(event_obj)
                evt, evt_time, itemid, security, subject = '', '', '', '', ''
            i = i + 1
        return events
        
    # extract name value pairs from raw string returned by livejournal
    def _dictify_return_string(self, raw):
        response_properties = {}
        # split into words 
        tokens = string.split(raw, '\n')
        # split function leaves a dangling item at the end of the list
        # so truncate it
        tokens = tokens[:-1]
        #iterate through each name, and add name-value to response_properties
        for i in xrange(0, len(tokens), 2):
            response_properties[tokens[i]]=tokens[i+1]
        return response_properties     
        
    def _process_login_string(self, login_string):
        result = self._dictify_return_string(login_string)
        return result
    
    def _populate_access_journals(self, dictified_response):
	for key, val in dictified_response.items():
	    if re.compile("^access_[\d]+$").search(key):
		self.journal_access_list.append(val)
	self.journal_access_list.insert(0, self.username)
        

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品理论片| 国产精品国产自产拍高清av| 午夜亚洲国产au精品一区二区| 91在线播放网址| 亚洲精选免费视频| 欧美久久久久久久久久| 六月丁香婷婷色狠狠久久| 精品国产伦理网| 不卡一区在线观看| 一区二区三区四区中文字幕| 51精品久久久久久久蜜臀| 麻豆精品国产传媒mv男同| 久久精品欧美一区二区三区不卡 | 久久综合久久鬼色| 丁香六月综合激情| 一区二区三区久久| 欧美tickling网站挠脚心| 欧美电视剧免费全集观看| 国产麻豆午夜三级精品| 悠悠色在线精品| 日韩欧美国产精品一区| 不卡一区二区三区四区| 亚洲一二三区在线观看| 日韩亚洲欧美高清| 不卡电影一区二区三区| 五月天婷婷综合| 丰满少妇久久久久久久| 中文字幕在线一区免费| 欧美日韩五月天| 国产精品99久久久久久似苏梦涵| 亚洲激情第一区| 日韩精品一区二区三区在线播放| www.日韩精品| 免费在线看成人av| 一区二区三区在线看| 欧美精品一区男女天堂| 一本在线高清不卡dvd| 精品综合久久久久久8888| 日韩一区欧美小说| 精品久久久久久久一区二区蜜臀| 日本韩国精品在线| 国产美女在线精品| 成人亚洲一区二区一| 石原莉奈一区二区三区在线观看| 欧美激情一二三区| 日韩视频免费观看高清完整版在线观看 | 国产精品白丝av| 亚洲电影欧美电影有声小说| 国产亚洲短视频| 欧美一区午夜视频在线观看| 91免费视频网址| 顶级嫩模精品视频在线看| 日av在线不卡| 亚洲成人你懂的| 亚洲精品免费播放| 久久99国产精品免费网站| 亚洲国产三级在线| 国产精品家庭影院| 久久精品人人做| 精品国产三级a在线观看| 欧美日韩国产高清一区二区| 91久久人澡人人添人人爽欧美| 国产凹凸在线观看一区二区| 久国产精品韩国三级视频| 三级欧美韩日大片在线看| 亚洲一区免费观看| 亚洲男人的天堂在线aⅴ视频| 国产资源在线一区| 国产精品色噜噜| 欧美精品一区二区三区很污很色的| 欧美日韩成人综合天天影院| 色悠悠亚洲一区二区| 成人av资源在线| 成人午夜免费视频| 国产成人在线视频播放| 337p亚洲精品色噜噜| 欧美三级视频在线| 欧美精品一二三四| 欧美日韩国产精选| 91精品一区二区三区在线观看| 欧美色视频在线观看| 日本韩国一区二区| 欧美日韩aaaaaa| 欧美高清一级片在线| 欧美另类一区二区三区| 欧美一区二区三区免费观看视频 | 国产成人精品免费在线| 国产做a爰片久久毛片| 国产成人免费av在线| 成人一区二区视频| 91麻豆精品视频| 欧美亚洲国产一区在线观看网站| 欧美亚洲愉拍一区二区| 4438x成人网最大色成网站| 日韩视频一区二区三区在线播放| 2023国产一二三区日本精品2022| 国产人妖乱国产精品人妖| 国产精品久久久久久久久久免费看| 亚洲欧洲成人av每日更新| 国产一区二三区| 久久精品99国产国产精| 国产麻豆视频精品| 国产三级三级三级精品8ⅰ区| 欧美国产丝袜视频| 亚洲综合区在线| 亚洲超碰精品一区二区| 久久se这里有精品| 欧美精品一区视频| 国产精品国产三级国产有无不卡| 亚洲免费在线视频一区 二区| 日本va欧美va精品发布| 丝袜亚洲精品中文字幕一区| 精品一区二区日韩| 国产日韩v精品一区二区| 国产精品超碰97尤物18| 午夜精品福利久久久| 国产乱码精品一品二品| 欧美在线免费播放| 久久久午夜精品| 亚洲精品福利视频网站| 精品亚洲国内自在自线福利| 91小视频免费看| 欧美大片顶级少妇| 一区二区三区不卡视频 | 免费观看日韩电影| 成人欧美一区二区三区小说 | 欧美色精品天天在线观看视频| 精品国产99国产精品| 一区免费观看视频| 久久99精品久久久久久久久久久久| 99久久夜色精品国产网站| 日韩一区二区三区电影| 一区二区激情小说| 国产成人av电影在线| 欧美日韩二区三区| 亚洲欧美日韩系列| 国产成人精品三级麻豆| 精品奇米国产一区二区三区| 亚洲一区二区三区四区不卡| 成人黄色电影在线| 久久亚洲精精品中文字幕早川悠里| 亚洲成在人线免费| 91网址在线看| 国产精品视频yy9299一区| 久久99久久精品| 91精品国产免费| 亚洲国产另类av| 一本大道久久a久久精二百| 国产视频一区二区在线| 精品亚洲免费视频| 制服.丝袜.亚洲.另类.中文| 亚洲自拍偷拍欧美| 99re成人精品视频| 国产精品狼人久久影院观看方式| 久久99国产精品久久99| 日韩欧美一区二区视频| 亚洲高清三级视频| 欧美无砖砖区免费| 亚洲夂夂婷婷色拍ww47| 色偷偷成人一区二区三区91| 国产精品国产三级国产aⅴ入口| 国产精品系列在线播放| 国产性色一区二区| 国产一区二区三区综合| 久久这里只精品最新地址| 狠狠色狠狠色综合| 2023国产一二三区日本精品2022| 欧美一级免费观看| 日韩国产在线一| 91精品欧美福利在线观看| 日韩电影在线一区| 91麻豆精品国产| 蜜桃一区二区三区在线观看| 日韩一卡二卡三卡国产欧美| 久久精品国内一区二区三区| 精品sm在线观看| 国产精品一区专区| 国产精品久久久久久久久免费相片 | 国产亚洲一区二区三区四区| 国产真实乱对白精彩久久| 久久综合色8888| 成人性色生活片免费看爆迷你毛片| 久久综合久久99| 成人激情av网| 亚洲精品国产a| 欧美高清性hdvideosex| 久久国内精品视频| 国产欧美va欧美不卡在线| 色综合久久88色综合天天6 | 成a人片亚洲日本久久| 亚洲欧美电影院| 欧美伦理电影网| 久久超碰97人人做人人爱| 久久久www成人免费毛片麻豆 | 麻豆91在线观看| 国产精品妹子av| 欧美日韩国产美| 国产一区在线观看视频| 日韩理论片中文av| 91麻豆精品91久久久久同性|