R/fbParsers.R

Defines functions fbParserBMUsers fbParserAdConversions fbParserAdVideos fbParserBM fbParserAdCreatives fbParserPages fbParserAdsets fbParserAds fbNullReplacer

# block for parsing helpers function
# check for null
fbNullReplacer <- function(x) {
  
  return(
    ifelse( is.null(x), 
            NA,
            x) 
  )
}

# pasing ads
fbParserAds <- function(x) {
  
  return(
    list(id                = x$id,
         name              = x$name,
         creative_id       = x$creative$id,
         adset_id          = x$adset_id,
         campaign_id       = x$campaign_id,
         account_id        = x$account_id,
         bid_amount        = fbNullReplacer(x$bid_amount) ,
         bid_type          = x$bid_type,
         configured_status = x$configured_status,
         effective_status  = x$effective_status)
  )
  
}

# pasing adsets
fbParserAdsets <- function(x) {
  
  return(
    list(id                = x$id,
         name              = x$name,
         account_id        = x$account_id,
         bid_amount        = fbNullReplacer(x$bid_amount),
         bid_strategy      = fbNullReplacer(x$bid_strategy),
         billing_event     = fbNullReplacer(x$billing_event),
         budget_remaining  = fbNullReplacer(x$budget_remaining) ,
         campaign_id       = x$campaign_id ,
         configured_status = x$configured_status,
         effective_status  = x$effective_status,
         status            = x$status,
         optimization_goal = fbNullReplacer(x$optimization_goal),
         pacing_type       = paste0(x$pacing_type, collapse = ", "),
         destination_type  = fbNullReplacer(x$destination_type),
         daily_budget      = fbNullReplacer(x$daily_budget),
         created_time      = x$created_time,
         source_adset_id   = fbNullReplacer(x$source_adset_id)
         )
  )
  
}

# pasing pages
fbParserPages <- function(x) {
  
  return(
    list(id                = x$id,
         name              = fbNullReplacer(x$name),
         username          = fbNullReplacer(x$username),
         link              = x$link,
         general_info      = fbNullReplacer(x$general_info),
         is_owned          = x$is_owned,
         is_published      = x$is_published,
         about             = fbNullReplacer(x$about),
         business_id       = fbNullReplacer(x$business$id),
         business_name     = fbNullReplacer(x$business$name),
         category          = fbNullReplacer(x$category)
         )
    )
  
}

# pasing ad creatives
fbParserAdCreatives <- function(x) {
  
  if ( ! is.null(x$object_type) ) {
    if ( x$object_type == "VIDEO" ) {
      data_type_name <- "video_data"
    } else {
      data_type_name <- "link_data"
    }
  } else {
      data_type_name <- "unknown"
  }
  
  return(
    list(
      id               = x$id,
      name             = x$name,
      title            = fbNullReplacer(x$title),
      body             = fbNullReplacer(x$body),
      status           = x$status,
      object_type      = fbNullReplacer(x$object_type),
      url_tags         = fbNullReplacer(x$url_tags),
      account_id       = fbNullReplacer(x$account_id),
      page_id          = fbNullReplacer(x$object_story_spec$page_id), 
      link             = ifelse( ! is.null(x$object_story_spec$video_data) , 
                                 fbNullReplacer(x$object_story_spec$video_data$call_to_action$value$link), 
                                 fbNullReplacer(x$object_story_spec$link_data$link)), 
      link_nested      = ifelse(is.null(x$object_story_spec$link_data$child_attachments), 
                                NA, 
                                paste0(lapply(x$object_story_spec$link_data$child_attachments, 
                                              function (x) paste0(x$link)), collapse = ";")), 
      call_to_action   = ifelse(is.null(x$object_story_spec$link_data$call_to_action), 
                                NA, 
                                paste0(lapply(x$object_story_spec$link_data$call_to_action, 
                                              function (x) paste0(x)), collapse = ",")),
      message          = fbNullReplacer(x$object_story_spec[[data_type_name]]$message), 
      caption          = fbNullReplacer(x$object_story_spec$link_data$caption), 
      video_id         = fbNullReplacer(x$object_story_spec$video_data$video_id), 
      attachment_style = fbNullReplacer(x$object_story_spec$link_data$attachment_style), 
      description      = fbNullReplacer(x$object_story_spec$link_data$description), 
      image_hash       = fbNullReplacer(x$object_story_spec[[data_type_name]]$image_hash),
      image_url        = fbNullReplacer(x$image_url)
    )
  )
  
}

# pasing bussines managers
fbParserBM <- function(x) {
  
  return(
    list(id                       = x$id,
         name                     = x$name,
         primary_page_id          = x$primary_page$id,
         primary_page_name        = x$primary_page$name,
         created_by_id            = fbNullReplacer(x$created_by$id),
         created_by_name          = fbNullReplacer(x$created_by$name),
         created_by_business_id   = fbNullReplacer(x$created_by$business$id),
         created_by_business_name = fbNullReplacer(x$created_by$business$name)
  )
  )
  
}

# advideo parser
fbParserAdVideos <- function(x, account_id) {
  
  return(
    list(id                       = x$id,
         video_status             = fbNullReplacer(x$status$video_status),
         processing_progress      = fbNullReplacer(x$status$processing_progress),
         published                = x$published,
         source                   = x$source,
         length                   = x$length,
         icon                     = x$icon,
         content_category         = x$content_category,
         created_time             = x$created_time,
         updated_time             = x$updated_time,
         embeddable               = x$embeddable,
         embed_html               = x$embed_html,
         is_crosspost_video       = x$is_crosspost_video,
         is_crossposting_eligible = x$is_crossposting_eligible,
         is_episode               = x$is_episode,
         is_instagram_eligible    = x$is_instagram_eligible,
         account_id               = account_id)
  )
  
}

# conversions parser
fbParserAdConversions <- function(x) {
  
  return(
    list(id                       = x$id,
         name                     = x$name,
         rule                     = x$rule,
         creation_time            = x$creation_time,
         custom_event_type        = x$custom_event_type,
         default_conversion_value = x$default_conversion_value,
         event_source_type        = x$event_source_type,
         first_fired_time         = fbNullReplacer(x$first_fired_time),
         is_archived              = x$is_archived,
         is_unavailable           = x$is_unavailable,
         pixel_ids                = ifelse(is.null(x$pixel), 
                                           NA, 
                                           paste0(lapply(x$pixel, 
                                                         function (x) paste0(x)), collapse = ",")), 
         retention_days           = x$retention_days,
         account_id               = x$account_id)
  )
  
}

# business users parser
# conversions parser
fbParserBMUsers <- function(x, user_type) {
  
  return(
    list(id            = x$id,
         name          = x$name,
         business_id   = x$business$id,
         business_name = x$business$name,
         role          = x$role,
         first_name    = x$first_name,
         last_name     = x$last_name,
         email         = x$email,
         user_type     = user_type)
  )
  
}

Try the rfacebookstat package in your browser

Any scripts or data that you put into this service are public.

rfacebookstat documentation built on May 31, 2023, 7:27 p.m.