nadeemjq

lib_webuntis.rb

Jan 5th, 2017
57
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Rails 12.54 KB | None | 0 0
  1. module Lib_webuntis
  2.  
  3.   class Tools
  4.     class << self
  5.  
  6.       def fragment_cleaner events
  7.  
  8.         ranges = Hash.new
  9.         result = Hash.new
  10.         result[:schedules_to_remove] = []
  11.         result[:new_end_times] = Hash.new
  12.  
  13.         schedules = Schedule
  14.                                   .select(:start_time, :end_time, :id, :event_id, :type_id)
  15.                                   .where('event_id in (?)', events.ids)
  16.                                   .includes(:course, :event)
  17.  
  18.         schedules_by_groups = schedules.group_by { |schedule| schedule.rooms.pluck(:name).sort.join(",").hash.to_s + schedule.event.title }
  19.  
  20.  
  21.         schedules_by_groups.each do |groups|
  22.  
  23.           schedules_by_course = groups.second.group_by { |schedule| schedule.course.name }
  24.  
  25.           schedules_by_course.each do |schedules_of_course|
  26.  
  27.             schedules_by_lecturers = schedules_of_course.second.group_by { |schedule| schedule.event.lecturers.pluck(:email).sort.join(",").hash }
  28.  
  29.             schedules_by_lecturers.each do |lecturer_schedules|
  30.  
  31.               ranges[groups.first] ||= Hash.new
  32.               ranges[groups.first][schedules_of_course.first] ||= Hash.new
  33.               ranges[groups.first][schedules_of_course.first][lecturer_schedules.first] ||= Array.new
  34.               ranges[groups.first][schedules_of_course.first][lecturer_schedules.first].push lecturer_schedules.second
  35.  
  36.               current_schedule = nil
  37.  
  38.               # schedule_ids to remove
  39.               ranges[groups.first][schedules_of_course.first][lecturer_schedules.first].first.each do |schedule|
  40.  
  41.                 putc schedule.id
  42.                 if current_schedule == nil
  43.  
  44.                   current_schedule = schedule
  45.  
  46.                 else
  47.  
  48.                   # Check time
  49.                   time_difference_in_minutes = (schedule.start_time - current_schedule.end_time)/60
  50.  
  51.                   if time_difference_in_minutes <= 45 && current_schedule != schedule
  52.  
  53.                     current_schedule.end_time = schedule.end_time
  54.  
  55.                     result[:schedules_to_remove].push schedule.id
  56.                     result[:new_end_times][current_schedule.id] = current_schedule.end_time
  57.  
  58.                   else
  59.                     current_schedule = schedule
  60.  
  61.                   end
  62.  
  63.                 end
  64.  
  65.               end
  66.  
  67.             end
  68.  
  69.  
  70.           end
  71.  
  72.         end # // .each do |groups|
  73.  
  74.         events = events
  75.                      .where('schedules.id NOT IN (?)', result[:schedules_to_remove])
  76.  
  77.         events.each do |event|
  78.  
  79.           event.schedules.each do |schedule|
  80.             schedule.end_time = result[:new_end_times][schedule.id] || schedule.end_time
  81.           end
  82.  
  83.         end
  84.  
  85.         events
  86.  
  87.       end
  88.  
  89.     end
  90.  
  91.   end
  92.  
  93.   class Untis
  94.  
  95.     class << self
  96.  
  97.       # GET /clients/3/courses/:id/events
  98.       def get_events_for_course identifier, params
  99.  
  100.         if identifier.is_number?
  101.  
  102.           course = Course.
  103.               where(id: identifier, client_id: params["client_id"]).
  104.               first
  105.  
  106.         else
  107.  
  108.           course = Course.
  109.               where(name: URI.decode(identifier), client_id: params["client_id"]).
  110.               first
  111.  
  112.         end
  113.  
  114.         if course
  115.           # Event.includes(:schedules).where(
  116.           #   course_id: course.id,
  117.           #   schedules: {start_time: }
  118.           #   )
  119.           course.events
  120.  
  121.         else
  122.           Event.none
  123.         end
  124.  
  125.       end
  126.  
  127.       # GET /clients/3/users/:id/events
  128.       def get_events_for_user identifier, params
  129.  
  130.         client = Client.find params["client_id"]
  131.  
  132.         if identifier.is_number?
  133.  
  134.           user = client.
  135.               users.
  136.               where(id: identifier).
  137.               first
  138.  
  139.         elsif identifier.include? '@'
  140.  
  141.           user = client.
  142.               users.
  143.               where(email: URI.decode(identifier)).
  144.               first
  145.  
  146.         else
  147.  
  148.           user = client.
  149.               users.
  150.               where(username: URI.decode(identifier)).
  151.               first
  152.  
  153.         end
  154.  
  155.         if user
  156.  
  157.           user.events
  158.  
  159.         else
  160.  
  161.           Event.none
  162.  
  163.         end
  164.  
  165.       end
  166.  
  167.       # GET /clients/3/groups/:id/events
  168.       def get_events_for_group identifier, params
  169.  
  170.         if identifier.is_number?
  171.  
  172.           group = Group.
  173.               where(id: identifier, client_id: params["client_id"]).
  174.               first
  175.  
  176.         else
  177.  
  178.           group = Group.
  179.               where(name: URI.decode(identifier), client_id: params["client_id"]).
  180.               first
  181.  
  182.         end
  183.  
  184.         if group
  185.  
  186.           group.events
  187.  
  188.         else
  189.  
  190.           Event.none
  191.  
  192.         end
  193.  
  194.       end
  195.  
  196.     end # / class << self
  197.  
  198.   end # / class Untis
  199.  
  200.   class JSON
  201.  
  202.     class << self
  203.  
  204.       def parse_elements_feed data, client
  205.  
  206.         # JSON looks like this
  207.         # - result
  208.         #   - elementIds
  209.         #   - elementPeriods
  210.         #     - ext_id - cotains events
  211.         #       - elements
  212.         #   - elementRoomLocks
  213.         #   - elements
  214.  
  215.         # Types
  216.         # Type 1 - Class
  217.         # Type 2 - User
  218.         # Type 3 - Subject
  219.         # Type 4 - Room
  220.  
  221.         # Let's create the elements first.
  222.         data['elements'].each do |element|
  223.  
  224.           case element['type']
  225.  
  226.             when 1 # a class
  227.  
  228.               group = client.groups.
  229.                   where(name: element['name']).
  230.                   first_or_create(
  231.                       ext_id: element['id'],
  232.                       longName: element['longName']
  233.                   )
  234.  
  235.               group.ext_id = element['id']
  236.               group.save
  237.  
  238.               client.groups << group unless client.groups.include? group
  239.  
  240.             when 2 # a user
  241.  
  242.               email = (element['displayname'].split(',').map { |e| e.strip }).reverse.join('.').downcase + client.main_domain
  243.  
  244.               user = client.users.
  245.                   where(ext_id: element['id']).
  246.                   first_or_create(
  247.                       full_name: element['displayname'],
  248.                       email: email,
  249.                       ext_id: element['id']
  250.                   )
  251.  
  252.               user.ext_id = element['id']
  253.               user.save
  254.  
  255.               client.users << user unless client.users.include? user
  256.  
  257.             when 3 # a subject
  258.  
  259.               course = client.courses.
  260.                   where(name: element['name']).
  261.                   first_or_create(
  262.                       title: element['longName'],
  263.                       ext_id: element['id']
  264.                   )
  265.  
  266.               course.ext_id = element['id']
  267.               course.save
  268.  
  269.               client.courses << course unless client.courses.include? course
  270.  
  271.             when 4 # a room
  272.  
  273.               room = client.rooms.
  274.                   where(name: element['name']).
  275.                   first_or_create(
  276.                       name: element['name'],
  277.                       longName: element['longName'],
  278.                       ext_id: element['id']
  279.                   )
  280.  
  281.               room.ext_id = element['id']
  282.               room.save
  283.  
  284.               client.rooms << room unless client.rooms.include? room
  285.  
  286.             else
  287.  
  288.               false
  289.  
  290.           end
  291.  
  292.         end # / data['elements'].each
  293.  
  294.         # Let's iterate over each lesson to create events and schedules
  295.         data['elementPeriods'].first.second.each do |period|
  296.  
  297.           # Times
  298.           start_time = (period['startTime'].to_s.length == 4) ? period['startTime'] : '0' + period['startTime'].to_s
  299.           end_time = (period['endTime'].to_s.length == 4) ? period['endTime'] : '0' + period['endTime'].to_s
  300.           date = period['date']
  301.  
  302.  
  303.           # Collecting arrays for elements to create associations later
  304.           groups_array = Array.new
  305.           users_array = Array.new
  306.           courses_array = Array.new
  307.           rooms_array = Array.new
  308.  
  309.           # What elements belong to this period?
  310.           period['elements'].each do |element|
  311.  
  312.             case element['type']
  313.  
  314.               when 1 # a class
  315.  
  316.                 group = client.groups.
  317.                     where(ext_id: element['id']).
  318.                     first
  319.  
  320.                 groups_array.push group
  321.  
  322.               when 2 # a user
  323.  
  324.                 user = client.users.
  325.                     where(ext_id: element['id']).
  326.                     first
  327.  
  328.                 users_array.push user
  329.  
  330.               when 3 # a subject
  331.  
  332.                 course = client.courses.
  333.                     where(ext_id: element['id']).
  334.                     first
  335.  
  336.                 courses_array.push course
  337.  
  338.               when 4 # a room
  339.  
  340.                 room = client.rooms.
  341.                     where(ext_id: element['id']).
  342.                     first
  343.  
  344.                 rooms_array.push room
  345.  
  346.               else
  347.  
  348.                 false
  349.  
  350.             end
  351.  
  352.           end # /period['elements'].each
  353.  
  354.           if users_array.count < 1
  355.  
  356.             ghost_user = client.users.where(username: 'admin').first_or_create(
  357.                 first_name:'Admin',
  358.                 last_name: 'Mode',
  359.                 full_name: 'Admin Mode',
  360.                 email: 'admin.mode@' + client.main_domain,
  361.                 auxillary: true
  362.             )
  363.             client.users << ghost_user unless ghost_user.clients.include? client
  364.             users_array.push  ghost_user
  365.           end
  366.  
  367.           # The ext_id of events is unique only for a given Client and Course combo, or so I hope.
  368.  
  369.           courses_array.each do |course|
  370.  
  371.             # Transitionary code:
  372.             # Let's find duplicate schedules in other events.
  373.             # This shouldn't really be neccessary if we started from scratch
  374.             related_course_ids = client.courses.where(name: course.name).pluck(:id)
  375.  
  376.             related_events_ids = Event.where(course_id: related_course_ids, title: course.name).pluck(:id)
  377.  
  378.             # Create schedule, but check to see if it already exists
  379.             # Remember: If a and b are in the same place at the same time, then a = b
  380.             schedule = Schedule
  381.                            .includes(event: :groups)
  382.                            .includes(event: :users)
  383.                            .where(
  384.                                start_time: Time.zone.parse("#{date} #{start_time}"),
  385.                                end_time: Time.zone.parse("#{date} #{end_time}"),
  386.                                event_id: related_events_ids,
  387.                                groups: {id: (groups_array.map { |group| group.id })},
  388.                                users: {id: (users_array.map { |user| user.id })}
  389.  
  390.                            ).first
  391.  
  392.             if schedule
  393.  
  394.               event = Event.includes(:schedules).includes(:users).where(id: schedule.event_id).first
  395.  
  396.             else
  397.  
  398.               # If doesnt exist already
  399.               # Find event
  400.               event = course.events.create!(
  401.                   title: course.name,
  402.                   ext_id: period['id']
  403.               )
  404.               event.ext_id = period['id']
  405.               event.save
  406.  
  407.               schedule = Schedule
  408.                              .create(
  409.                                  start_time: Time.zone.parse("#{date} #{start_time}"),
  410.                                  end_time: Time.zone.parse("#{date} #{end_time}"),
  411.                                  event_id: event.id
  412.                              )
  413.  
  414.               event = Event.includes(:schedules).includes(:users).where(id: schedule.event_id).first
  415.  
  416.             end
  417.  
  418.             # Add relations
  419.             event.schedules << schedule unless event.schedules.include? schedule
  420.  
  421.             # Groups
  422.             groups_array.each do |group|
  423.               group.events << event unless group.events.include? event
  424.             end
  425.  
  426.             # Users
  427.             users_array.each do |user|
  428.  
  429.               event.users << user unless event.users.include? user
  430.  
  431.               user.add_role :lecturer, event unless user.has_role? :lecturer, event
  432.  
  433.             end
  434.  
  435.             # Rooms
  436.  
  437.             rooms_array.each do |room|
  438.  
  439.               room.schedules << schedule unless room.schedules.include? schedule
  440.  
  441.             end
  442.  
  443.             # Delete events with empty titles
  444.             if event.title.nil?
  445.               event.destroy
  446.             end
  447.  
  448.           end # /courses_array.each
  449.  
  450.  
  451.         end # / data['elementPeriods'].each
  452.         nil
  453.       end # / parse_elements_feed
  454.  
  455.     end # class << self
  456.  
  457.   end # class JSON
  458.  
  459. end # module Lib_webuntis
  460.  
  461. #Extend class string
  462. class String
  463.   def is_number?
  464.     true if Float(self) rescue false
  465.   end
  466. end
Add Comment
Please, Sign In to add comment