buddypress/bp-activity.php
Andy Peatling c927cd01a3 updating internal version numbers
git-svn-id: https://buddypress.svn.wordpress.org/trunk@1460 cdf35c40-ae34-48e0-9cc9-0c9da1808c22
2009-04-30 18:15:15 +00:00

307 lines
No EOL
11 KiB
PHP

<?php
define ( 'BP_ACTIVITY_VERSION', '1.0' );
define ( 'BP_ACTIVITY_DB_VERSION', '1300' );
/* Define the slug for the component */
if ( !defined( 'BP_ACTIVITY_SLUG' ) )
define ( 'BP_ACTIVITY_SLUG', 'activity' );
/* How long before activity items in streams are re-cached? */
if ( !defined( 'BP_ACTIVITY_CACHE_LENGTH' ) )
define ( 'BP_ACTIVITY_CACHE_LENGTH', '6 HOURS' );
require ( BP_PLUGIN_DIR . '/bp-activity/bp-activity-classes.php' );
require ( BP_PLUGIN_DIR . '/bp-activity/bp-activity-templatetags.php' );
require ( BP_PLUGIN_DIR . '/bp-activity/bp-activity-widgets.php' );
require ( BP_PLUGIN_DIR . '/bp-activity/bp-activity-cssjs.php' );
require ( BP_PLUGIN_DIR . '/bp-activity/bp-activity-filters.php' );
/**************************************************************************
bp_bp_activity_install()
Sets up the component ready for use on a site installation.
**************************************************************************/
function bp_activity_install() {
global $wpdb, $bp;
if ( !empty($wpdb->charset) )
$charset_collate = "DEFAULT CHARACTER SET $wpdb->charset";
$sql[] = "CREATE TABLE {$bp->activity->table_name_user_activity} (
id bigint(20) NOT NULL AUTO_INCREMENT PRIMARY KEY,
user_id bigint(20) NOT NULL,
component_name varchar(75) NOT NULL,
component_action varchar(75) NOT NULL,
item_id bigint(20) NOT NULL,
secondary_item_id bigint(20) NOT NULL,
date_recorded datetime NOT NULL,
is_private tinyint(1) NOT NULL DEFAULT 0,
no_sitewide_cache tinyint(1) NOT NULL DEFAULT 0,
KEY item_id (item_id),
KEY user_id (user_id),
KEY is_private (is_private),
KEY component_name (component_name)
) {$charset_collate};";
$sql[] = "CREATE TABLE {$bp->activity->table_name_user_activity_cached} (
id bigint(20) NOT NULL AUTO_INCREMENT PRIMARY KEY,
user_id bigint(20) NOT NULL,
component_name varchar(75) NOT NULL,
component_action varchar(75) NOT NULL,
content longtext NOT NULL,
primary_link varchar(150) NOT NULL,
item_id bigint(20) NOT NULL,
secondary_item_id bigint(20) NOT NULL,
date_cached datetime NOT NULL,
date_recorded datetime NOT NULL,
is_private tinyint(1) NOT NULL DEFAULT 0,
KEY date_cached (date_cached),
KEY date_recorded (date_recorded),
KEY is_private (is_private),
KEY user_id (user_id),
KEY item_id (item_id),
KEY component_name (component_name)
) {$charset_collate};";
$sql[] = "CREATE TABLE {$bp->activity->table_name_sitewide} (
id bigint(20) NOT NULL AUTO_INCREMENT PRIMARY KEY,
user_id bigint(20) NOT NULL,
item_id bigint(20) NOT NULL,
secondary_item_id bigint(20),
content longtext NOT NULL,
primary_link varchar(150) NOT NULL,
component_name varchar(75) NOT NULL,
component_action varchar(75) NOT NULL,
date_cached datetime NOT NULL,
date_recorded datetime NOT NULL,
KEY date_cached (date_cached),
KEY date_recorded (date_recorded),
KEY user_id (user_id),
KEY item_id (item_id),
KEY component_name (component_name)
) {$charset_collate};";
require_once( ABSPATH . 'wp-admin/upgrade-functions.php' );
dbDelta($sql);
if ( '' == get_site_option( 'bp-activity-db-merge' ) || !get_site_option( 'bp-activity-db-merge' ) ) {
$users = $wpdb->get_col( "SELECT ID FROM " . CUSTOM_USER_TABLE );
foreach ( $users as $user_id ) {
BP_Activity_Activity::convert_tables_for_user( $user_id );
BP_Activity_Activity::kill_tables_for_user( $user_id );
}
add_site_option( 'bp-activity-db-merge', 1 );
}
update_site_option( 'bp-activity-db-version', BP_ACTIVITY_DB_VERSION );
}
/**************************************************************************
bp_activity_setup_globals()
Set up and add all global variables for this component, and add them to
the $bp global variable array.
**************************************************************************/
function bp_activity_setup_globals() {
global $bp, $wpdb, $current_blog;
$bp->activity->table_name_user_activity = $wpdb->base_prefix . 'bp_activity_user_activity';
$bp->activity->table_name_user_activity_cached = $wpdb->base_prefix . 'bp_activity_user_activity_cached';
$bp->activity->table_name_sitewide = $wpdb->base_prefix . 'bp_activity_sitewide';
$bp->activity->image_base = BP_PLUGIN_URL . '/bp-activity/images';
$bp->activity->slug = BP_ACTIVITY_SLUG;
$bp->version_numbers->activity = BP_ACTIVITY_VERSION;
if ( is_site_admin() && get_site_option( 'bp-activity-db-version' ) < BP_ACTIVITY_DB_VERSION )
bp_activity_install();
}
add_action( 'plugins_loaded', 'bp_activity_setup_globals', 5 );
add_action( 'admin_menu', 'bp_activity_setup_globals', 1 );
function bp_activity_setup_root_component() {
/* Register 'groups' as a root component */
bp_core_add_root_component( BP_ACTIVITY_SLUG );
}
add_action( 'plugins_loaded', 'bp_activity_setup_root_component', 1 );
/**************************************************************************
bp_activity_setup_nav()
Set up front end navigation.
**************************************************************************/
function bp_activity_setup_nav() {
global $bp;
/* Add 'Activity' to the main navigation */
bp_core_add_nav_item( __('Activity', 'buddypress'), $bp->activity->slug );
bp_core_add_nav_default( $bp->activity->slug, 'bp_activity_screen_my_activity', 'just-me' );
$activity_link = $bp->loggedin_user->domain . $bp->activity->slug . '/';
/* Add the subnav items to the activity nav item */
bp_core_add_subnav_item( $bp->activity->slug, 'just-me', __('Just Me', 'buddypress'), $activity_link, 'bp_activity_screen_my_activity' );
bp_core_add_subnav_item( $bp->activity->slug, 'my-friends', __('My Friends', 'buddypress'), $activity_link, 'bp_activity_screen_friends_activity', 'activity-my-friends', bp_is_home() );
if ( $bp->current_component == $bp->activity->slug ) {
if ( bp_is_home() ) {
$bp->bp_options_title = __( 'My Activity', 'buddypress' );
} else {
$bp->bp_options_avatar = bp_core_get_avatar( $bp->displayed_user->id, 1 );
$bp->bp_options_title = $bp->displayed_user->fullname;
}
}
}
add_action( 'wp', 'bp_activity_setup_nav', 2 );
add_action( 'admin_menu', 'bp_activity_setup_nav', 2 );
/***** Screens **********/
function bp_activity_screen_my_activity() {
do_action( 'bp_activity_screen_my_activity' );
bp_core_load_template( apply_filters( 'bp_activity_template_my_activity', 'activity/just-me' ) );
}
function bp_activity_screen_friends_activity() {
do_action( 'bp_activity_screen_friends_activity' );
bp_core_load_template( apply_filters( 'bp_activity_template_friends_activity', 'activity/my-friends' ) );
}
/***** Actions **********/
function bp_activity_record( $item_id, $component_name, $component_action, $is_private, $secondary_item_id = false, $user_id = false, $secondary_user_id = false, $recorded_time = false ) {
global $bp, $wpdb;
if ( !$user_id )
$user_id = $bp->loggedin_user->id;
if ( !$recorded_time )
$recorded_time = time();
$activity = new BP_Activity_Activity;
$activity->item_id = $item_id;
$activity->secondary_item_id = $secondary_item_id;
$activity->user_id = $user_id;
$activity->component_name = $component_name;
$activity->component_action = $component_action;
$activity->date_recorded = $recorded_time;
$activity->is_private = $is_private;
$loggedin_user_save = $activity->save();
/* Save an activity entry for both logged in and secondary user. For example for a new friend connection
you would want to show "X and Y are now friends" on both users activity stream */
if ( $secondary_user_id ) {
$activity = new BP_Activity_Activity;
$activity->item_id = $item_id;
$activity->user_id = $secondary_user_id;
$activity->component_name = $component_name;
$activity->component_action = $component_action;
$activity->date_recorded = $recorded_time;
$activity->is_private = $is_private;
// We don't want to record this on the sitewide stream, otherwise we will get duplicates.
$activity->no_sitewide_cache = true;
$secondary_user_save = $activity->save();
}
do_action( 'bp_activity_record', $item_id, $component_name, $component_action, $is_private, $secondary_item_id, $user_id, $secondary_user_id );
return true;
}
function bp_activity_action_sitewide_feed() {
global $bp, $wp_query;
if ( $bp->current_component != $bp->activity->slug || $bp->current_action != 'feed' || $bp->displayed_user->id )
return false;
$wp_query->is_404 = false;
status_header( 200 );
include_once( 'bp-activity/feeds/bp-activity-sitewide-feed.php' );
die;
}
add_action( 'wp', 'bp_activity_action_sitewide_feed', 3 );
function bp_activity_action_personal_feed() {
global $bp, $wp_query;
if ( $bp->current_component != $bp->activity->slug || !$bp->displayed_user->id || $bp->current_action != 'feed' )
return false;
$wp_query->is_404 = false;
status_header( 200 );
include_once( 'bp-activity/feeds/bp-activity-personal-feed.php' );
die;
}
add_action( 'wp', 'bp_activity_action_personal_feed', 3 );
function bp_activity_action_friends_feed() {
global $bp, $wp_query;
if ( $bp->current_component != $bp->activity->slug || !$bp->displayed_user->id || $bp->current_action != 'my-friends' || $bp->action_variables[0] != 'feed' )
return false;
$wp_query->is_404 = false;
status_header( 200 );
include_once( 'bp-activity/feeds/bp-activity-friends-feed.php' );
die;
}
add_action( 'wp', 'bp_activity_action_friends_feed', 3 );
function bp_activity_get_last_updated() {
return BP_Activity_Activity::get_last_updated();
}
function bp_activity_get_sitewide_activity( $max_items = 30, $pag_num = false, $pag_page = false ) {
return BP_Activity_Activity::get_sitewide_activity( $max_items, $pag_num, $pag_page );
}
function bp_activity_get_user_activity( $user_id, $max_items = 30, $since = '-4 weeks', $pag_num = false, $pag_page = false ) {
return BP_Activity_Activity::get_activity_for_user( $user_id, $max_items, $since, $pag_num, $pag_page );
}
function bp_activity_get_friends_activity( $user_id, $max_items = 30, $since = '-4 weeks', $max_items_per_friend = false, $pag_num = false, $pag_page = false ) {
return BP_Activity_Activity::get_activity_for_friends( $user_id, $max_items, $since, $max_items_per_friend, $pag_num, $pag_page );
}
function bp_activity_delete( $item_id, $component_name, $component_action, $user_id, $secondary_item_id ) {
if ( !BP_Activity_Activity::delete( $item_id, $component_name, $component_action, $user_id, $secondary_item_id ) )
return false;
do_action( 'bp_activity_delete', $item_id, $component_name, $component_action, $user_id, $secondary_item_id );
return true;
}
function bp_activity_order_by_date( $a, $b ) {
return strcasecmp( $b['date_recorded'], $a['date_recorded'] );
}
function bp_activity_remove_data( $user_id ) {
// Clear the user's activity from the sitewide stream and clear their activity tables
BP_Activity_Activity::delete_activity_for_user( $user_id );
// Remove the deleted users activity tables
BP_Activity_Activity::kill_tables_for_user( $user_id );
do_action( 'bp_activity_remove_data', $user_id );
}
add_action( 'wpmu_delete_user', 'bp_activity_remove_data' );
add_action( 'delete_user', 'bp_activity_remove_data' );
?>