func_render.py 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. from .func_tool import *
  2. from .func_render_namumark import class_do_render_namumark
  3. # 커스텀 마크 언젠간 다시 추가 예정
  4. class class_do_render:
  5. def __init__(self, conn, lang_data = {}):
  6. self.conn = conn
  7. if lang_data == '{}':
  8. lang_data = {
  9. 'toc' : 'toc',
  10. 'category' : 'category'
  11. }
  12. self.lang_data = lang_data
  13. def do_render(self, doc_name, doc_data, data_type, data_in):
  14. curs = self.conn.cursor()
  15. doc_set = {}
  16. if data_type == 'from':
  17. doc_set['doc_from'] = 'O'
  18. data_type = 'view'
  19. data_in = (data_in + '_') if data_in != '' else ''
  20. doc_set['doc_include'] = data_in
  21. rep_data = ''
  22. if rep_data == '' and doc_name != '':
  23. curs.execute(db_change("select set_data from data_set where doc_name = ? and set_name = 'document_markup'"), [doc_name])
  24. db_data = curs.fetchall()
  25. if db_data and db_data[0][0] != '' and db_data[0][0] != 'normal':
  26. rep_data = db_data[0][0]
  27. if rep_data == '':
  28. curs.execute(db_change('select data from other where name = "markup"'))
  29. db_data = curs.fetchall()
  30. rep_data = db_data[0][0] if db_data else 'namumark'
  31. if rep_data == 'namumark' or rep_data == 'namumark_beta':
  32. data_end = class_do_render_namumark(
  33. curs,
  34. doc_name,
  35. doc_data,
  36. doc_set,
  37. self.lang_data
  38. )()
  39. elif rep_data == 'raw':
  40. data_end = [
  41. html.escape(doc_data).replace('\n', '<br>'),
  42. '',
  43. {}
  44. ]
  45. else:
  46. data_end = [
  47. doc_data,
  48. '',
  49. {}
  50. ]
  51. if data_type == 'thread' or data_type == 'api_thread':
  52. def do_thread_a_change(match):
  53. data = match[2].replace('#', '')
  54. data_split = data.split('-')
  55. if match[1] == 'topic_a' or len(data_split) == 1:
  56. return '<a href="' + match[2] + '">' + match[2] + '</a>'
  57. elif match[1] == 'topic_a_post' and len(data_split) == 3:
  58. return '<a href="/bbs/w/' + data_split[2] + '/' + data_split[1] + '#' + data_split[0] + '">#' + data_split[0] + '-' + data_split[1] + '</a>'
  59. elif len(data_split) == 2:
  60. return '<a href="/thread/' + data_split[1] + '#' + data_split[0] + '">' + match[2] + '</a>'
  61. else:
  62. return ''
  63. data_end[0] = re.sub(
  64. r'&lt;(topic_a(?:_post|_thread)?)&gt;((?:(?!&lt;\/topic_a(?:_post|_thread)?&gt;).)+)&lt;\/topic_a(?:_post|_thread)?&gt;',
  65. do_thread_a_change,
  66. data_end[0]
  67. )
  68. data_end[0] = re.sub(
  69. r'&lt;topic_call&gt;@(?P<in>(?:(?!&lt;\/topic_call&gt;).)+)&lt;\/topic_call&gt;',
  70. '<a href="/w/user:\\g<in>">@\\g<in></a>',
  71. data_end[0]
  72. )
  73. if data_type == 'backlink':
  74. if 'backlink' in data_end[2]:
  75. backlink = data_end[2]['backlink']
  76. else:
  77. backlink = []
  78. if backlink != []:
  79. curs.executemany(db_change("insert into back (link, title, type, data) values (?, ?, ?, ?)"), data_end[2]['backlink'])
  80. curs.execute(db_change("delete from back where title = ? and type = 'no'"), [doc_name])
  81. self.conn.commit()
  82. return [
  83. data_end[0],
  84. data_end[1],
  85. data_end[2]
  86. ]