• Jetzt anmelden. Es dauert nur 2 Minuten und ist kostenlos!

Twitter API 1.1 funktioniert nicht mehr

Congo1692

Neues Mitglied
Hallo zusammen,

und zwar habe ich ein Problem seit einer Woche ungefähr funktioniert mein Twitter Feed nicht mehr, habe im Internet gelesen das Twitter die API von 1 auf 1.1 umgestellt hat ich weiß jetzt nicht was ich an mein Code ändern muss kann mir einer weiter helfen?

Code:
/*TWITTER PLUGIN STARTS*/(function($) {


  $.fn.tweet = function(o){
    var s = $.extend({
      username: null,                           // [string or array] required unless using the 'query' option; one or more twitter screen names
      list: null,                               // [string]   optional name of list belonging to username
      favorites: false,                         // [boolean]  display the user's favorites instead of his tweets
      query: null,                              // [string]   optional search query
      avatar_size: null,                        // [integer]  height and width of avatar if displayed (48px max)
      count: 1,                                 // [integer]  how many tweets to display?
      fetch: null,                              // [integer]  how many tweets to fetch via the API (set this higher than 'count' if using the 'filter' option)
      retweets: true,                           // [boolean]  whether to fetch (official) retweets (not supported in all display modes)
      intro_text: null,                         // [string]   do you want text BEFORE your your tweets?
      outro_text: null,                         // [string]   do you want text AFTER your tweets?
      join_text:  null,                         // [string]   optional text in between date and tweet, try setting to "auto"
      auto_join_text_default: "i said,",        // [string]   auto text for non verb: "i said" bullocks
      auto_join_text_ed: "i",                   // [string]   auto text for past tense: "i" surfed
      auto_join_text_ing: "i am",               // [string]   auto tense for present tense: "i was" surfing
      auto_join_text_reply: "i replied to",     // [string]   auto tense for replies: "i replied to" @someone "with"
      auto_join_text_url: "i was looking at",   // [string]   auto tense for urls: "i was looking at" http:...
      loading_text: null,                       // [string]   optional loading text, displayed while tweets load
      refresh_interval: null ,                  // [integer]  optional number of seconds after which to reload tweets
      twitter_url: "twitter.com",               // [string]   custom twitter url, if any (apigee, etc.)
      twitter_api_url: "api.twitter.com",       // [string]   custom twitter api url, if any (apigee, etc.)
      twitter_search_url: "search.twitter.com", // [string]   custom twitter search url, if any (apigee, etc.)
      template: "{avatar}{text}{join}{time}",   // [string or function] template used to construct each tweet <li> - see code for available vars
      comparator: function(tweet1, tweet2) {    // [function] comparator used to sort tweets (see Array.sort)
        return tweet2["tweet_time"] - tweet1["tweet_time"];
      },
      filter: function(tweet) {                 // [function] whether or not to include a particular tweet (be sure to also set 'fetch')
        return true;
      }
    }, o);


    $.fn.extend({
      linkUrl: function() {
        var returning = [];
        // See http://daringfireball.net/2010/07/improved_regex_for_matching_urls
        var regexp = /\b((?:[a-z][\w-]+:(?:\/{1,3}|[a-z0-9%])|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}\/)(?:[^\s()<>]+|\(([^\s()<>]+|(\([^\s()<>]+\)))*\))+(?:\(([^\s()<>]+|(\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:'".,<>?«»“”‘’]))/gi;
        this.each(function() {
          returning.push(this.replace(regexp,
                                      function(match) {
                                        var url = (/^[a-z]+:/i).test(match) ? match : "http://"+match;
                                        return "<a href=\""+url+"\">"+match+"</a>";
                                      }));
        });
        return $(returning);
      },
      linkUser: function() {
        var returning = [];
        var regexp = /[\@]+(\w+)/gi;
        this.each(function() {
          returning.push(this.replace(regexp,"@<a href=\"http://"+s.twitter_url+"/$1\">$1</a>"));
        });
        return $(returning);
      },
      linkHash: function() {
        var returning = [];
        // Support various latin1 (\u00**) and arabic (\u06**) alphanumeric chars
        var regexp = /(?:^| )[\#]+([\w\u00c0-\u00d6\u00d8-\u00f6\u00f8-\u00ff\u0600-\u06ff]+)/gi;
        var usercond = (s.username && s.username.length == 1) ? '&from='+s.username.join("%2BOR%2B") : '';
        this.each(function() {
          returning.push(this.replace(regexp, ' <a href="http://'+s.twitter_search_url+'/search?q=&tag=$1&lang=all'+usercond+'">#$1</a>'));
        });
        return $(returning);
      },
      capAwesome: function() {
        var returning = [];
        this.each(function() {
          returning.push(this.replace(/\b(awesome)\b/gi, '<span class="awesome">$1</span>'));
        });
        return $(returning);
      },
      capEpic: function() {
        var returning = [];
        this.each(function() {
          returning.push(this.replace(/\b(epic)\b/gi, '<span class="epic">$1</span>'));
        });
        return $(returning);
      },
      makeHeart: function() {
        var returning = [];
        this.each(function() {
          returning.push(this.replace(/(&lt;)+[3]/gi, "<tt class='heart'>♥</tt>"));
        });
        return $(returning);
      }
    });


    function parse_date(date_str) {
      // The non-search twitter APIs return inconsistently-formatted dates, which Date.parse
      // cannot handle in IE. We therefore perform the following transformation:
      // "Wed Apr 29 08:53:31 +0000 2009" => "Wed, Apr 29 2009 08:53:31 +0000"
      return Date.parse(date_str.replace(/^([a-z]{3})( [a-z]{3} \d\d?)(.*)( \d{4})$/i, '$1,$2$4$3'));
    }


    function relative_time(date) {
      var relative_to = (arguments.length > 1) ? arguments[1] : new Date();
      var delta = parseInt((relative_to.getTime() - date) / 1000, 10);
      var r = '';
      if (delta < 60) {
        r = delta + ' Sekunden';
      } else if(delta < 120) {
        r = 'einer Minute';
      } else if(delta < (45*60)) {
        r = (parseInt(delta / 60, 10)).toString() + ' Minuten';
      } else if(delta < (2*60*60)) {
        r = 'einer Stunde';
      } else if(delta < (24*60*60)) {
        r = '' + (parseInt(delta / 3600, 10)).toString() + ' Stunden';
      } else if(delta < (48*60*60)) {
        r = 'einem Tag';
      } else {
        r = (parseInt(delta / 86400, 10)).toString() + ' Tagen';
      }
      return 'vor ' + r;
    }


    function build_url() {
      var proto = ('https:' == document.location.protocol ? 'https:' : 'http:');
      var count = (s.fetch === null) ? s.count : s.fetch;
      if (s.list) {
        return proto+"//"+s.twitter_api_url+"/1/"+s.username[0]+"/lists/"+s.list+"/statuses.json?per_page="+count+"&callback=?";
      } else if (s.favorites) {
        return proto+"//"+s.twitter_api_url+"/favorites/"+s.username[0]+".json?count="+s.count+"&callback=?";
      } else if (s.query === null && s.username.length == 1) {
        return proto+'//'+s.twitter_api_url+'/1/statuses/user_timeline.json?screen_name='+s.username[0]+'&count='+count+(s.retweets ? '&include_rts=1' : '')+'&callback=?';
      } else {
        var query = (s.query || 'from:'+s.username.join(' OR from:'));
        return proto+'//'+s.twitter_search_url+'/search.json?&q='+encodeURIComponent(query)+'&rpp='+count+'&callback=?';
      }
    }


    return this.each(function(i, widget){
      var list = $('<ul class="tweet_list">').appendTo(widget);
      var intro = '<p class="tweet_intro">'+s.intro_text+'</p>';
      var outro = '<p class="tweet_outro">'+s.outro_text+'</p>';
      var loading = $('<p class="loading">'+s.loading_text+'</p>');


      if(s.username && typeof(s.username) == "string"){
        s.username = [s.username];
      }
 
Die Version 1.1 ist bereits seit Mitte letzten Jahres raus, erst seit März 2013 Pflicht. In der Zeit hatten Entwickler eigentlich Zeit ihre Anwendungen an die neuen Anforderungen anzupassen. Denn die erfordern zahlreiche Änderungen im Quellcode. Ich würde dir empfehlen deine Anbindung komplett neu zu entwickeln. Es gibt auch schöne Anleitungen dafür, wie z.B. hier:
Creating a Custom jQuery Twitter Feed (API v1.1)
 
Vielen Dank für die schnelle Antwort, also kann ich den Code nicht mehr verwenden? Das Problem ist ich habe diese Webseite mal für 49€ gekauft und kenne mich nicht so sehr damit aus die Farben und kleine Sachen kann ich ändern aber so der Rest ist echt schwer. Hatte jetzt gehofft das ich nur paar Sachen ändern muss werde mal versuchen das ich den Verkäufer erreiche. Wenn nicht werde ich einfach drauf verzichten.

Mit freundlichen Grüßen
 
Ich glaube kaum, dass jemand der eine Webseite (?) für 49 Euro dir einfach mal so noch etwas programmiert. Da wirst Du vermutlich draufzahlen müssen. Könnte dir aber ebenso gut jeder andere, der sich mit der twitter API auskennt, programmieren. Kannst ja auch hier im Forum in der Jobbörse mal fragen.
 
Schönen Guten Tag

ich würde ganz gerne das Angebot annehmen das jemand den Code für mich schreibt, das sollte aber an mein Design angepasst sein.

Wenn jemand zu bereit wäre kann er mich gerne Privat anschreiben dann kann man über die Bezahlung schreiben.

Mit freundlichen Grüßen
 
Zurück
Oben